:root{--color-white: #ffffff;--color-gray-50: #f8f8f8;--color-gray-100: #f5f5f5;--color-gray-200: #e8e8e8;--color-gray-300: #d0d0d0;--color-gray-400: #b0b0b0;--color-gray-500: #808080;--color-gray-600: #505050;--color-gray-700: #333333;--color-gray-800: #2a2a2a;--color-gray-900: #1a1a1a;--color-success: #4caf50;--color-success-light: #e8f5e9;--color-success-dark: #2e7d32;--color-error: #d32f2f;--color-error-light: #ffebee;--color-error-dark: #c62828;--color-warning: #ffa500;--color-warning-light: #fff3e0;--color-warning-dark: #e65100;--color-info: #2196f3;--color-info-light: #e3f2fd;--color-info-dark: #1565c0;--color-belt-white: #f0f0f0;--color-belt-yellow: #ffc400;--color-belt-orange: #ff8c00;--color-belt-green: #4caf50;--color-belt-blue: #2196f3;--color-belt-brown: #8b6914;--color-belt-black: #1a1a1a;--color-primary: #646cff;--color-primary-light: #f0f4ff;--color-primary-dark: #535bf2;--color-surface-bg: #ffffff;--color-surface-raised: #ffffff;--color-surface-overlay: rgba(0, 0, 0, .05);--color-border: #ddd;--color-border-light: #e8e8e8;--color-text-primary: #333333;--color-text-secondary: #666666;--color-text-tertiary: #999999;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 2.5rem;--radius-sm: .375rem;--radius-md: .75rem;--radius-lg: 1.25rem;--radius-full: 9999px;--motion-fast: .12s;--motion-normal: .22s;--motion-slow: .3s;--easing-ease-out: cubic-bezier(.4, 0, .2, 1);--easing-ease-in-out: cubic-bezier(.4, 0, .2, 1);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1);--shadow-xl: 0 10px 24px rgba(0, 0, 0, .15);font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-bold: 700;line-height:var(--line-height-normal);font-weight:var(--font-weight-regular);color-scheme:light dark;color:var(--color-text-primary);background-color:var(--color-surface-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:var(--font-weight-medium);color:var(--color-primary);text-decoration:inherit;transition:color var(--motion-normal)}a:hover{color:var(--color-primary-dark)}body{margin:0;display:flex;place-items:flex-start;min-width:320px;min-height:100vh}h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}h2{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}h3{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}h4{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}button{border-radius:var(--radius-md);border:1px solid transparent;padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);font-family:inherit;background-color:var(--color-gray-100);color:var(--color-text-primary);cursor:pointer;transition:all var(--motion-normal)}button:hover{background-color:var(--color-gray-200);border-color:var(--color-primary)}button:focus,button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:disabled{opacity:.5;cursor:not-allowed}@media(prefers-color-scheme:light){:root{--color-surface-bg: #ffffff;--color-text-primary: #333333;--color-text-secondary: #666666;--color-text-tertiary: #999999;--color-border: #ddd}a:hover{color:var(--color-primary-dark)}button{background-color:var(--color-gray-100);color:var(--color-text-primary)}}@media(prefers-color-scheme:dark){:root{--color-surface-bg: #1a1a1a;--color-surface-raised: #2a2a2a;--color-text-primary: #e0e0e0;--color-text-secondary: #b0b0b0;--color-text-tertiary: #808080;--color-border: #555;--color-border-light: #444}button{background-color:var(--color-gray-800);color:var(--color-text-primary)}}.page-container{width:100%;max-width:1280px;margin:0 auto;padding:var(--spacing-lg);box-sizing:border-box;animation:fadeIn var(--motion-normal) ease-out}.grid-lessons,.grid-items{display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.grid-stats{display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}@media(max-width:768px){.page-container{padding:var(--spacing-md)}.grid-lessons,.grid-items,.grid-stats{grid-template-columns:1fr;gap:var(--spacing-md)}}@media(max-width:480px){.page-container{padding:var(--spacing-sm)}}#root{max-width:1280px;margin:0 auto;padding:var(--spacing-xl);text-align:center}.app-header{position:fixed;top:0;left:0;right:0;background-color:var(--color-surface-bg);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);z-index:1000}.app-header-content{max-width:1280px;margin:0 auto;padding:var(--spacing-md) var(--spacing-xl);display:flex;justify-content:space-between;align-items:center}.app-header-logo{background:none;border:none;cursor:pointer;padding:0;margin:0;display:flex;align-items:center;gap:var(--spacing-sm)}.app-header-logo h1{margin:0;font-size:var(--font-size-2xl);color:var(--color-text-primary);transition:color var(--motion-normal)}.app-header-logo:hover h1{color:var(--color-primary)}.app-main{padding-top:80px}.card{padding:var(--spacing-xl);background-color:var(--color-surface-raised);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.section-progress-block{margin-top:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-gray-100);transition:all var(--motion-normal)}.section-progress-label{margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.section-progress-bar-container{height:8px;background-color:var(--color-gray-300);border-radius:4px;overflow:hidden}.section-progress-bar-fill{height:100%;transition:width var(--motion-normal);background-color:var(--color-primary)}.section-progress-bar-fill.status-complete{background-color:var(--color-success)}.section-progress-bar-fill.status-in-progress{background-color:var(--color-info)}.section-progress-bar-fill.status-not-started{background-color:var(--color-gray-400)}.container{max-width:800px;margin:0 auto;padding:var(--spacing-lg);text-align:left}.header{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.back-button{padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-raised);font-size:var(--font-size-sm);color:var(--color-text-primary);transition:all var(--motion-normal);margin-bottom:var(--spacing-md)}.back-button:hover{background-color:var(--color-gray-100);border-color:var(--color-text-secondary)}.item-card{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);background-color:var(--color-surface-raised);color:var(--color-text-primary);transition:all var(--motion-normal);box-shadow:var(--shadow-sm)}.item-card-content{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.item-card-text h3{margin-top:0;margin-bottom:var(--spacing-sm);font-size:var(--font-size-lg);color:var(--color-text-primary)}.item-card-text p{margin:0 0 var(--spacing-sm) 0;color:var(--color-text-secondary)}.item-card-type{background-color:var(--color-gray-200);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-left:var(--spacing-md)}.item-card-description{color:var(--color-text-secondary);margin-bottom:var(--spacing-md);font-size:var(--font-size-base)}.item-card-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.item-card-tag{background-color:var(--color-info-light);color:var(--color-info-dark);padding:2px var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);transition:all var(--motion-normal)}.item-card-tag:hover{background-color:var(--color-info);color:#fff}.item-card-difficulty{color:var(--color-belt-orange);font-size:var(--font-size-lg)}.practice-item-card{background-color:var(--color-surface-raised);border-radius:var(--radius-lg);padding:var(--spacing-2xl);box-shadow:var(--shadow-md);max-width:600px;margin:0 auto;color:var(--color-text-primary)}.practice-item-card-header{text-align:center;margin-bottom:var(--spacing-2xl)}.practice-item-card-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.practice-item-card-jp{font-size:32px;font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-lg);color:var(--color-text-primary)}.practice-item-card-answer{font-size:var(--font-size-2xl);text-align:center;margin-bottom:var(--spacing-2xl);color:var(--color-text-primary)}.practice-item-card-alternative{font-size:var(--font-size-base);text-align:center;margin-bottom:var(--spacing-2xl);color:var(--color-text-secondary)}.error-message{padding:var(--spacing-lg);background-color:var(--color-error-light);border:1px solid #ffcccc;border-radius:var(--radius-md);color:var(--color-error-dark);text-align:center}.exercise-start{display:flex;flex-direction:column;gap:var(--spacing-2xl);margin-top:var(--spacing-lg)}.lesson-info{text-align:center;padding:var(--spacing-lg);background-color:var(--color-gray-100);border-radius:var(--radius-md)}.direction-selector{padding:var(--spacing-lg);border:1px solid var(--color-border);border-radius:var(--radius-md)}.radio-group{display:flex;flex-direction:column;gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.radio-label{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--motion-normal);background-color:var(--color-surface-raised)}.radio-label:hover{background-color:var(--color-gray-100);border-color:var(--color-primary)}.radio-label input[type=radio]:checked+span{font-weight:var(--font-weight-bold);color:var(--color-primary)}.radio-label input[type=radio]{cursor:pointer}.button{padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-raised);font-size:var(--font-size-base);color:var(--color-text-primary);transition:all var(--motion-normal)}.button:hover{background-color:var(--color-gray-100);border-color:var(--color-primary)}.button:disabled{opacity:.5;cursor:not-allowed}.button-primary{background-color:var(--color-primary);color:#fff;border:none;font-weight:var(--font-weight-bold)}.button-primary:hover:not(:disabled){background-color:var(--color-primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.exercise-header{text-align:center;margin-bottom:var(--spacing-lg)}.direction-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--spacing-sm)}.progress-bar-container{margin:var(--spacing-lg) 0}.progress-info{display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.progress-bar{height:8px;background-color:var(--color-gray-300);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background-color:var(--color-primary);transition:width var(--motion-normal)}.question-card{background-color:var(--color-surface-raised);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin:var(--spacing-lg) 0;transition:all var(--motion-normal)}.question-text{text-align:center;margin-bottom:var(--spacing-2xl)}.question-text h3{font-size:32px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.answer-options{display:flex;flex-direction:column;gap:var(--spacing-md)}.answer-option{padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-raised);cursor:pointer;font-size:var(--font-size-lg);text-align:left;transition:all var(--motion-normal);color:var(--color-text-primary)}.answer-option.selected{border-color:var(--color-primary);background-color:var(--color-primary-light);color:var(--color-primary-dark)}.answer-option.correct{border-color:var(--color-success);background-color:var(--color-success-light);color:var(--color-success-dark)}.answer-option.incorrect{border-color:var(--color-error);background-color:var(--color-error-light);color:var(--color-error-dark)}.answer-option:disabled{cursor:not-allowed}.feedback{margin-top:var(--spacing-lg);padding:var(--spacing-lg);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);text-align:center;animation:slideIn var(--motion-normal) ease-out}.feedback.correct{background-color:var(--color-success-light);color:var(--color-success-dark)}.feedback.incorrect{background-color:var(--color-error-light);color:var(--color-error-dark)}.exercise-actions{display:flex;justify-content:center;margin-top:var(--spacing-2xl);gap:var(--spacing-md)}.exercise-summary{display:flex;flex-direction:column;gap:var(--spacing-2xl);align-items:center;padding:var(--spacing-2xl) var(--spacing-lg)}.summary-card{width:100%;max-width:500px;background-color:var(--color-surface-raised);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);text-align:center}.summary-stats{display:flex;justify-content:space-around;margin:var(--spacing-2xl) 0}.stat-item{display:flex;flex-direction:column;gap:var(--spacing-sm)}.stat-value{font-size:36px;font-weight:var(--font-weight-bold);color:var(--color-primary)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.score-message{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);padding:var(--spacing-lg);border-radius:var(--radius-md);margin-top:var(--spacing-lg);animation:slideIn var(--motion-slow) ease-out}.score-message.excellent{background-color:var(--color-success-light);color:var(--color-success-dark)}.score-message.good{background-color:var(--color-warning-light);color:var(--color-warning-dark)}.score-message.needs-practice{background-color:var(--color-error-light);color:var(--color-error-dark)}.summary-actions{display:flex;gap:var(--spacing-md);flex-wrap:wrap;justify-content:center}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.matching-exercise{max-width:900px;margin:0 auto;padding:var(--spacing-lg)}.matching-instructions{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl)}.matching-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl);margin:var(--spacing-2xl) 0}.matching-column{display:flex;flex-direction:column;gap:var(--spacing-md)}.matching-column h3{text-align:center;margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.matching-item{padding:var(--spacing-lg);background-color:var(--color-surface-raised);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--motion-normal);display:flex;justify-content:space-between;align-items:center;min-height:60px;color:var(--color-text-primary)}.matching-item:hover:not(.matched){border-color:var(--color-primary);transform:translate(5px);box-shadow:var(--shadow-md)}.matching-item.selected{border-color:var(--color-primary);background-color:var(--color-primary-light);box-shadow:var(--shadow-md)}.matching-item.matched{border-color:var(--color-success);background-color:var(--color-success-light);cursor:default;color:var(--color-success-dark)}.matching-item.clickable{cursor:pointer}.matching-item-image{display:flex;gap:var(--spacing-md);align-items:center}.matching-item-image img{width:40px;height:40px;object-fit:cover;border-radius:var(--radius-sm)}.check-mark{color:var(--color-success);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}.matching-actions{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-2xl)}.matching-progress{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.typing-exercise{max-width:600px;margin:0 auto;padding:var(--spacing-lg)}.typing-input{width:100%;padding:var(--spacing-lg);font-size:var(--font-size-lg);border:2px solid var(--color-border);border-radius:var(--radius-md);margin:var(--spacing-lg) 0;transition:all var(--motion-normal);background-color:var(--color-surface-raised);color:var(--color-text-primary);font-family:inherit}.typing-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.typing-input:disabled{background-color:var(--color-gray-200);cursor:not-allowed;opacity:.6}.feedback-warning{background-color:var(--color-warning-light);color:var(--color-warning-dark)}.feedback-error{background-color:var(--color-error-light);color:var(--color-error-dark)}.feedback-success{background-color:var(--color-success-light);color:var(--color-success-dark)}.hint{font-size:var(--font-size-sm);margin-top:var(--spacing-md);font-style:italic;color:var(--color-text-secondary)}.correct-answer{font-size:var(--font-size-base);margin-top:var(--spacing-md);font-weight:var(--font-weight-bold);color:var(--color-success-dark)}.typing-hints{margin-top:var(--spacing-lg);text-align:center}.hint-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.ordering-exercise{max-width:700px;margin:0 auto;padding:var(--spacing-lg)}.ordering-instructions{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl)}.ordering-list{display:flex;flex-direction:column;gap:var(--spacing-md);margin:var(--spacing-2xl) 0}.ordering-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background-color:var(--color-surface-raised);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:move;transition:all var(--motion-normal);color:var(--color-text-primary)}.ordering-item:hover{border-color:var(--color-primary);transform:translate(5px);box-shadow:var(--shadow-md)}.ordering-item.misplaced{border-color:var(--color-error);background-color:var(--color-error-light);color:var(--color-error-dark)}.ordering-item.correct{border-color:var(--color-success);background-color:var(--color-success-light);color:var(--color-success-dark)}.ordering-item-number{min-width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:var(--color-primary);color:#fff;border-radius:50%;font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);flex-shrink:0}.ordering-item.correct .ordering-item-number{background-color:var(--color-success)}.ordering-item-text{flex:1;font-size:var(--font-size-base);color:var(--color-text-primary)}.ordering-item-controls{display:flex;gap:var(--spacing-sm)}.ordering-button{width:36px;height:36px;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-raised);cursor:pointer;font-size:var(--font-size-base);transition:all var(--motion-normal);color:var(--color-text-primary)}.ordering-button:hover:not(:disabled){background-color:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.ordering-button:disabled{opacity:.3;cursor:not-allowed}.ordering-actions{display:flex;justify-content:center;margin-top:var(--spacing-2xl)}.correct-order-hint{margin-top:var(--spacing-lg);padding:var(--spacing-lg);background-color:var(--color-gray-100);border-radius:var(--radius-md);border-left:4px solid var(--color-primary)}.correct-order-hint ol{text-align:left;margin:var(--spacing-md) 0 0 var(--spacing-lg);color:var(--color-text-primary)}.correct-order-hint li{margin:var(--spacing-sm) 0}.exercise-type-selector{margin:var(--spacing-2xl) 0}.exercise-type-selector h3{margin-bottom:var(--spacing-md)}.image-exercise{max-width:600px;margin:0 auto;padding:var(--spacing-lg)}.image-exercise-question{margin-bottom:var(--spacing-2xl);text-align:center}.image-exercise-question h3{margin-bottom:var(--spacing-lg);font-size:var(--font-size-xl);color:var(--color-text-primary)}.image-exercise-image-container{display:flex;justify-content:center;align-items:center;margin:var(--spacing-lg) 0;padding:var(--spacing-lg);background-color:var(--color-gray-100);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.image-exercise-image{max-width:100%;max-height:400px;height:auto;border-radius:var(--radius-md);object-fit:contain}.image-exercise-options{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.image-exercise-option{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-lg);background-color:var(--color-surface-raised);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--motion-normal);text-align:center;color:var(--color-text-primary)}.image-exercise-option:hover:not(:disabled){background-color:var(--color-gray-100);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.image-exercise-option.selected{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary-dark);font-weight:var(--font-weight-bold)}.image-exercise-option:disabled{opacity:.6;cursor:not-allowed}.image-exercise-actions{display:flex;justify-content:center;margin-top:var(--spacing-xl)}@media(max-width:768px){.matching-grid{grid-template-columns:1fr}.image-exercise-image{max-height:300px}.image-exercise-option{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base)}}@media(prefers-color-scheme:dark){:root{--color-surface-bg: #1a1a1a;--color-surface-raised: #2a2a2a;--color-text-primary: #e0e0e0;--color-text-secondary: #b0b0b0;--color-text-tertiary: #808080;--color-border: #555;--color-border-light: #444}:root{--color-success-light: #1b5e20;--color-success-dark: #81c784;--color-error-light: #b71c1c;--color-error-dark: #e57373;--color-warning-light: #e65100;--color-warning-dark: #ffb74d;--color-info-light: #1e3a5f;--color-info-dark: #64b5f6}:root{--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 2px 8px rgba(0, 0, 0, .5);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .5);--shadow-xl: 0 10px 24px rgba(0, 0, 0, .6)}}.btn-primary{background-color:var(--color-primary);color:write;border:none;font-weight:var(--font-weight-bold);transition:all var(--motion-normal)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--color-gray-200);color:var(--color-text-primary);border:1px solid var(--color-border);font-weight:var(--font-weight-medium);transition:all var(--motion-normal)}.btn-secondary:hover:not(:disabled){background-color:var(--color-gray-300);border-color:var(--color-primary);color:var(--color-primary)}.btn-ghost{background-color:transparent;color:var(--color-primary);border:1px solid var(--color-primary);font-weight:var(--font-weight-medium);transition:all var(--motion-normal)}.btn-ghost:hover:not(:disabled){background-color:var(--color-primary-light);border-color:var(--color-primary-dark)}.btn-danger{background-color:var(--color-error);position:relative;border:none;font-weight:var(--font-weight-bold);transition:all var(--motion-normal)}.btn-danger:hover:not(:disabled){background-color:var(--color-error-dark);box-shadow:var(--shadow-lg)}.btn-success{background-color:var(--color-success);color:#fff;border:none;font-weight:var(--font-weight-bold);transition:all var(--motion-normal)}.btn-success:hover:not(:disabled){background-color:var(--color-success-dark);box-shadow:var(--shadow-lg)}.btn-sm{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.btn-lg{padding:var(--spacing-lg) var(--spacing-xl);font-size:var(--font-size-lg)}.btn-full{width:100%}.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled{opacity:.5;cursor:not-allowed;@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-warning{background-color:var(--color-warning);color:#fff;border:none;font-weight:var(--font-weight-bold);transition:all var(--motion-normal)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-warning:hover:not(:disabled){background-color:var(--color-warning-dark);box-shadow:var(--shadow-lg)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-link{background-color:transparent;color:var(--color-primary);border:none;text-decoration:underline;padding:var(--spacing-sm) 0;font-weight:var(--font-weight-medium);cursor:pointer;transition:color var(--motion-normal)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-link:hover:not(:disabled){color:var(--color-primary-dark)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-sm{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-lg{padding:var(--spacing-lg) var(--spacing-xl);font-size:var(--font-size-lg)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-xl{padding:var(--spacing-xl) var(--spacing-2xl);font-size:var(--font-size-lg)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-full{width:100%}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-block{display:block;width:100%}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-icon{padding:var(--spacing-md);aspect-ratio:1;display:flex;align-items:center;justify-content:center}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-loading{pointer-events:none;opacity:.85}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-loading:after{content:"";display:inline-block;width:1em;height:1em;margin-left:var(--spacing-sm);border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin var(--motion-normal) linear infinite;opacity:.7}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-loading.btn-sm:after{width:.8em;height:.8em;margin-left:var(--spacing-xs)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-icon-left{display:inline-flex;align-items:center;gap:var(--spacing-sm)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-icon-right{display:inline-flex;align-items:center;gap:var(--spacing-sm);flex-direction:row-reverse}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-badge{position:relative}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-badge:before{content:attr(data-badge);position:absolute;top:-8px;right:-8px;background-color:var(--color-error);color:#fff;border-radius:var(--radius-full);width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);border:2px solid var(--color-surface-bg)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-primary:disabled,:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-secondary:disabled,:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-ghost:disabled,:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-danger:disabled,:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-success:disabled,:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-warning:disabled,:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-link:disabled,:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-icon:disabled{opacity:.5;cursor:not-allowed;transform:none!important}@media(prefers-color-scheme:dark){:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-secondary{background-color:var(--color-gray-800);border-color:var(--color-border)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-secondary:hover:not(:disabled){background-color:var(--color-gray-700)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-ghost{border-color:var(--color-primary)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-ghost:hover:not(:disabled){background-color:var(--color-primary-light);border-color:var(--color-primary-dark)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-link{color:var(--color-primary)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-link:hover:not(:disabled){color:var(--color-primary-dark)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-badge:before{border-color:var(--color-surface-bg)}}@media(max-width:640px){:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base)}:is(.btn-primary:disabled,.btn-secondary:disabled,.btn-ghost:disabled,.btn-danger:disabled,.btn-success:disabled) .btn-block{display:flex;width:100%}}.card{background-color:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);transition:all var(--motion-normal)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.card-header h2,.card-header h3{margin:0;color:var(--color-text-primary)}.card-body{color:var(--color-text-primary)}.card-footer{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border);display:flex;gap:var(--spacing-md);justify-content:flex-end}.card-elevated,.card-elevated:hover{box-shadow:var(--shadow-xl)}.card-compact{padding:var(--spacing-md)}.card-interactive{cursor:pointer;border:2px solid transparent}.card-interactive:hover{border-color:var(--color-primary);background-color:var(--color-primary-light)}.card-interactive:active{transform:translateY(0)}.card-success{border-left:4px solid var(--color-success)}.card-error{border-left:4px solid var(--color-error)}.card-warning{border-left:4px solid var(--color-warning)}.card-info{border-left:4px solid var(--color-info)}.card-locked{opacity:.6;border:2px dashed var(--color-border);background-color:var(--color-gray-100)}.card-completed{border-left:4px solid var(--color-success);background-color:var(--color-success-light)}.card-completed h3{color:var(--color-success-dark)}.card-with-progress{padding-bottom:var(--spacing-xl)}.card-progress{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.m-xs{margin:var(--spacing-xs)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.m-lg{margin:var(--spacing-lg)}.m-xl{margin:var(--spacing-xl)}.mx-auto{margin-left:auto;margin-right:auto}.my-auto{margin-top:auto;margin-bottom:auto}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-center{align-items:center;justify-content:center}.justify-between{justify-content:space-between}.items-center{align-items:center}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.text-4xl{font-size:var(--font-size-4xl)}.font-normal{font-weight:var(--font-weight-regular)}.font-medium{font-weight:var(--font-weight-medium)}.font-bold{font-weight:var(--font-weight-bold)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-warning{color:var(--color-warning)}.text-info{color:var(--color-info)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.bg-primary{background-color:var(--color-primary)}.bg-success{background-color:var(--color-success)}.bg-error{background-color:var(--color-error)}.bg-warning{background-color:var(--color-warning)}.bg-info{background-color:var(--color-info)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-gray-200{background-color:var(--color-gray-200)}.border{border:1px solid var(--color-border)}.border-top{border-top:1px solid var(--color-border)}.border-bottom{border-bottom:1px solid var(--color-border)}.border-left{border-left:1px solid var(--color-border)}.border-right{border-right:1px solid var(--color-border)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.transition-fast{transition:all var(--motion-fast)}.transition-normal{transition:all var(--motion-normal)}.transition-slow{transition:all var(--motion-slow)}.hidden{display:none}.block{display:block}.inline{display:inline}.inline-block{display:inline-block}.w-full{width:100%}.h-full{height:100%}.z-dropdown{z-index:1000}.z-sticky{z-index:100}.z-base{z-index:1}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.stack-sm{display:flex;flex-direction:column;gap:var(--spacing-sm)}.stack-md{display:flex;flex-direction:column;gap:var(--spacing-md)}.stack-lg{display:flex;flex-direction:column;gap:var(--spacing-lg)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.loading{pointer-events:none;opacity:.6}.focus-ring:focus{outline:2px solid var(--color-primary);outline-offset:2px}@media(max-width:640px){.sm\:hidden{display:none!important}.sm\:flex{display:flex!important}.sm\:p-sm{padding:var(--spacing-sm)!important}.sm\:gap-sm{gap:var(--spacing-sm)!important}}@media(max-width:768px){.md\:hidden{display:none!important}.md\:flex{display:flex!important}.md\:flex-col{flex-direction:column!important}}@media(max-width:1024px){.lg\:hidden{display:none!important}}.grade-white,.belt-white{--accent-color: var(--color-belt-white);--accent-text: var(--color-text-primary)}.grade-yellow,.belt-yellow{--accent-color: var(--color-belt-yellow);--accent-text: #333}.grade-orange,.belt-orange{--accent-color: var(--color-belt-orange);--accent-text: white}.grade-green,.belt-green{--accent-color: var(--color-belt-green);--accent-text: white}.grade-blue,.belt-blue{--accent-color: var(--color-belt-blue);--accent-text: white}.grade-brown,.belt-brown{--accent-color: var(--color-belt-brown);--accent-text: white}.grade-black,.belt-black{--accent-color: var(--color-belt-black);--accent-text: white}.progress-ring-accent{color:var(--accent-color)}.progress-ring-accent circle{stroke:var(--accent-color)}.badge-accent{background-color:var(--accent-color);color:var(--accent-text);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);display:inline-block}.card-accent{border-left:4px solid var(--accent-color)}.section-progress-fill{background-color:var(--accent-color)!important}.difficulty-stars{color:var(--accent-color)}.difficulty-stars::selection{color:var(--accent-text)}.btn-grade-accent{background-color:var(--accent-color);color:var(--accent-text);border:none;font-weight:var(--font-weight-bold);transition:all var(--motion-normal)}.btn-grade-accent:hover:not(:disabled){opacity:.9;transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-grade-accent:active:not(:disabled){transform:translateY(0)}.btn-grade-accent:disabled{opacity:.5;cursor:not-allowed}.achievement-accent{border:2px solid var(--accent-color);color:var(--accent-color);padding:var(--spacing-md);border-radius:var(--radius-lg);background-color:transparent;transition:all var(--motion-normal)}.achievement-accent.unlocked{background-color:var(--accent-color);color:var(--accent-text)}.achievement-accent.unlocked:before{content:"✓ "}.belt-white .card,.belt-white .btn-primary{box-shadow:var(--shadow-sm)}.belt-yellow .card,.belt-orange .card{box-shadow:var(--shadow-md)}.belt-green .card,.belt-blue .card,.belt-brown .card,.belt-black .card{box-shadow:var(--shadow-lg)}.grade-indicator{position:relative;padding-top:2rem}.grade-indicator:before{content:attr(data-grade);position:absolute;top:0;right:0;background-color:var(--accent-color);color:var(--accent-text);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em}@media(prefers-color-scheme:dark){.belt-white,.belt-yellow{--accent-text: var(--color-text-primary)}.achievement-accent{border-color:var(--accent-color)}.achievement-accent.unlocked{background-color:var(--accent-color)}}@media(max-width:768px){.grade-indicator:before{font-size:var(--font-size-xs);padding:var(--spacing-xs) var(--spacing-sm)}}.animation-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#00000080;z-index:1000;animation:fadeIn .3s ease-in}.animation-content{background:#fff;padding:2rem;border-radius:1rem;text-align:center;max-width:400px;animation:scaleIn .4s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes confetti{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(360deg);opacity:0}}.animation-slow{animation-duration:calc(var(--animation-duration, 1s) * 2)}.animation-fast{animation-duration:calc(var(--animation-duration, 1s) * .5)}@media(prefers-reduced-motion:reduce){.animation-overlay,.animation-content,*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(prefers-color-scheme:dark){.animation-content{background:#2a2a2a;color:#e0e0e0;@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideOutUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}@keyframes shimmer{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes jiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-2deg)}75%{transform:rotate(2deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spinReverse{0%{transform:rotate(360deg)}to{transform:rotate(0)}}@keyframes progressFill{0%{width:0%}}@keyframes popIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes floatUp{0%{transform:translateY(0);opacity:1}to{transform:translateY(-30px);opacity:0}}}.animation-content .animate-fade-in{animation:fadeIn var(--motion-normal) ease-out}.animation-content .animate-fade-out{animation:fadeOut var(--motion-normal) ease-out}.animation-content .animate-slide-up{animation:slideInUp var(--motion-normal) ease-out}.animation-content .animate-slide-down{animation:slideInDown var(--motion-normal) ease-out}.animation-content .animate-slide-left{animation:slideInLeft var(--motion-normal) ease-out}.animation-content .animate-slide-right{animation:slideInRight var(--motion-normal) ease-out}.animation-content .animate-scale-in{animation:scaleIn var(--motion-normal) ease-out}.animation-content .animate-pulse{animation:pulse 2s ease-in-out infinite}.animation-content .animate-shimmer{animation:shimmer 1.5s ease-in-out infinite}.animation-content .animate-spin{animation:spin var(--motion-normal) linear infinite}.animation-content .animate-bounce{animation:bounce var(--motion-normal) ease-in-out infinite}.animation-content .animate-float{animation:float 3s ease-in-out infinite}.animation-content .animate-pop-in{animation:popIn var(--motion-slow) cubic-bezier(.34,1.56,.64,1)}.animation-content .animate-fast{animation-duration:var(--motion-fast)!important}.animation-content .animate-normal{animation-duration:var(--motion-normal)!important}.animation-content .animate-slow{animation-duration:var(--motion-slow)!important}.animation-content .animate-delay-100{animation-delay:.1s}.animation-content .animate-delay-200{animation-delay:.2s}.animation-content .animate-delay-300{animation-delay:.3s}}.spinner{display:inline-block;width:48px;height:48px;border:4px solid var(--color-gray-200);border-top-color:var(--accent-color, var(--color-primary));border-radius:50%;animation:spin var(--motion-normal) linear infinite}.spinner.spinner-sm{width:24px;height:24px;border-width:3px}.spinner.spinner-lg{width:64px;height:64px;border-width:5px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--spacing-md);animation:fadeIn var(--motion-normal) ease-out}.loading-container.full-screen{min-height:100vh}.loading-text{color:var(--color-gray-600);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.skeleton{background:linear-gradient(90deg,var(--color-gray-100) 0%,var(--color-gray-200) 50%,var(--color-gray-100) 100%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-text{height:16px;margin-bottom:var(--spacing-xs)}.skeleton-text.skeleton-text-lg{height:24px}.skeleton-title{height:32px;width:60%;margin-bottom:var(--spacing-md)}.skeleton-card{background-color:var(--color-surface);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.skeleton-card .skeleton-header{display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.skeleton-card .skeleton-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(90deg,var(--color-gray-100) 0%,var(--color-gray-200) 50%,var(--color-gray-100) 100%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.skeleton-card .skeleton-content{display:flex;flex-direction:column;gap:var(--spacing-xs)}.skeleton-grid{display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}@media(max-width:768px){.skeleton-grid{grid-template-columns:1fr;gap:var(--spacing-md)}}.loading-overlay{position:fixed;inset:0;background-color:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:9998;animation:fadeIn var(--motion-fast) ease-out}@media(prefers-color-scheme:dark){.skeleton{background:linear-gradient(90deg,var(--color-gray-800) 0%,var(--color-gray-700) 50%,var(--color-gray-800) 100%);background-size:200% 100%}.skeleton-card{background-color:var(--color-surface-dark);border-color:var(--color-gray-700)}.skeleton-card .skeleton-avatar{background:linear-gradient(90deg,var(--color-gray-800) 0%,var(--color-gray-700) 50%,var(--color-gray-800) 100%);background-size:200% 100%}.loading-overlay{background-color:#1a1a1af2}.loading-text{color:var(--color-gray-400)}.spinner{border-color:var(--color-gray-700);border-top-color:var(--accent-color, var(--color-primary))}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-2xl);min-height:300px;animation:fadeIn var(--motion-normal) ease-out}.empty-state-icon{font-size:64px;margin-bottom:var(--spacing-lg);opacity:.5;animation:float 3s ease-in-out infinite}.empty-state-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-700);margin-bottom:var(--spacing-sm)}.empty-state-message{font-size:var(--font-size-base);color:var(--color-gray-600);max-width:400px;margin-bottom:var(--spacing-lg);line-height:var(--line-height-relaxed)}.empty-state-action{margin-top:var(--spacing-md)}.empty-state.empty-state-compact{min-height:200px;padding:var(--spacing-xl)}.empty-state.empty-state-compact .empty-state-icon{font-size:48px}.empty-state.empty-state-compact .empty-state-title{font-size:var(--font-size-xl)}@media(prefers-color-scheme:dark){.empty-state-title{color:var(--color-gray-300)}.empty-state-message{color:var(--color-gray-400)}}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-2xl);animation:slideInUp var(--motion-normal) ease-out}.error-card{background-color:var(--color-error-light);border:2px solid var(--color-error);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:500px;margin:0 auto;animation:shake var(--motion-normal) ease-in-out}.error-icon{font-size:48px;margin-bottom:var(--spacing-md)}.error-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-error);margin-bottom:var(--spacing-sm)}.error-message{font-size:var(--font-size-base);color:var(--color-error-dark);margin-bottom:var(--spacing-lg);line-height:var(--line-height-relaxed)}.error-actions{display:flex;gap:var(--spacing-sm);justify-content:center}.error-inline{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-error-light);border-left:4px solid var(--color-error);border-radius:var(--radius-sm);color:var(--color-error-dark);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.error-inline:before{content:"⚠️";font-size:var(--font-size-lg)}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}@media(prefers-color-scheme:dark){.error-card{background-color:#d32f2f1a;border-color:var(--color-error)}.error-message{color:var(--color-error-light)}.error-inline{background-color:#d32f2f26;color:var(--color-error-light)}}.success-card{background-color:var(--color-success-light);border:2px solid var(--color-success);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:500px;margin:0 auto;animation:popIn var(--motion-normal) ease-out}.success-icon{font-size:48px;margin-bottom:var(--spacing-md);text-align:center}.success-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-success-dark);margin-bottom:var(--spacing-sm);text-align:center}.success-message{font-size:var(--font-size-base);color:var(--color-success-dark);text-align:center;line-height:var(--line-height-relaxed)}@media(prefers-color-scheme:dark){.success-card{background-color:#4caf501a;border-color:var(--color-success)}.success-title,.success-message{color:var(--color-success-light)}}.toast-container{position:fixed;top:80px;right:var(--spacing-lg);z-index:10000;display:flex;flex-direction:column;gap:var(--spacing-sm);pointer-events:none}.toast{background-color:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--spacing-md) var(--spacing-lg);min-width:320px;max-width:480px;display:flex;align-items:start;gap:var(--spacing-sm);pointer-events:auto;animation:slideInRight var(--motion-fast) ease-out;position:relative;overflow:hidden;border-left:4px solid var(--toast-color)}.toast.toast-exit{animation:slideOutRight var(--motion-fast) ease-in}.toast-icon{font-size:var(--font-size-xl);flex-shrink:0;line-height:1}.toast-content{flex:1;min-width:0}.toast-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin-bottom:var(--spacing-xs)}.toast-message{font-size:var(--font-size-sm);color:var(--color-gray-600);line-height:var(--line-height-normal);word-wrap:break-word}.toast-close{background:none;border:none;color:var(--color-gray-500);font-size:var(--font-size-lg);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background-color var(--motion-fast),color var(--motion-fast);flex-shrink:0}.toast-close:hover{background-color:var(--color-gray-100);color:var(--color-gray-700)}.toast-progress{position:absolute;bottom:0;left:0;height:3px;background-color:var(--toast-color);opacity:.5;animation:progressShrink var(--toast-duration, 5s) linear}@keyframes progressShrink{0%{width:100%}to{width:0%}}.toast.toast-success{--toast-color: var(--color-success)}.toast.toast-error{--toast-color: var(--color-error)}.toast.toast-warning{--toast-color: var(--color-warning)}.toast.toast-info{--toast-color: var(--color-info)}.toast.toast-success .toast-icon{color:var(--color-success)}.toast.toast-error .toast-icon{color:var(--color-error)}.toast.toast-warning .toast-icon{color:var(--color-warning)}.toast.toast-info .toast-icon{color:var(--color-info)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}@media(prefers-color-scheme:dark){.toast{background-color:var(--color-surface-dark);border-left-color:var(--toast-color)}.toast-title{color:var(--color-gray-100)}.toast-message,.toast-close{color:var(--color-gray-400)}.toast-close:hover{background-color:var(--color-gray-800);color:var(--color-gray-200)}}@media(max-width:768px){.toast-container{top:70px;right:var(--spacing-sm);left:var(--spacing-sm)}.toast{min-width:0;max-width:100%}}@media(prefers-reduced-motion:reduce){.toast{animation:fadeIn var(--motion-fast) ease-out}.toast.toast-exit{animation:fadeOut var(--motion-fast) ease-in}}.item-card{background-color:var(--color-surface);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:box-shadow var(--motion-normal),transform var(--motion-normal);animation:slideInUp var(--motion-normal) ease-out}.item-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.item-card-content{display:flex;justify-content:space-between;align-items:start;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.item-card-text{flex:1}.item-card-text h3{margin:0 0 var(--spacing-xs) 0;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.item-card-primary{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-gray-800);margin:var(--spacing-xs) 0}.item-card-alternative{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:var(--spacing-xs) 0}.item-card-type{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px}.item-card-description{color:var(--color-gray-700);font-size:var(--font-size-base);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-md);padding:var(--spacing-sm);background-color:var(--color-gray-50);border-radius:var(--radius-sm);border-left:3px solid var(--color-primary)}.item-card-image{width:100%;max-height:200px;object-fit:cover;border-radius:var(--radius-md);margin-bottom:var(--spacing-md);box-shadow:var(--shadow-sm);transition:transform var(--motion-normal)}.item-card-image:hover{transform:scale(1.02)}.item-card-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.item-card-tag{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-gray-100);color:var(--color-gray-700);border-radius:var(--radius-full);font-size:var(--font-size-xs);border:1px solid var(--color-gray-200);transition:background-color var(--motion-fast),border-color var(--motion-fast)}.item-card-tag:hover{background-color:var(--color-gray-200);border-color:var(--color-gray-300)}.item-card-difficulty{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-lg);color:var(--accent-color, var(--color-primary));-webkit-user-select:none;user-select:none}.item-card-difficulty:before{content:"Difficulty:";font-size:var(--font-size-sm);color:var(--color-gray-600);font-weight:var(--font-weight-semibold);margin-right:var(--spacing-xs)}.item-card-difficulty .filled{color:var(--accent-color, var(--color-primary))}.item-card-difficulty .empty{color:var(--color-gray-300)}@media(prefers-color-scheme:dark){.item-card{background-color:var(--color-surface-dark);border-color:var(--color-gray-700)}.item-card-text h3{color:var(--color-gray-100)}.item-card-primary{color:var(--color-gray-200)}.item-card-alternative{color:var(--color-gray-400)}.item-card-description{background-color:var(--color-gray-800);color:var(--color-gray-300)}.item-card-type{background-color:var(--color-primary);color:var(--color-white)}.item-card-tag{background-color:var(--color-gray-800);color:var(--color-gray-300);border-color:var(--color-gray-700)}.item-card-tag:hover{background-color:var(--color-gray-700);border-color:var(--color-gray-600)}.item-card-difficulty:before{color:var(--color-gray-400)}}@media(max-width:768px){.item-card{padding:var(--spacing-md)}.item-card-text h3{font-size:var(--font-size-xl)}.item-card-primary{font-size:var(--font-size-base)}.item-card-image{max-height:150px}}.lesson-card{background-color:var(--color-surface);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-lg);cursor:pointer;transition:box-shadow var(--motion-normal),transform var(--motion-normal),border-color var(--motion-normal);position:relative;overflow:hidden;animation:slideInUp var(--motion-normal) ease-out}.lesson-card:before{content:"";position:absolute;left:0;top:0;height:100%;width:4px;background-color:var(--accent-color, var(--color-primary));transform:scaleY(0);transform-origin:bottom;transition:transform var(--motion-normal)}.lesson-card:hover:before{transform:scaleY(1);transform-origin:top}.lesson-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:var(--accent-color, var(--color-primary))}.lesson-card:active{transform:translateY(-2px)}.lesson-card:focus-visible{outline:2px solid var(--accent-color, var(--color-primary));outline-offset:2px}.lesson-card-title{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);transition:color var(--motion-fast)}.lesson-card:hover .lesson-card-title{color:var(--accent-color, var(--color-primary))}.lesson-card-meta{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-gray-600);font-size:var(--font-size-sm);margin:0}.lesson-card-meta:before{content:"📚";font-size:var(--font-size-base)}.lesson-card.completed{border-color:var(--color-success)}.lesson-card.completed:before{background-color:var(--color-success);transform:scaleY(1)}.lesson-card.completed .lesson-card-title:after{content:" ✓";color:var(--color-success);font-size:.8em}.lesson-card.locked{opacity:.6;cursor:not-allowed;border-style:dashed}.lesson-card.locked:hover{transform:none;box-shadow:none}.lesson-card.in-progress{border-color:var(--color-warning)}.lesson-card.in-progress:before{background-color:var(--color-warning);transform:scaleY(.5)}.lesson-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg);margin:var(--spacing-lg) 0}@media(prefers-color-scheme:dark){.lesson-card{background-color:var(--color-surface-dark);border-color:var(--color-gray-700)}.lesson-card:hover{border-color:var(--accent-color, var(--color-primary))}.lesson-card-title{color:var(--color-gray-100)}.lesson-card:hover .lesson-card-title{color:var(--accent-color, var(--color-primary))}.lesson-card-meta{color:var(--color-gray-400)}.lesson-card.completed{border-color:var(--color-success-light)}.lesson-card.in-progress{border-color:var(--color-warning-light)}}@media(max-width:768px){.lesson-card{padding:var(--spacing-md)}.lesson-card-title{font-size:var(--font-size-lg)}.lesson-cards-grid{grid-template-columns:1fr;gap:var(--spacing-md)}}@media(max-width:480px){.lesson-card{padding:var(--spacing-sm)}}.practice-item-card{background-color:var(--color-surface);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:600px;margin:0 auto;box-shadow:var(--shadow-lg);animation:scaleIn var(--motion-normal) ease-out}.practice-item-card-header{text-align:center;margin-bottom:var(--spacing-xl)}.practice-item-card-label{display:inline-block;padding:var(--spacing-xs) var(--spacing-md);background-color:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--spacing-md)}.practice-item-card-label.new{background-color:var(--color-info-light);color:var(--color-info)}.practice-item-card-label.review{background-color:var(--color-warning-light);color:var(--color-warning)}.practice-item-card-jp{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin:var(--spacing-lg) 0;animation:fadeIn var(--motion-normal) ease-out}.practice-item-card-image{max-width:300px;width:100%;height:auto;margin:0 auto var(--spacing-lg) auto;display:block;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);animation:fadeIn var(--motion-normal) ease-out;transition:transform var(--motion-normal)}.practice-item-card-image:hover{transform:scale(1.05)}.practice-item-card-answer{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-800);text-align:center;margin:var(--spacing-lg) 0;padding:var(--spacing-md);background-color:var(--color-gray-50);border-radius:var(--radius-md);border-left:4px solid var(--accent-color, var(--color-primary));animation:slideInUp var(--motion-normal) ease-out}.practice-item-card-alternative{font-size:var(--font-size-base);color:var(--color-gray-600);text-align:center;margin:var(--spacing-sm) 0 var(--spacing-lg) 0;font-style:italic}.practice-item-card-actions{display:flex;gap:var(--spacing-md);justify-content:center;margin-top:var(--spacing-xl)}.practice-item-card-btn{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);border:none;border-radius:var(--radius-md);cursor:pointer;transition:transform var(--motion-fast),box-shadow var(--motion-fast),opacity var(--motion-fast);min-width:140px}.practice-item-card-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.practice-item-card-btn:active{transform:translateY(0)}.practice-item-card-btn:disabled{opacity:.5;cursor:not-allowed}.practice-item-card-btn:disabled:hover{transform:none;box-shadow:none}.practice-item-card-btn.incorrect{background-color:var(--color-error);color:var(--color-white)}.practice-item-card-btn.incorrect:hover:not(:disabled){background-color:var(--color-error-dark)}.practice-item-card-btn.correct{background-color:var(--color-success);color:var(--color-white)}.practice-item-card-btn.correct:hover:not(:disabled){background-color:var(--color-success-dark)}.practice-item-card-btn.reveal{background-color:var(--color-primary);color:var(--color-white)}.practice-item-card-btn.reveal:hover:not(:disabled){background-color:var(--color-primary);opacity:.9}.practice-item-card.show-answer .practice-item-card-jp{font-size:var(--font-size-2xl);color:var(--color-gray-600)}@media(prefers-color-scheme:dark){.practice-item-card{background-color:var(--color-surface-dark);border-color:var(--color-gray-700)}.practice-item-card-jp{color:var(--color-gray-100)}.practice-item-card-answer{background-color:var(--color-gray-800);color:var(--color-gray-200)}.practice-item-card-alternative,.practice-item-card.show-answer .practice-item-card-jp{color:var(--color-gray-400)}}@media(max-width:768px){.practice-item-card{padding:var(--spacing-lg)}.practice-item-card-jp{font-size:var(--font-size-3xl)}.practice-item-card-answer{font-size:var(--font-size-xl)}.practice-item-card-image{max-width:240px}.practice-item-card-actions{flex-direction:column;gap:var(--spacing-sm)}.practice-item-card-btn{width:100%;min-width:auto}}@media(max-width:480px){.practice-item-card{padding:var(--spacing-md)}.practice-item-card-jp{font-size:var(--font-size-2xl)}.practice-item-card-answer{font-size:var(--font-size-lg)}}.question-card{background-color:var(--color-surface-raised);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin:var(--spacing-lg) 0;transition:all var(--motion-normal);animation:slideInUp var(--motion-normal) ease-out}.question-card:hover{box-shadow:var(--shadow-lg)}.question-text{text-align:center;margin-bottom:var(--spacing-2xl);animation:fadeIn var(--motion-slow) ease-out}.question-text h3{font-size:32px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}.answer-options{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-2xl)}.answer-option{padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-raised);cursor:pointer;font-size:var(--font-size-lg);text-align:left;transition:all var(--motion-normal);color:var(--color-text-primary);position:relative;overflow:hidden}.answer-option:before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background-color:var(--color-primary);transform:scaleY(0);transition:transform var(--motion-fast);transform-origin:bottom}.answer-option:hover:not(:disabled){background-color:var(--color-gray-100);border-color:var(--color-primary);transform:translate(4px)}.answer-option:hover:not(:disabled):before{transform:scaleY(1);transform-origin:top}.answer-option.selected{border-color:var(--color-primary);background-color:var(--color-primary-light);color:var(--color-primary-dark);font-weight:var(--font-weight-medium);animation:scaleIn var(--motion-fast) ease-out}.answer-option.selected:before{transform:scaleY(1)}.answer-option.correct{border-color:var(--color-success);background-color:var(--color-success-light);color:var(--color-success-dark);animation:slideInLeft var(--motion-fast) ease-out}.answer-option.correct:before{background-color:var(--color-success);transform:scaleY(1)}.answer-option.incorrect{border-color:var(--color-error);background-color:var(--color-error-light);color:var(--color-error-dark);animation:slideInRight var(--motion-fast) ease-out}.answer-option.incorrect:before{background-color:var(--color-error);transform:scaleY(1)}.answer-option:disabled{cursor:not-allowed;opacity:.85}.feedback{margin-top:var(--spacing-lg);padding:var(--spacing-lg);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);text-align:center;animation:slideInUp var(--motion-normal) ease-out;display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);min-height:50px}.feedback:before{font-size:var(--font-size-2xl)}.feedback.correct{background-color:var(--color-success-light);color:var(--color-success-dark);border-left:4px solid var(--color-success)}.feedback.correct:before{content:"✓"}.feedback.incorrect{background-color:var(--color-error-light);color:var(--color-error-dark);border-left:4px solid var(--color-error)}.feedback.incorrect:before{content:"✕"}@media(prefers-color-scheme:dark){.answer-option{background-color:var(--color-surface-raised);border-color:var(--color-border);color:var(--color-text-primary)}.answer-option:hover:not(:disabled){background-color:var(--color-gray-700);border-color:var(--color-primary)}.answer-option.selected{border-color:var(--color-primary);background-color:var(--color-primary-light)}}@media(max-width:768px){.question-card{padding:var(--spacing-lg);margin:var(--spacing-md) 0}.question-text h3{font-size:24px}.answer-option{padding:var(--spacing-md);font-size:var(--font-size-base)}.feedback{font-size:var(--font-size-sm);padding:var(--spacing-md)}}.section-card{background-color:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);cursor:pointer;transition:all var(--motion-normal);display:flex;flex-direction:column;gap:var(--spacing-md);position:relative;overflow:hidden;animation:slideInUp var(--motion-normal) ease-out}.section-card:before{content:"";position:absolute;left:0;top:0;height:100%;width:4px;background-color:var(--accent-color, var(--color-primary));transition:width var(--motion-normal)}.section-card:hover{border-color:var(--accent-color, var(--color-primary));box-shadow:var(--shadow-lg);transform:translateY(-4px)}.section-card:hover:before{width:100%;opacity:.1}.section-card:active{transform:translateY(-2px)}.section-card-title{margin:0;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);transition:color var(--motion-normal)}.section-card:hover .section-card-title{color:var(--accent-color, var(--color-primary))}.section-card-description{margin:0;font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.section-card-progress{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.section-progress-bar{height:8px;background-color:var(--color-gray-300);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-sm)}.section-progress-fill{height:100%;background-color:var(--accent-color, var(--color-primary));transition:width var(--motion-normal) ease-out;border-radius:var(--radius-lg)}.section-progress-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex;justify-content:space-between;align-items:center}.section-progress-text strong{color:var(--color-text-primary)}.section-card.completed{border-color:var(--color-success);background-color:var(--color-success-light)}.section-card.completed .section-card-title{color:var(--color-success-dark)}.section-card.completed:before{background-color:var(--color-success);width:100%;opacity:.2}.section-card.locked{opacity:.6;cursor:not-allowed;border-style:dashed}.section-card.locked:hover{box-shadow:var(--shadow-sm);transform:none;border-color:var(--color-border)}.section-card.locked:before{width:4px}.section-card.in-progress:before{background-color:var(--color-warning)}.section-card-status{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background-color:var(--accent-color, var(--color-primary));color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em}.section-card.completed .section-card-status{background-color:var(--color-success);content:"✓ Complete"}.section-card.locked .section-card-status{background-color:var(--color-gray-400);content:"Locked"}@media(prefers-color-scheme:dark){.section-card{background-color:var(--color-surface-raised);border-color:var(--color-border)}.section-card:hover{border-color:var(--accent-color, var(--color-primary))}.section-card.completed{background-color:var(--color-success-light)}}@media(max-width:768px){.section-card{padding:var(--spacing-md)}.section-card-title{font-size:var(--font-size-xl)}.section-card-description{font-size:var(--font-size-sm)}.section-card-status{top:var(--spacing-sm);right:var(--spacing-sm);font-size:var(--font-size-xs)}}.section-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg);margin:var(--spacing-lg) 0}@media(max-width:768px){.section-cards-grid{grid-template-columns:1fr;gap:var(--spacing-md)}}.section-card:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.section-card[role=button]:focus-visible{outline:3px solid var(--color-primary)}.streak-badge{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-xl);background-color:var(--color-surface);border-radius:var(--radius-lg);border:3px solid var(--streak-color, var(--color-gray-400));box-shadow:var(--shadow-md);transition:transform var(--motion-normal),box-shadow var(--motion-normal);animation:scaleIn var(--motion-normal) ease-out}.streak-badge:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.streak-emoji{font-size:48px;margin-bottom:var(--spacing-md);animation:float 3s ease-in-out infinite;-webkit-user-select:none;user-select:none}.streak-number{font-size:var(--font-size-5xl);font-weight:var(--font-weight-bold);color:var(--streak-color, var(--color-gray-600));margin-bottom:var(--spacing-xs);line-height:1;animation:popIn var(--motion-normal) ease-out}.streak-label{font-size:var(--font-size-lg);color:var(--color-gray-600);margin-bottom:var(--spacing-md);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:1px}.streak-best{font-size:var(--font-size-sm);color:var(--color-gray-500);text-align:center;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-gray-50);border-radius:var(--radius-sm);margin-top:var(--spacing-xs)}.streak-best:before{content:"🏆 ";opacity:.8}.streak-message{font-size:var(--font-size-sm);color:var(--color-gray-500);text-align:center;margin-top:var(--spacing-md);font-style:italic;max-width:240px}.streak-message.encourage{color:var(--color-primary);font-weight:var(--font-weight-semibold)}.streak-badge.streak-0{--streak-color: var(--color-gray-400);border-style:dashed}.streak-badge.streak-3{--streak-color: var(--color-success)}.streak-badge.streak-7{--streak-color: #ffd700}.streak-badge.streak-7 .streak-emoji{animation:float 3s ease-in-out infinite,pulse 2s ease-in-out infinite}.streak-badge.streak-14{--streak-color: var(--color-warning)}.streak-badge.streak-14 .streak-emoji{animation:float 3s ease-in-out infinite,pulse 2s ease-in-out infinite}.streak-badge.streak-30{--streak-color: #ff6b6b;box-shadow:0 0 20px #ff6b6b4d}.streak-badge.streak-30 .streak-emoji{animation:float 3s ease-in-out infinite,pulse 1.5s ease-in-out infinite}.streak-badge.streak-30:hover{box-shadow:0 0 30px #ff6b6b80,var(--shadow-xl)}.streak-badge.milestone{animation:scaleIn var(--motion-normal) ease-out,shimmer 2s ease-in-out}.streak-badge.milestone:after{content:"✨";position:absolute;top:-10px;right:-10px;font-size:24px;animation:rotate360 2s linear infinite}@media(prefers-color-scheme:dark){.streak-badge{background-color:var(--color-surface-dark)}.streak-label{color:var(--color-gray-400)}.streak-best{background-color:var(--color-gray-800);color:var(--color-gray-400)}.streak-message{color:var(--color-gray-400)}.streak-message.encourage{color:var(--color-primary-light)}.streak-badge.streak-0{--streak-color: var(--color-gray-600)}}@media(max-width:768px){.streak-badge{padding:var(--spacing-lg)}.streak-emoji{font-size:40px}.streak-number{font-size:var(--font-size-4xl)}.streak-label{font-size:var(--font-size-base)}}@media(max-width:480px){.streak-badge{padding:var(--spacing-md)}.streak-emoji{font-size:32px}.streak-number{font-size:var(--font-size-3xl)}}.session-summary{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-2xl);box-shadow:var(--shadow-lg);max-width:600px;margin:0 auto;text-align:center;animation:scaleIn var(--motion-normal) ease-out}.session-summary-emoji{font-size:48px;margin-bottom:var(--spacing-lg);animation:popIn var(--motion-normal) ease-out;-webkit-user-select:none;user-select:none}.session-summary-heading{margin-bottom:var(--spacing-xl);font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.session-summary-score{margin-bottom:var(--spacing-xl)}.session-summary-score-number{font-size:48px;font-weight:var(--font-weight-bold);color:var(--color-success);margin-bottom:var(--spacing-sm);animation:fadeIn var(--motion-normal) ease-out}.session-summary-score-label{font-size:var(--font-size-lg);color:var(--color-gray-600)}.session-summary-stats{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.session-summary-stat{background-color:var(--color-gray-50);padding:var(--spacing-lg);border-radius:var(--radius-md);transition:transform var(--motion-fast),box-shadow var(--motion-fast)}.session-summary-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.session-summary-stat-number{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-xs)}.session-summary-stat-number.reviewed{color:var(--color-primary)}.session-summary-stat-number.new{color:var(--color-info)}.session-summary-stat-label{font-size:var(--font-size-sm);color:var(--color-gray-600);text-transform:uppercase;letter-spacing:.5px}.session-summary-actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.session-summary-actions .btn{width:100%;justify-content:center}.session-summary-message{margin-top:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}@media(prefers-color-scheme:dark){.session-summary{background-color:var(--color-surface-dark)}.session-summary-heading{color:var(--color-gray-100)}.session-summary-stat{background-color:var(--color-gray-800)}.session-summary-stat-label,.session-summary-score-label{color:var(--color-gray-400)}.session-summary-message{background-color:var(--color-primary);color:var(--color-white)}}@media(max-width:768px){.session-summary{padding:var(--spacing-xl)}.session-summary-emoji{font-size:40px}.session-summary-heading{font-size:var(--font-size-2xl)}.session-summary-score-number{font-size:40px}.session-summary-stats{gap:var(--spacing-md)}.session-summary-stat{padding:var(--spacing-md)}.session-summary-stat-number{font-size:var(--font-size-2xl)}}@media(max-width:480px){.session-summary{padding:var(--spacing-lg)}.session-summary-stats{grid-template-columns:1fr;gap:var(--spacing-sm)}.session-summary-actions{gap:var(--spacing-xs)}}.milestone-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn var(--motion-normal) ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.milestone-content{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-2xl);max-width:500px;text-align:center;box-shadow:var(--shadow-xl);animation:scaleIn var(--motion-normal) ease-out;position:relative}.milestone-emoji{font-size:72px;margin-bottom:var(--spacing-lg);animation:popIn var(--motion-normal) ease-out,float 3s ease-in-out infinite;-webkit-user-select:none;user-select:none}.milestone-title{font-size:var(--font-size-3xl);margin:0 0 var(--spacing-sm) 0;color:var(--color-gray-900);font-weight:var(--font-weight-bold);animation:slideInUp var(--motion-normal) ease-out}.milestone-message{font-size:var(--font-size-lg);color:var(--color-gray-600);margin:0 0 var(--spacing-lg) 0;animation:slideInUp var(--motion-normal) ease-out .1s;animation-fill-mode:both}.milestone-dismiss{padding:var(--spacing-sm) var(--spacing-xl);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);background-color:var(--color-success);color:var(--color-white);border:none;border-radius:var(--radius-md);cursor:pointer;transition:transform var(--motion-fast),background-color var(--motion-fast);animation:slideInUp var(--motion-normal) ease-out .2s;animation-fill-mode:both}.milestone-dismiss:hover{transform:translateY(-2px);background-color:var(--color-success-dark)}.milestone-dismiss:active{transform:translateY(0)}.milestone-content.streak{border:3px solid #ff6b6b}.milestone-content.streak .milestone-title{color:#ff6b6b}.milestone-content.streak-7{border:3px solid #ffd700}.milestone-content.streak-7 .milestone-title{color:gold}.milestone-content.streak-30{border:3px solid #ff6b6b;box-shadow:0 0 30px #ff6b6b66,var(--shadow-xl)}.milestone-content.streak-30 .milestone-title{color:#ff6b6b;text-shadow:0 0 10px rgba(255,107,107,.3)}.milestone-content.streak-100{border:3px solid #ff6b6b;box-shadow:0 0 40px #ff6b6b99,var(--shadow-xl)}.milestone-content.streak-100 .milestone-emoji{animation:popIn var(--motion-normal) ease-out,rotate360 4s linear infinite}.milestone-content:before{content:"✨";position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:32px;animation:floatUp 2s ease-out infinite}.milestone-content:after{content:"🎊";position:absolute;bottom:-20px;right:-20px;font-size:32px;animation:rotate360 3s linear infinite}@media(prefers-color-scheme:dark){.milestone-overlay{background-color:#000000d9}.milestone-content{background-color:var(--color-surface-dark)}.milestone-title{color:var(--color-gray-100)}.milestone-message{color:var(--color-gray-400)}}@media(max-width:768px){.milestone-content{padding:var(--spacing-xl);max-width:90%}.milestone-emoji{font-size:56px}.milestone-title{font-size:var(--font-size-2xl)}.milestone-message{font-size:var(--font-size-base)}}@media(max-width:480px){.milestone-content{padding:var(--spacing-lg)}.milestone-emoji{font-size:48px}.milestone-title{font-size:var(--font-size-xl)}}@media(prefers-reduced-motion:reduce){.milestone-emoji{animation:none}.milestone-content:before,.milestone-content:after{animation:none}}.star-display{display:inline-flex;gap:.25rem;align-items:center}.star-icon{width:1.25rem;height:1.25rem;transition:transform .2s ease}.star-icon.filled{color:#fbbf24;fill:currentColor}.star-icon.empty{color:#d1d5db;fill:none;stroke:currentColor;stroke-width:2}.star-icon:hover{transform:scale(1.1)}@keyframes starAppear{0%{transform:scale(0) rotate(-180deg);opacity:0}50%{transform:scale(1.2) rotate(0)}to{transform:scale(1) rotate(0);opacity:1}}.star-icon.animate{animation:starAppear .5s ease-out}@media(prefers-reduced-motion:reduce){.star-icon{transition:none}.star-icon:hover{transform:none}.star-icon.animate{animation:none}}
