.tab-bar{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;background:var(--bg-secondary);border-top:1px solid var(--border);padding:var(--spacing-sm) 0;padding-bottom:calc(var(--spacing-sm) + env(safe-area-inset-bottom));z-index:100}.tab-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--spacing-xs) var(--spacing-md);color:var(--text-muted);text-decoration:none;font-size:.625rem;font-weight:500;transition:color .2s ease}.tab-item.active{color:var(--primary)}.tab-item:hover{color:var(--primary-dark)}.tab-item svg{transition:transform .2s ease}.tab-item.active svg{transform:scale(1.05)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;border:none;outline:none;text-decoration:none}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-primary);color:var(--text-primary)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--error);color:#fff}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem}.btn-md{padding:var(--spacing-sm) var(--spacing-lg);font-size:.875rem}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:1rem}.btn-icon{width:2.5rem;height:2.5rem;padding:0;border-radius:var(--radius-full)}.btn-disabled,.btn:disabled{opacity:.5;cursor:not-allowed}.btn-loading{position:relative;color:transparent}.btn-spinner{position:absolute;width:1rem;height:1rem;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.card-default{background:var(--bg-card)}.card-outlined{background:transparent;border:1px solid var(--border);box-shadow:none}.card-elevated{box-shadow:var(--shadow-md)}.card-gradient{background:linear-gradient(135deg,var(--primary) 0%,var(--accent-purple) 100%);color:#fff}.card-padding-none{padding:0}.card-padding-sm{padding:var(--spacing-sm)}.card-padding-md{padding:var(--spacing-md)}.card-padding-lg{padding:var(--spacing-lg)}.card-clickable{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.card-clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.card-clickable:active{transform:translateY(0)}.card-header{padding:var(--spacing-md);border-bottom:1px solid var(--border)}.card-body{padding:var(--spacing-md)}.card-footer{padding:var(--spacing-md);border-top:1px solid var(--border);background:var(--bg-primary)}.input-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.input-required{color:var(--error);margin-left:2px}.input-wrapper{position:relative;display:flex;align-items:center}.input-wrapper.has-icon .input{padding-left:2.75rem}.input-icon{position:absolute;left:var(--spacing-md);color:var(--text-muted);pointer-events:none}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius);font-size:1rem;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .2s ease,box-shadow .2s ease}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.input:disabled{background:var(--bg-primary);cursor:not-allowed;opacity:.7}.input-wrapper.input-error .input{border-color:var(--error)}.input-wrapper.input-error .input:focus{box-shadow:0 0 0 3px #ef44441a}.input-hint{font-size:.75rem;color:var(--text-muted)}.input-hint.error{color:var(--error)}select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-md) center;padding-right:2.5rem}textarea.input{min-height:100px;resize:vertical}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-weight:600}.badge-sm{font-size:.625rem;padding:2px var(--spacing-xs)}.badge-md{font-size:.75rem}.badge-lg{font-size:.875rem;padding:var(--spacing-xs) var(--spacing-md)}.badge-primary{background:#3b82f626;color:var(--primary-dark)}.badge-purple{background:#a78bfa26;color:#7c3aed}.badge-mint{background:#6ee7b726;color:#059669}.badge-orange{background:#fb923c26;color:#ea580c}.badge-success{background:#22c55e26;color:#15803d}.badge-warning{background:#eab30826;color:#a16207}.badge-error{background:#ef444426;color:#dc2626}.badge-neutral{background:var(--bg-primary);color:var(--text-secondary)}.progress-bar{width:100%;background:var(--border);border-radius:var(--radius-full);overflow:hidden;position:relative}.progress-bar-sm{height:.25rem}.progress-bar-md{height:.5rem}.progress-bar-lg{height:.75rem}.progress-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .4s ease}.progress-bar-primary{background:var(--primary)}.progress-bar-success{background:var(--success)}.progress-bar-warning{background:var(--warning)}.progress-bar-error{background:var(--error)}.progress-bar-gradient{background:linear-gradient(90deg,var(--primary) 0%,var(--accent-purple) 100%)}.progress-bar-label{position:absolute;right:var(--spacing-xs);top:50%;transform:translateY(-50%);font-size:.625rem;font-weight:600;color:#fff}.progress-vertical{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--spacing-sm)}.progress-vertical-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);flex:1}.progress-vertical-bar{width:100%;max-width:2rem;border-radius:var(--radius);transition:height .4s ease}.progress-vertical-label{font-size:.625rem;color:var(--text-muted);font-weight:500}.home-page{padding-top:var(--spacing-md)}.home-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg)}.greeting-text{font-size:.875rem;color:var(--text-muted)}.greeting h1{font-size:1.5rem;margin-top:var(--spacing-xs)}.search-container{margin-bottom:var(--spacing-lg)}.search-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-muted);text-decoration:none;transition:border-color .2s ease}.search-bar:hover{border-color:var(--primary)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm);margin-bottom:var(--spacing-xl)}.home-section{margin-bottom:var(--spacing-xl)}.home-section h3{font-size:1rem;margin-bottom:var(--spacing-md)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.see-all{font-size:.875rem;color:var(--primary);text-decoration:none;font-weight:500}.continue-card{text-decoration:none;display:block}.continue-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.continue-info h4{font-size:1rem;margin:var(--spacing-xs) 0;color:var(--text-primary)}.continue-info p{font-size:.75rem;color:var(--text-muted)}.continue-arrow{color:var(--text-muted)}.review-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.review-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--bg-card);border-radius:var(--radius);text-decoration:none;transition:transform .2s ease}.review-item:hover{transform:translate(4px)}.review-info{display:flex;flex-direction:column;gap:2px}.review-subject{font-size:.625rem;text-transform:uppercase;letter-spacing:.5px;color:var(--primary);font-weight:600}.review-title{font-size:.875rem;color:var(--text-primary);font-weight:500}.review-item svg{color:var(--text-muted)}.scan-cta{text-decoration:none;display:block;margin-bottom:var(--spacing-xl)}.scan-content{display:flex;align-items:center;gap:var(--spacing-md)}.scan-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:var(--radius-lg)}.scan-text h3{color:#fff;font-size:1.125rem;margin-bottom:var(--spacing-xs)}.scan-text p{color:#fffc;font-size:.75rem}.empty-state{text-align:center;padding:var(--spacing-xl);background:var(--bg-card);border-radius:var(--radius-lg);margin-top:var(--spacing-xl)}.empty-icon{color:var(--text-muted);margin-bottom:var(--spacing-md)}.empty-state h3{margin-bottom:var(--spacing-sm)}.empty-state p{font-size:.875rem;color:var(--text-muted)}.lessons-page{padding-top:var(--spacing-md)}.lessons-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.lessons-header h1{font-size:1.5rem}.lessons-search{margin-bottom:var(--spacing-md)}.lessons-filters{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.filter-chips{display:flex;gap:var(--spacing-xs);overflow-x:auto;padding-bottom:var(--spacing-xs);-webkit-overflow-scrolling:touch}.filter-chip{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-full);font-size:.75rem;font-weight:500;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all .2s ease}.filter-chip:hover{border-color:var(--primary);color:var(--primary)}.filter-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.subject-filter{padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;color:var(--text-primary);cursor:pointer}.lessons-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.lesson-card{text-decoration:none;display:block}.lesson-card .card{transition:transform .2s ease,box-shadow .2s ease}.lesson-card:hover .card{transform:translateY(-2px);box-shadow:var(--shadow-md)}.lesson-card-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.lesson-subject{font-size:.625rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:600}.lesson-title{font-size:1rem;margin-bottom:var(--spacing-md);color:var(--text-primary)}.lesson-card-footer{display:flex;align-items:center;gap:var(--spacing-md)}.lesson-card-footer .progress-bar{flex:1}.lesson-arrow{color:var(--text-muted)}.lessons-empty{text-align:center;padding:var(--spacing-xl);color:var(--text-muted)}.lessons-empty svg{margin-bottom:var(--spacing-md)}.lessons-empty h3{margin-bottom:var(--spacing-sm);color:var(--text-primary)}.lessons-empty p{margin-bottom:var(--spacing-lg);font-size:.875rem}.quiz-container{display:flex;flex-direction:column;gap:var(--spacing-md)}.quiz-progress{display:flex;align-items:center;gap:var(--spacing-md)}.quiz-progress .progress-bar{flex:1;height:6px;background:var(--border);border-radius:var(--radius-full);overflow:hidden}.quiz-progress .progress-fill{height:100%;background:var(--primary);border-radius:var(--radius-full);transition:width .3s ease}.progress-text{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.question-card .badge{margin-bottom:var(--spacing-md)}.question-text{font-size:1.125rem;line-height:1.5;margin-bottom:var(--spacing-lg)}.options-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-primary);border:2px solid var(--border);border-radius:var(--radius);text-align:left;cursor:pointer;transition:all .2s ease}.option:hover:not(:disabled){border-color:var(--primary-light)}.option.selected{border-color:var(--primary);background:#3b82f60d}.option.correct{border-color:var(--success);background:#22c55e1a}.option.incorrect{border-color:var(--error);background:#ef44441a}.option:disabled{cursor:default}.option-letter{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:var(--radius);font-weight:600;font-size:.875rem;color:var(--text-secondary);flex-shrink:0}.option.selected .option-letter{background:var(--primary);color:#fff}.option-text{flex:1;font-size:.875rem}.option-icon{flex-shrink:0}.option-icon.correct{color:var(--success)}.option-icon.incorrect{color:var(--error)}.open-answer textarea{width:100%;padding:var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;font-family:inherit;resize:vertical;min-height:100px}.open-answer textarea:focus{outline:none;border-color:var(--primary)}.open-answer textarea:disabled{background:var(--bg-primary)}.feedback{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius);margin-top:var(--spacing-md);font-size:.875rem}.feedback.correct{background:#22c55e1a;color:#15803d}.feedback.incorrect{background:#ef44441a;color:#dc2626}.feedback svg{flex-shrink:0;margin-top:2px}.quiz-actions{margin-top:var(--spacing-md)}.quiz-complete{padding:var(--spacing-xl) 0}.result-card{text-align:center}.result-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);margin:0 auto var(--spacing-lg)}.result-icon.success{background:#6ee7b733;color:#059669}.result-icon.failure{background:#fb923c33;color:#ea580c}.result-card h2{margin-bottom:var(--spacing-lg)}.result-score{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.score-value{font-size:3rem;font-weight:700;color:var(--primary)}.score-label{font-size:.875rem;color:var(--text-muted)}.result-message{font-size:.875rem;margin-bottom:var(--spacing-xl);max-width:280px;margin-left:auto;margin-right:auto}.result-actions{display:flex;gap:var(--spacing-md)}.result-actions .btn{flex:1}.quiz-empty{text-align:center;padding:var(--spacing-xl);color:var(--text-muted)}.lesson-detail-page{padding-top:var(--spacing-md);padding-bottom:0}.lesson-loading{display:flex;align-items:center;justify-content:center}.loader{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.lesson-header{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.back-btn{background:none;border:none;padding:var(--spacing-xs);color:var(--text-primary);cursor:pointer;flex-shrink:0}.lesson-title-section{flex:1}.lesson-title-section h1{font-size:1.25rem;margin:var(--spacing-xs) 0}.lesson-subject{font-size:.75rem;color:var(--text-muted)}.progress-card{margin-bottom:var(--spacing-lg)}.progress-info{display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm);font-size:.75rem;color:var(--text-secondary)}.progress-count{font-weight:600;color:var(--primary)}.mastery-badge{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);margin-top:var(--spacing-md);padding:var(--spacing-sm);background:#6ee7b726;border-radius:var(--radius);color:#059669;font-size:.875rem;font-weight:600}.lesson-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);background:var(--bg-card);padding:var(--spacing-xs);border-radius:var(--radius-lg)}.tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;border-radius:var(--radius);font-size:.75rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .2s ease}.tab.active{background:var(--primary);color:#fff}.tab:not(.active):hover{background:var(--bg-primary);color:var(--text-primary)}.lesson-content{animation:fadeIn .3s ease}.summary-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.summary-content h3{font-size:1rem;margin-bottom:var(--spacing-md)}.summary-text p{margin-bottom:var(--spacing-sm);line-height:1.7;font-size:.875rem}.key-points{list-style:none;padding:0}.key-points li{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;font-size:.875rem;border-bottom:1px solid var(--border)}.key-points li:last-child{border-bottom:none}.key-points li svg{color:var(--primary);flex-shrink:0;margin-top:2px}.podcast-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.podcast-player{text-align:center}.podcast-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);text-align:left}.podcast-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:var(--radius-lg);font-size:1.5rem}.podcast-header h3{font-size:1rem;margin-bottom:2px}.podcast-header p{font-size:.75rem;color:var(--text-muted)}.play-button{width:72px;height:72px;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-full);margin:0 auto var(--spacing-lg);cursor:pointer;transition:transform .2s ease}.play-button:hover{transform:scale(1.05)}.podcast-disclaimer{padding:var(--spacing-sm);background:var(--bg-primary);border-radius:var(--radius)}.podcast-disclaimer p{font-size:.75rem;color:var(--text-muted)}.podcast-script{font-size:.875rem;line-height:1.7}.podcast-script h3{margin-bottom:var(--spacing-md)}.podcast-script p{margin-bottom:var(--spacing-sm)}.podcast-script .speaker{font-weight:600;color:var(--primary);margin-top:var(--spacing-md)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.stats-page{padding-top:var(--spacing-md)}.stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.stats-header h1{font-size:1.5rem}.main-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.stat-main-card{text-align:center}.stat-main-icon{width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);margin:0 auto var(--spacing-sm)}.stat-main-icon.primary{background:#3b82f626;color:var(--primary)}.stat-main-icon.mint{background:#6ee7b726;color:#059669}.stat-main-icon.orange{background:#fb923c26;color:#ea580c}.stat-main-icon.purple{background:#a78bfa26;color:#7c3aed}.stat-main-value{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.stat-main-label{font-size:.75rem;color:var(--text-muted)}.stats-section{margin-bottom:var(--spacing-xl)}.stats-section h3{font-size:1rem;margin-bottom:var(--spacing-md)}.weekly-chart{padding:var(--spacing-md) 0}.mastery-overview{display:flex;flex-direction:column;gap:var(--spacing-md)}.mastery-row{display:grid;grid-template-columns:80px 1fr 40px;align-items:center;gap:var(--spacing-md)}.mastery-label{font-size:.75rem;color:var(--text-secondary);font-weight:500}.mastery-count{font-size:.875rem;font-weight:600;color:var(--text-primary);text-align:right}.badges-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm)}.badge-card{text-align:center;transition:transform .2s ease}.badge-card:hover{transform:scale(1.05)}.badge-icon{width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-orange) 0%,var(--accent-purple) 100%);color:#fff;border-radius:var(--radius-full);margin:0 auto var(--spacing-xs)}.badge-title{font-size:.625rem;color:var(--text-secondary);font-weight:500}.stats-empty{text-align:center;padding:var(--spacing-xl);color:var(--text-muted)}.stats-empty svg{margin-bottom:var(--spacing-md)}.stats-empty h3{margin-bottom:var(--spacing-sm);color:var(--text-primary)}.stats-empty p{font-size:.875rem}.profile-page{padding-top:var(--spacing-md)}.profile-header{margin-bottom:var(--spacing-lg)}.profile-header h1{font-size:1.5rem}.user-card{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.user-avatar{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);color:var(--primary);border-radius:var(--radius-full)}.user-info{flex:1}.user-info h3{font-size:1.125rem;margin-bottom:2px}.user-info p{font-size:.75rem;color:var(--text-muted)}.profile-section{margin-bottom:var(--spacing-xl)}.profile-section h4{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:var(--spacing-sm);padding-left:var(--spacing-sm)}.profile-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-md);background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s ease}.profile-item:last-child{border-bottom:none}.profile-item:hover{background:var(--bg-primary)}.profile-item-left{display:flex;align-items:center;gap:var(--spacing-md);color:var(--text-primary)}.profile-item-left>div{display:flex;flex-direction:column;align-items:flex-start}.profile-item-label{font-size:.875rem;font-weight:500}.profile-item-value{font-size:.75rem;color:var(--text-muted)}.profile-item svg{color:var(--text-muted)}.toggle{width:44px;height:24px;background:var(--border);border-radius:var(--radius-full);position:relative;transition:background .2s ease}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:var(--radius-full);transition:transform .2s ease;box-shadow:0 1px 3px #0003}.toggle.active{background:var(--primary)}.toggle.active:after{transform:translate(20px)}.profile-logout{margin-top:var(--spacing-xl)}.logout-btn{width:100%;color:var(--error)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);z-index:200}.modal-content{width:100%;max-width:320px;text-align:center}.modal-content h3{margin-bottom:var(--spacing-sm)}.modal-content p{font-size:.875rem;margin-bottom:var(--spacing-lg)}.modal-actions{display:flex;gap:var(--spacing-sm)}.modal-actions .btn{flex:1}.profile-footer{text-align:center;padding:var(--spacing-xl) 0}.profile-footer p{font-size:.75rem;color:var(--text-muted)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,var(--accent-purple) 100%);padding:var(--spacing-lg)}.login-container{width:100%;max-width:380px}.login-logo{text-align:center;margin-bottom:var(--spacing-xl);color:#fff}.logo-icon{width:72px;height:72px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:var(--radius-xl);margin:0 auto var(--spacing-md);box-shadow:var(--shadow-md)}.logo-icon span{font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--primary) 0%,var(--accent-purple) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-logo h1{font-size:2rem;color:#fff;margin-bottom:var(--spacing-xs)}.login-logo p{color:#fffc;font-size:.875rem}.login-card{margin-bottom:var(--spacing-lg)}.form-group{margin-bottom:var(--spacing-md)}.password-input{position:relative}.password-toggle{position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--spacing-xs)}.error-message{color:var(--error);font-size:.75rem;margin-bottom:var(--spacing-md);text-align:center}.submit-btn{width:100%}.login-divider{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-lg) 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.login-divider span{font-size:.75rem;color:var(--text-muted)}.google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.google-btn svg{flex-shrink:0}.login-toggle{text-align:center;color:#fffc;font-size:.875rem}.login-toggle button{background:none;border:none;color:#fff;font-weight:600;cursor:pointer;margin-left:var(--spacing-xs);text-decoration:underline}.onboarding-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.onboarding-container{flex:1;display:flex;flex-direction:column;padding:var(--spacing-xl);max-width:428px;margin:0 auto;width:100%}.onboarding-progress{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);padding-top:var(--spacing-lg)}.progress-dot{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--border);color:var(--text-muted);font-size:.875rem;font-weight:600;transition:all .3s ease}.progress-dot.active{background:var(--primary);color:#fff}.progress-line{width:40px;height:2px;background:var(--border)}.onboarding-step{flex:1;animation:fadeIn .3s ease}.onboarding-header{text-align:center;margin-bottom:var(--spacing-xl)}.onboarding-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);color:var(--primary);border-radius:var(--radius-full);margin:0 auto var(--spacing-lg)}.onboarding-icon.success{background:#6ee7b733;color:#059669}.onboarding-header h1{font-size:1.5rem;margin-bottom:var(--spacing-sm)}.onboarding-header p{font-size:1rem;color:var(--text-secondary)}.niveau-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.niveau-card{cursor:pointer;transition:all .2s ease;border:2px solid transparent}.niveau-card:hover{border-color:var(--primary-light)}.niveau-card.selected{border-color:var(--primary);background:#3b82f60d}.niveau-content{display:flex;align-items:center;justify-content:space-between}.niveau-info h4{font-size:1rem;margin-bottom:2px}.niveau-info p{font-size:.75rem;color:var(--text-muted)}.niveau-card svg{color:var(--text-muted)}.niveau-check{color:var(--primary)!important}.diplome-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.diplome-hint{font-size:.75rem;color:var(--text-muted);text-align:center}.onboarding-actions{display:flex;gap:var(--spacing-md);margin-top:auto;padding-top:var(--spacing-xl)}.next-btn{flex:1}@keyframes fadeIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.scanner-page{min-height:100vh;background:var(--bg-primary)}.scanner-container{max-width:428px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}.scanner-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--bg-secondary);border-bottom:1px solid var(--border)}.close-btn{background:none;border:none;padding:var(--spacing-xs);color:var(--text-primary);cursor:pointer}.scanner-header h1{font-size:1.125rem}.scanner-capture{flex:1;display:flex;flex-direction:column;padding:var(--spacing-xl)}.capture-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border:2px dashed var(--border);border-radius:var(--radius-xl);margin-bottom:var(--spacing-xl);cursor:pointer;transition:all .2s ease;min-height:250px;color:var(--text-muted)}.capture-area:hover{border-color:var(--primary);background:#3b82f60d}.capture-area h3{margin:var(--spacing-md) 0 var(--spacing-xs);color:var(--text-primary)}.capture-area p{font-size:.875rem}.capture-options{display:flex;flex-direction:column;gap:var(--spacing-md)}.capture-hint{text-align:center;font-size:.875rem;color:var(--text-muted);margin-top:var(--spacing-lg)}.scanner-processing{flex:1;display:flex;flex-direction:column;padding:var(--spacing-xl)}.preview-image{flex:1;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-xl);max-height:300px}.preview-image img{width:100%;height:100%;object-fit:cover}.processing-status{text-align:center;padding:var(--spacing-xl)}.spinner{color:var(--primary);animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}@keyframes spin{to{transform:rotate(360deg)}}.processing-status h3{margin-bottom:var(--spacing-xs)}.processing-status p{font-size:.875rem;color:var(--text-muted)}.scanner-confirm{flex:1;display:flex;flex-direction:column;padding:var(--spacing-md)}.content-preview{flex:1;overflow-y:auto;margin-bottom:var(--spacing-md)}.content-preview h3{font-size:1.25rem;margin-bottom:var(--spacing-lg)}.subject-input,.preview-section{margin-bottom:var(--spacing-lg)}.preview-section h4{font-size:.875rem;color:var(--text-muted);margin-bottom:var(--spacing-sm)}.preview-section p{font-size:.875rem;line-height:1.6}.preview-section ul{list-style:none;padding:0}.preview-section li{font-size:.875rem;padding:var(--spacing-xs) 0;padding-left:var(--spacing-md);position:relative}.preview-section li:before{content:"•";position:absolute;left:0;color:var(--primary)}.confirm-actions{display:flex;gap:var(--spacing-md)}.confirm-actions .btn{flex:1}@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}}:root{--primary:#3b82f6;--primary-light:#93c5fd;--primary-dark:#1d4ed8;--accent-purple:#a78bfa;--accent-mint:#6ee7b7;--accent-orange:#fb923c;--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-card:#fff;--text-primary:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8;--border:#e2e8f0;--success:#22c55e;--warning:#eab308;--error:#ef4444;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--radius-sm:.375rem;--radius:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}#root{flex-direction:column;min-height:100vh;display:flex}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:700;line-height:1.2}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}p{color:var(--text-secondary)}.container{width:100%;max-width:428px;padding:0 var(--spacing-md);margin:0 auto}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow)}.badge{padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-full);align-items:center;font-size:.75rem;font-weight:600;display:inline-flex}.badge-purple{color:#7c3aed;background:#a78bfa33}.badge-mint{color:#059669;background:#6ee7b733}.badge-orange{color:#ea580c;background:#fb923c33}.badge-primary{color:var(--primary-dark);background:#3b82f633}.btn{justify-content:center;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm)var(--spacing-lg);border-radius:var(--radius);cursor:pointer;border:none;outline:none;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-lg{padding:var(--spacing-md)var(--spacing-xl);font-size:1rem}.btn-icon{border-radius:var(--radius-full);width:2.5rem;height:2.5rem;padding:0}.input{width:100%;padding:var(--spacing-sm)var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;transition:border-color .2s}.input:focus{border-color:var(--primary);outline:none}.input::placeholder{color:var(--text-muted)}.progress-bar{background:var(--border);border-radius:var(--radius-full);width:100%;height:.5rem;overflow:hidden}.progress-bar-fill{background:var(--primary);border-radius:var(--radius-full);height:100%;transition:width .3s}.progress-vertical{align-items:flex-end;gap:var(--spacing-sm);height:100px;display:flex}.progress-vertical-bar{background:var(--primary-light);border-radius:var(--radius);width:1.5rem;position:relative}.progress-vertical-bar:after{content:"";background:var(--primary);border-radius:var(--radius);transition:height .3s;position:absolute;bottom:0;left:0;right:0}.page{flex:1;padding-bottom:5rem}.page-header{padding:var(--spacing-lg)0}.page-content{gap:var(--spacing-md);flex-direction:column;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{50%{opacity:.5}}.animate-fade-in{animation:.3s fadeIn}.animate-pulse{animation:2s infinite pulse}.stat-card{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex}.stat-card-icon{border-radius:var(--radius);justify-content:center;align-items:center;width:3rem;height:3rem;display:flex}.stat-card-icon.purple{color:#7c3aed;background:#a78bfa33}.stat-card-icon.mint{color:#059669;background:#6ee7b733}.stat-card-icon.orange{color:#ea580c;background:#fb923c33}.stat-card-icon.primary{color:var(--primary);background:#3b82f633}.stat-card-content h4{font-size:1.25rem;font-weight:700}.stat-card-content p{color:var(--text-muted);font-size:.75rem}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
