.pwa-update-prompt{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:10000;max-width:90%;width:400px;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translate(-50%) translateY(100px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.pwa-update-content{background:#fff;border-radius:16px;padding:20px;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;gap:16px;border:2px solid #58cc02}.pwa-update-icon{font-size:2rem;text-align:center}.pwa-update-text h3{margin:0 0 8px;font-size:1.1rem;color:#1a1a1a;text-align:center}.pwa-update-text p{margin:0;font-size:.9rem;color:#666;text-align:center}.pwa-update-actions{display:flex;gap:12px;justify-content:center}.pwa-update-btn{padding:10px 20px;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.pwa-update-btn.primary{background:#58cc02;color:#fff}.pwa-update-btn.primary:hover{background:#4caf00;transform:translateY(-2px);box-shadow:0 4px 12px #58cc024d}.pwa-update-btn.secondary{background:#f0f0f0;color:#666}.pwa-update-btn.secondary:hover{background:#e0e0e0}:root.dark .pwa-update-content{background:var(--color-surface);border-color:var(--color-primary)}:root.dark .pwa-update-text h3{color:var(--color-text)}:root.dark .pwa-update-text p{color:var(--color-text-light)}:root.dark .pwa-update-btn.secondary{background:var(--color-border);color:var(--color-text-light)}:root.dark .pwa-update-btn.secondary:hover{background:var(--color-surface)}@media(max-width:768px){.pwa-update-prompt{bottom:10px;max-width:95%}.pwa-update-content{padding:16px}.pwa-update-actions{flex-direction:column}.pwa-update-btn{width:100%}}.welcome-page{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,#f0fdf4,#ecfeff,#f0f9ff);overflow-x:hidden}.welcome-hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;text-align:center;position:relative}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#58cc02,#1cb0f6);color:#fff;padding:.5rem 1rem;border-radius:24px;font-size:.875rem;font-weight:700;margin-bottom:1.5rem;animation:pulse 2s ease-in-out infinite}.hero-icon{width:120px;height:120px;margin-bottom:1.5rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.hero-icon svg{width:100%;height:100%;color:#58cc02}.welcome-hero h1{font-size:2rem;font-weight:800;color:#1a1a2e;margin:0 0 1rem;line-height:1.2}.welcome-hero h1 span{background:linear-gradient(135deg,#58cc02,#1cb0f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-hero p{font-size:1.125rem;color:#64748b;margin:0 0 2rem;max-width:400px;line-height:1.6}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem;width:100%;max-width:400px}.feature-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .5rem;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000d}.feature-item svg{color:#58cc02}.feature-item span{font-size:.75rem;font-weight:600;color:#475569;text-align:center}.cta-buttons{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:320px}.welcome-stats{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem;padding:1rem 0}.welcome-stats .stat{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.9rem}.welcome-stats .stat svg{color:#ffc800}.welcome-stats .stat strong{color:#1a1a2e}.cta-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;border-radius:16px;font-size:1.125rem;font-weight:700;cursor:pointer;transition:all .2s;border:none;text-decoration:none}.cta-btn.primary{background:linear-gradient(135deg,#58cc02,#44a08d);color:#fff;box-shadow:0 4px #3d8b00,0 8px 16px #58cc024d}.cta-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px #3d8b00,0 12px 24px #58cc0266}.cta-btn.primary:active{transform:translateY(2px);box-shadow:0 2px #3d8b00}.cta-btn.secondary{background:#fff;color:#475569;border:2px solid #e2e8f0}.cta-btn.secondary:hover{border-color:#58cc02;color:#58cc02}.social-proof{display:flex;align-items:center;gap:.75rem;margin-top:2rem;padding:.75rem 1rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.avatar-stack{display:flex}.avatar-stack .avatar{width:32px;height:32px;border-radius:50%;border:2px solid white;margin-left:-8px;background:linear-gradient(135deg,#58cc02,#1cb0f6);display:flex;align-items:center;justify-content:center;font-size:.75rem}.avatar-stack .avatar:first-child{margin-left:0}.social-proof span{font-size:.875rem;color:#64748b}.social-proof strong{color:#1a1a2e}.welcome-footer{padding:1.5rem;text-align:center;background:#fff;border-top:1px solid #e2e8f0}.welcome-footer p{font-size:.75rem;color:#94a3b8;margin:0}@media(min-width:640px){.welcome-hero h1{font-size:3rem}.welcome-hero p{font-size:1.25rem}.hero-icon{width:150px;height:150px}.features-grid{max-width:500px}.cta-buttons{flex-direction:row;max-width:500px}.cta-btn{flex:1}}@media(min-width:1024px){.welcome-hero{padding:4rem 2rem}.welcome-hero h1{font-size:3.5rem}}@media(max-width:380px){.welcome-hero{padding:1.5rem 1rem}.hero-badge{font-size:.75rem;padding:.4rem .75rem;margin-bottom:1rem}.hero-icon{width:90px;height:90px;margin-bottom:1rem}.welcome-hero h1{font-size:1.5rem;margin-bottom:.75rem}.welcome-hero p{font-size:.95rem;margin-bottom:1.5rem}.features-grid{gap:.75rem;margin-bottom:1.5rem}.feature-item{padding:.75rem .35rem;border-radius:12px}.feature-item svg{width:20px;height:20px}.feature-item span{font-size:.65rem}.welcome-stats{gap:1.5rem;margin-bottom:1.5rem}.welcome-stats .stat{font-size:.8rem}.cta-buttons{gap:.75rem}.cta-btn{padding:.875rem 1.5rem;font-size:1rem;border-radius:12px}.social-proof{gap:.5rem;padding:.5rem .75rem;margin-top:1.5rem}.avatar-stack .avatar{width:28px;height:28px}.social-proof span{font-size:.75rem}.welcome-footer{padding:1.25rem}}@media(hover:none)and (pointer:coarse){.cta-btn.primary:hover{transform:none;box-shadow:0 4px #3d8b00,0 8px 16px #58cc024d}.cta-btn.primary:active{transform:translateY(2px);box-shadow:0 2px #3d8b00}.cta-btn.secondary:hover{border-color:#e2e8f0;color:#475569}.cta-btn.secondary:active{border-color:#58cc02;color:#58cc02}}:root.dark .welcome-page{background:linear-gradient(180deg,#0f172a,#1e293b)}:root.dark .welcome-hero h1{color:#fff}:root.dark .welcome-hero p{color:#94a3b8}:root.dark .feature-item{background:#1e293b}:root.dark .feature-item span{color:#cbd5e1}:root.dark .cta-btn.secondary{background:#1e293b;border-color:#334155;color:#e2e8f0}:root.dark .social-proof{background:#1e293b}:root.dark .social-proof span{color:#94a3b8}:root.dark .social-proof strong{color:#fff}:root.dark .welcome-footer{background:#0f172a;border-color:#1e293b}:root.dark .welcome-stats .stat{color:#94a3b8}:root.dark .welcome-stats .stat strong{color:#fff}@media(prefers-color-scheme:dark){.welcome-page{background:linear-gradient(180deg,#0f172a,#1e293b)}.welcome-hero h1{color:#fff}.welcome-hero p{color:#94a3b8}.feature-item{background:#1e293b}.feature-item span{color:#cbd5e1}.cta-btn.secondary{background:#1e293b;border-color:#334155;color:#e2e8f0}.social-proof{background:#1e293b}.social-proof span{color:#94a3b8}.social-proof strong{color:#fff}.welcome-footer{background:#0f172a;border-color:#1e293b}}.welcome-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-background)}.welcome-loading .spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.btn{position:relative;display:inline-flex;justify-content:center;align-items:center;border:none;background:transparent;padding:0;cursor:pointer;outline-offset:4px;transition:filter .25s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.btn-face{display:flex;justify-content:center;align-items:center;width:100%;height:100%;padding:12px 24px;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:700;text-transform:uppercase;letter-spacing:.8px;transition:transform .1s cubic-bezier(.3,.7,.4,.1);will-change:transform;transform:translateY(-4px)}.btn:active:not(:disabled) .btn-face{transform:translateY(-2px)}.btn:disabled{cursor:not-allowed;filter:grayscale(1);opacity:.7}.btn-primary .btn-face{background-color:var(--color-primary);color:#fff;box-shadow:0 4px 0 var(--color-primary-dark)}.btn-primary:active:not(:disabled) .btn-face{box-shadow:0 2px 0 var(--color-primary-dark)}.btn-secondary .btn-face{background-color:var(--color-secondary);color:#fff;box-shadow:0 4px 0 var(--color-secondary-dark)}.btn-secondary:active:not(:disabled) .btn-face{box-shadow:0 2px 0 var(--color-secondary-dark)}.btn-danger .btn-face{background-color:var(--color-danger);color:#fff;box-shadow:0 4px 0 var(--color-danger-dark)}.btn-danger:active:not(:disabled) .btn-face{box-shadow:0 2px 0 var(--color-danger-dark)}.btn-outline .btn-face{background-color:transparent;color:var(--color-primary);border:2px solid var(--color-border);box-shadow:0 4px 0 var(--color-border)}.btn-outline:active:not(:disabled) .btn-face{box-shadow:0 2px 0 var(--color-border);background-color:var(--color-surface)}.btn-sm .btn-face{padding:8px 16px;font-size:.875rem}.btn-lg .btn-face{padding:16px 32px;font-size:var(--font-size-lg)}.btn-full{width:100%}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,var(--color-background) 0%,var(--color-surface) 100%)}.auth-card{background:var(--color-background);border-radius:var(--radius-xl);padding:2.5rem;width:100%;max-width:420px;box-shadow:0 10px 40px #0000001a;border:1px solid var(--color-border)}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:1.75rem;color:var(--color-text);margin-bottom:.5rem}.auth-header p{color:var(--color-text-light);font-size:1rem}.trial-badge{display:flex;align-items:center;justify-content:center;gap:.5rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;padding:.75rem 1.5rem;border-radius:var(--radius-lg);font-weight:700;margin-bottom:1.5rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.input-group{position:relative;display:flex;align-items:center}.input-group input{width:100%;padding:1rem 1rem 1rem 3rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;background:var(--color-surface);color:var(--color-text);transition:border-color .2s,box-shadow .2s}.input-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #58cc0233}.input-group input::placeholder{color:var(--color-text-light)}.input-icon{position:absolute;left:1rem;color:var(--color-text-light);pointer-events:none}.password-toggle{position:absolute;right:1rem;background:none;border:none;color:var(--color-text-light);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--color-text)}.auth-error{background:#ff4b4b1a;border:1px solid var(--color-danger);color:var(--color-danger);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.9rem;text-align:center}.auth-success{background:#58cc021a;border:1px solid var(--color-primary);color:var(--color-primary);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.9rem;text-align:center}.auth-info{background:#1cb0f61a;border:1px solid var(--color-info);color:var(--color-info);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.9rem;text-align:center}.auth-footer{margin-top:1.5rem;text-align:center;color:var(--color-text-light)}.auth-footer p{margin-top:.5rem}.auth-link{color:var(--color-text-light);text-decoration:none;transition:color .2s}.auth-link:hover{color:var(--color-primary)}.auth-link.highlight{color:var(--color-primary);font-weight:600}.admin-container{padding:2rem;max-width:1400px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-header h1{font-size:1.75rem;color:var(--color-text)}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.admin-stat-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:1.5rem;border:1px solid var(--color-border)}.admin-stat-card h3{font-size:.875rem;color:var(--color-text-light);margin-bottom:.5rem}.admin-stat-card .value{font-size:2rem;font-weight:700;color:var(--color-text)}.users-table{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.users-table table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--color-border)}.users-table th{background:var(--color-background);font-weight:600;color:var(--color-text-light);font-size:.875rem;text-transform:uppercase}.users-table tr:hover{background:var(--color-background)}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase}.role-badge.admin{background:#ff4b4b1a;color:var(--color-danger)}.role-badge.teacher{background:#ce82ff1a;color:var(--color-secondary)}.role-badge.student{background:#58cc021a;color:var(--color-primary)}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.status-badge.trial{background:#1cb0f61a;color:var(--color-info)}.status-badge.active{background:#58cc021a;color:var(--color-primary)}.status-badge.expired{background:#ff4b4b1a;color:var(--color-danger)}.action-buttons{display:flex;gap:.5rem}.action-btn{padding:.5rem;border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.action-btn.edit{background:#1cb0f61a;color:var(--color-info)}.action-btn.edit:hover{background:#1cb0f633}.action-btn.extend{background:#58cc021a;color:var(--color-primary)}.action-btn.extend:hover{background:#58cc0233}.action-btn.block{background:#ff4b4b1a;color:var(--color-danger)}.action-btn.block:hover{background:#ff4b4b33}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--color-background);border-radius:var(--radius-lg);padding:2rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{font-size:1.25rem;color:var(--color-text)}.modal-close{background:none;border:none;color:var(--color-text-light);cursor:pointer;padding:.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--color-text)}.form-group select,.form-group input{width:100%;padding:.75rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;background:var(--color-surface);color:var(--color-text)}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.admin-quick-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.quick-link-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;text-align:center}.quick-link-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.quick-link-card svg{color:var(--color-primary)}.quick-link-card.curriculum{background:linear-gradient(135deg,#8b5cf61a,#3b82f61a);border-color:#8b5cf6}.quick-link-card.curriculum:hover{border-color:#7c3aed;background:linear-gradient(135deg,#8b5cf633,#3b82f633)}.quick-link-card.curriculum svg{color:#8b5cf6}.quick-link-card.docs{background:linear-gradient(135deg,#3b82f61a,#06b6d41a);border-color:#3b82f6}.quick-link-card.docs:hover{border-color:#2563eb;background:linear-gradient(135deg,#3b82f633,#06b6d433)}.quick-link-card.docs svg{color:#3b82f6}.quick-link-card.gamification{background:linear-gradient(135deg,#f59e0b1a,#eab3081a);border-color:#f59e0b}.quick-link-card.gamification:hover{border-color:#d97706;background:linear-gradient(135deg,#f59e0b33,#eab30833)}.quick-link-card.gamification svg{color:#f59e0b}.quick-link-card span{font-weight:600;color:var(--color-text)}.quick-link-card p{font-size:.75rem;color:var(--color-text-light);margin:0}@media(max-width:768px){.auth-card{padding:1.5rem}.admin-container{padding:1rem 1rem 5rem}.admin-header{flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:1rem}.admin-header h1{font-size:1.25rem}.admin-stats{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem;scrollbar-width:thin}.admin-stats::-webkit-scrollbar{height:4px}.admin-stats::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.admin-stat-card{padding:.875rem;min-width:140px;flex-shrink:0}.admin-stat-card h3{font-size:.75rem}.admin-stat-card .value{font-size:1.25rem}.users-table{overflow-x:auto;-webkit-overflow-scrolling:touch}.users-table table{min-width:800px}.users-table th,.users-table td{padding:.75rem;font-size:.85rem}.admin-quick-links{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.quick-link-card{padding:1rem}.quick-link-card svg{width:20px;height:20px}.quick-link-card span{font-size:.85rem}.quick-link-card p{font-size:.7rem}.modal-content{padding:1rem;margin:.5rem}.modal-header h2{font-size:1.1rem}.form-group label{font-size:.85rem}.form-group select,.form-group input{padding:.625rem;font-size:.9rem}.form-actions{gap:.75rem;margin-top:1rem}.form-actions button{padding:.625rem 1rem;font-size:.85rem}.action-buttons{gap:.35rem}.action-btn{padding:.4rem}.action-btn svg{width:14px;height:14px}.role-badge,.status-badge{font-size:.7rem;padding:.2rem .6rem}.admin-section{margin-bottom:1rem}.admin-section h2{font-size:1rem}}@media(max-width:480px){.auth-container{padding:1rem}.auth-card{padding:1.25rem;border-radius:var(--radius-lg)}.auth-header h1{font-size:1.5rem}.auth-header p{font-size:.9rem}.input-group input{padding:.875rem .875rem .875rem 2.75rem;font-size:16px}.trial-badge{padding:.6rem 1rem;font-size:.9rem}.admin-container{padding:.5rem .5rem 5rem}.admin-header{margin-bottom:.75rem}.admin-header h1{font-size:1.1rem}.admin-stats{gap:.35rem;margin-bottom:.75rem}.admin-stat-card{padding:.75rem .5rem;text-align:center;min-width:120px}.admin-stat-card h3{font-size:.65rem;line-height:1.2}.admin-stat-card .value{font-size:1.1rem}.admin-quick-links{grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:.75rem}.quick-link-card{padding:.875rem .5rem;gap:.35rem}.quick-link-card svg{width:18px;height:18px}.quick-link-card span{font-size:.8rem;line-height:1.2}.quick-link-card p{display:none}.users-table table{min-width:700px}.users-table th,.users-table td{padding:.5rem;font-size:.8rem}.action-buttons{gap:.25rem}.action-btn{padding:.35rem}.action-btn svg{width:12px;height:12px}.role-badge,.status-badge{font-size:.65rem;padding:.15rem .5rem}.modal-content{padding:.875rem}.modal-header h2{font-size:1rem}.modal-close{padding:.35rem}.modal-close svg{width:18px;height:18px}.form-group label{font-size:.8rem}.form-group select,.form-group input{padding:.5rem;font-size:.85rem}.form-actions{gap:.5rem;margin-top:.875rem;padding-top:.75rem}.form-actions button{padding:.5rem .875rem;font-size:.8rem}.admin-section{margin-bottom:.75rem}.admin-section h2{font-size:.9rem}.icon-btn{width:36px;height:36px}.icon-btn svg{width:18px;height:18px}}.onboarding-container{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,#f0fdf4,#ecfeff,#f0f9ff);padding:1rem}.onboarding-progress{display:flex;align-items:center;gap:1rem;padding:1rem;max-width:600px;width:100%;margin:0 auto}.progress-bar{flex:1;height:8px;background:#0000001a;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#58cc02,#1cb0f6);border-radius:4px;transition:width .3s ease}.progress-text{font-size:.875rem;color:#64748b;white-space:nowrap}.onboarding-content{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.onboarding-step{max-width:500px;width:100%;text-align:center;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.step-icon{color:#58cc02;margin-bottom:1.5rem}.onboarding-step h1{font-size:2rem;font-weight:800;color:#1a1a2e;margin:0 0 .75rem}.onboarding-step h2{font-size:1.5rem;font-weight:700;color:#1a1a2e;margin:0 0 .5rem}.onboarding-step p{font-size:1rem;color:#64748b;margin:0 0 2rem;line-height:1.5}.welcome-step .welcome-icon{width:100px;height:100px;margin:0 auto 1.5rem;background:linear-gradient(135deg,#58cc02,#1cb0f6);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.welcome-features{display:flex;justify-content:center;gap:1.5rem;margin-top:2rem}.welcome-features .feature{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000d;min-width:100px}.welcome-features .feature svg{color:#58cc02}.welcome-features .feature span{font-size:.75rem;font-weight:600;color:#475569}.options-grid{display:grid;gap:1rem}.goals-grid,.time-grid{grid-template-columns:repeat(2,1fr)}.option-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 1rem;background:#fff;border:3px solid #e2e8f0;border-radius:16px;cursor:pointer;transition:all .2s}.option-card:hover{border-color:var(--accent-color, #58cc02);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.option-card.selected{border-color:var(--accent-color, #58cc02);background:linear-gradient(180deg,#fff,#58cc020d)}.option-icon{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--accent-color, #58cc02) 0%,rgba(88,204,2,.7) 100%);display:flex;align-items:center;justify-content:center;color:#fff}.option-card span{font-weight:600;color:#1a1a2e}.check-badge{position:absolute;top:.75rem;right:.75rem;width:24px;height:24px;background:#58cc02;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;animation:pop .2s ease}@keyframes pop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.time-option{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1rem;background:#fff;border:3px solid #e2e8f0;border-radius:16px;cursor:pointer;transition:all .2s}.time-option:hover{border-color:#58cc02;transform:translateY(-2px)}.time-option.selected{border-color:#58cc02;background:linear-gradient(180deg,#fff,#58cc020d)}.time-emoji{font-size:2rem}.time-label{font-weight:700;color:#1a1a2e;font-size:1rem}.time-desc{font-size:.75rem;color:#64748b}.options-list{display:flex;flex-direction:column;gap:.75rem}.level-option{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#fff;border:3px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s;text-align:left}.level-option:hover{border-color:#58cc02;transform:translate(4px)}.level-option.selected{border-color:#58cc02;background:linear-gradient(90deg,#fff,#58cc020d)}.level-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.level-label{font-weight:700;color:#1a1a2e}.level-desc{font-size:.875rem;color:#64748b}.cefr-badge{padding:.25rem .75rem;background:linear-gradient(135deg,#1cb0f6,#58cc02);color:#fff;border-radius:20px;font-size:.75rem;font-weight:700}.test-badge{padding:.25rem .75rem;background:#ffc800;color:#1a1a2e;border-radius:20px;font-size:.75rem;font-weight:700}.check-icon{width:28px;height:28px;background:#58cc02;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.ready-step .ready-icon{width:100px;height:100px;margin:0 auto 1.5rem;background:linear-gradient(135deg,#ffc800,#ff9600);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;animation:bounce 1s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.summary-card{background:#fff;border-radius:16px;padding:1.5rem;margin:1.5rem 0;box-shadow:0 4px 12px #0000001a}.summary-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 0;border-bottom:1px solid #e2e8f0}.summary-item:last-child{border-bottom:none}.summary-item svg{color:#58cc02}.summary-item span{color:#64748b}.summary-item strong{color:#1a1a2e}.ready-tips{background:#58cc021a;border-radius:12px;padding:1rem 1.5rem;text-align:left}.ready-tips h3{font-size:.875rem;color:#1a1a2e;margin:0 0 .75rem}.ready-tips ul{list-style:none;padding:0;margin:0}.ready-tips li{padding:.5rem 0;font-size:.875rem;color:#475569}.onboarding-nav{display:flex;align-items:center;padding:1rem;max-width:600px;width:100%;margin:0 auto}.nav-spacer{flex:1}.nav-btn{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;border:none}.nav-btn.back{background:#fff;color:#64748b;border:2px solid #e2e8f0}.nav-btn.back:hover{border-color:#94a3b8;color:#475569}.nav-btn.next{background:linear-gradient(135deg,#58cc02,#44a08d);color:#fff;box-shadow:0 4px #3d8b00}.nav-btn.next:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px #3d8b00}.nav-btn.next:active{transform:translateY(2px);box-shadow:0 2px #3d8b00}.nav-btn.next:disabled{opacity:.5;cursor:not-allowed}.nav-btn.finish{background:linear-gradient(135deg,#ffc800,#ff9600);color:#1a1a2e;box-shadow:0 4px #cc9f00}.nav-btn.finish:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px #cc9f00}@media(max-width:480px){.onboarding-container{padding:.5rem}.onboarding-step h1{font-size:1.5rem}.onboarding-step h2{font-size:1.25rem}.welcome-features{flex-direction:column;gap:.75rem}.welcome-features .feature{flex-direction:row;justify-content:center}.goals-grid,.time-grid{grid-template-columns:1fr 1fr;gap:.75rem}.option-card{padding:1rem .75rem}.option-icon{width:48px;height:48px}.option-icon svg{width:24px;height:24px}.level-option{padding:.875rem 1rem}.nav-btn{padding:.875rem 1.25rem;font-size:.9rem}}:root.dark .onboarding-container{background:linear-gradient(180deg,#0f172a,#1e293b)}:root.dark .onboarding-step h1,:root.dark .onboarding-step h2{color:#fff}:root.dark .onboarding-step p{color:#94a3b8}:root.dark .option-card,:root.dark .time-option,:root.dark .level-option{background:#1e293b;border-color:#334155}:root.dark .option-card span,:root.dark .time-label,:root.dark .level-label{color:#fff}:root.dark .time-desc,:root.dark .level-desc{color:#94a3b8}:root.dark .welcome-features .feature{background:#1e293b}:root.dark .welcome-features .feature span{color:#cbd5e1}:root.dark .summary-card{background:#1e293b}:root.dark .summary-item{border-color:#334155}:root.dark .summary-item span{color:#94a3b8}:root.dark .summary-item strong{color:#fff}:root.dark .ready-tips{background:#58cc0226}:root.dark .ready-tips h3{color:#fff}:root.dark .ready-tips li{color:#cbd5e1}:root.dark .nav-btn.back{background:#1e293b;border-color:#334155;color:#94a3b8}:root.dark .progress-text{color:#94a3b8}:root.dark .result-card,:root.dark .prompt-card{background:#1e293b}:root.dark .result-card h3,:root.dark .prompt-card h3{color:#fff}:root.dark .book-assignment{background:#58cc0226}:root.dark .book-name{color:#fff}@media(prefers-color-scheme:dark){.onboarding-container{background:linear-gradient(180deg,#0f172a,#1e293b)}.onboarding-step h1,.onboarding-step h2{color:#fff}.onboarding-step p{color:#94a3b8}.option-card,.time-option,.level-option{background:#1e293b;border-color:#334155}.option-card span,.time-label,.level-label{color:#fff}.time-desc,.level-desc{color:#94a3b8}.welcome-features .feature{background:#1e293b}.welcome-features .feature span{color:#cbd5e1}.summary-card{background:#1e293b}.summary-item{border-color:#334155}.summary-item span{color:#94a3b8}.summary-item strong{color:#fff}.ready-tips{background:#58cc0226}.ready-tips h3{color:#fff}.ready-tips li{color:#cbd5e1}.nav-btn.back{background:#1e293b;border-color:#334155;color:#94a3b8}.progress-text{color:#94a3b8}}.placement-result,.placement-prompt{margin-top:1.5rem}.result-card,.prompt-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 12px #0000001a;text-align:center}.result-icon,.prompt-icon{font-size:3rem;margin-bottom:1rem}.result-card h3,.prompt-card h3{font-size:1.25rem;font-weight:700;color:#1a1a2e;margin:0 0 .5rem}.result-card p,.prompt-card p{font-size:.9rem;color:#64748b;margin:.25rem 0}.book-assignment{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.25rem;background:linear-gradient(135deg,#58cc021a,#1cb0f61a);border-radius:12px;margin:1.5rem 0}.book-assignment svg{color:#58cc02}.book-info{display:flex;flex-direction:column;text-align:left}.book-name{font-size:1.1rem;font-weight:700;color:#1a1a2e}.book-cefr{font-size:.875rem;color:#58cc02;font-weight:600}.result-note{font-size:.8rem!important;color:#94a3b8!important;margin-top:1rem!important}.take-test-btn{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:linear-gradient(135deg,#58cc02,#44a08d);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;margin-top:1.5rem;transition:all .2s;box-shadow:0 4px #3d8b00}.take-test-btn:hover{transform:translateY(-2px);box-shadow:0 6px #3d8b00}.take-test-btn:active{transform:translateY(2px);box-shadow:0 2px #3d8b00}@media(prefers-color-scheme:dark){.result-card,.prompt-card{background:#1e293b}.result-card h3,.prompt-card h3{color:#fff}.book-assignment{background:#58cc0226}.book-name{color:#fff}}.placement-options{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.placement-choice{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:#fff;border:3px solid #e2e8f0;border-radius:16px;cursor:pointer;transition:all .2s;text-align:left}.placement-choice:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.placement-choice.beginner-choice:hover{border-color:#58cc02}.placement-choice.test-choice:hover{border-color:#1cb0f6}.choice-icon{font-size:2.5rem;flex-shrink:0}.choice-content{flex:1}.choice-content h3{font-size:1.1rem;font-weight:700;color:#1a1a2e;margin:0 0 .25rem}.choice-content p{font-size:.875rem;color:#64748b;margin:0 0 .5rem}.choice-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.choice-badge.beginner{background:linear-gradient(135deg,#58cc0226,#58cc0240);color:#3d8b00}.choice-badge.test{background:linear-gradient(135deg,#1cb0f626,#1cb0f640);color:#0284c7}.choice-arrow{color:#94a3b8;flex-shrink:0;transition:transform .2s}.placement-choice:hover .choice-arrow{transform:translate(4px);color:#64748b}.placement-divider{display:flex;align-items:center;gap:1rem;padding:.5rem 0}.placement-divider:before,.placement-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.placement-divider span{font-size:.875rem;color:#94a3b8;font-weight:500}:root.dark .placement-choice{background:#1e293b;border-color:#334155}:root.dark .choice-content h3{color:#fff}:root.dark .choice-content p{color:#94a3b8}:root.dark .choice-badge.beginner{background:#58cc0233;color:#86efac}:root.dark .choice-badge.test{background:#1cb0f633;color:#7dd3fc}:root.dark .placement-divider:before,:root.dark .placement-divider:after{background:#334155}:root.dark .placement-divider span{color:#64748b}@media(prefers-color-scheme:dark){.placement-choice{background:#1e293b;border-color:#334155}.choice-content h3{color:#fff}.choice-content p{color:#94a3b8}.choice-badge.beginner{background:#58cc0233;color:#86efac}.choice-badge.test{background:#1cb0f633;color:#7dd3fc}.placement-divider:before,.placement-divider:after{background:#334155}.placement-divider span{color:#64748b}}@media(max-width:480px){.placement-choice{padding:1rem}.choice-icon{font-size:2rem}.choice-content h3{font-size:1rem}.choice-content p{font-size:.8rem}}.onboarding-theme-toggle{position:absolute;top:1rem;right:1rem;background:#fff;border:1px solid #e2e8f0;color:#64748b;cursor:pointer;padding:.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 2px 8px #0000001a;z-index:10}.onboarding-theme-toggle:hover{background:#f1f5f9;color:#1a1a2e;transform:scale(1.05)}:root.dark .onboarding-theme-toggle{background:#1e293b;border-color:#334155;color:#94a3b8}:root.dark .onboarding-theme-toggle:hover{background:#334155;color:#fff}@media(prefers-color-scheme:dark){.onboarding-theme-toggle{background:#1e293b;border-color:#334155;color:#94a3b8}.onboarding-theme-toggle:hover{background:#334155;color:#fff}}.auth-callback{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-background);padding:2rem}.auth-callback-card{background:var(--color-surface);border-radius:16px;padding:3rem 2rem;max-width:400px;width:100%;text-align:center;box-shadow:0 4px 6px #0000001a}.auth-callback-card h2{margin:1rem 0 .5rem;color:var(--color-text);font-size:1.5rem}.auth-callback-card p{color:var(--color-text-light);margin-bottom:1.5rem;line-height:1.5}.spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.success-icon{font-size:4rem;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.error-icon{font-size:4rem;animation:shake .5s ease-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.auth-callback-card .btn-primary{background:var(--color-primary);color:#fff;border:none;border-radius:12px;padding:.875rem 2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:1rem}.auth-callback-card .btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #58cc024d}.auth-callback-card .btn-primary:active{transform:translateY(0)}@media(max-width:480px){.auth-callback{padding:1rem}.auth-callback-card{padding:2rem 1.5rem}.auth-callback-card h2{font-size:1.25rem}.success-icon,.error-icon{font-size:3rem}}.toast-container{position:fixed;top:1rem;right:1rem;z-index:10000;display:flex;flex-direction:column;gap:.5rem;max-width:400px;pointer-events:none}.toast{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:.75rem;font-size:.875rem;font-weight:600;box-shadow:0 4px 12px #00000026;animation:toast-in .3s ease;pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.toast-error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.toast-success{background:#dcfce7;color:#166534;border:1px solid #86efac}.toast-warning{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.toast-info{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}:root.dark .toast-error{background:#991b1be6;color:#fecaca;border-color:#fca5a54d}:root.dark .toast-success{background:#166534e6;color:#bbf7d0;border-color:#86efac4d}:root.dark .toast-warning{background:#92400ee6;color:#fde68a;border-color:#fcd34d4d}:root.dark .toast-info{background:#1e40afe6;color:#bfdbfe;border-color:#93c5fd4d}.toast-icon{flex-shrink:0}.toast-msg{flex:1;line-height:1.3}.toast-close{flex-shrink:0;background:none;border:none;padding:4px;cursor:pointer;opacity:.6;color:inherit;min-height:auto;border-radius:4px}.toast-close:hover{opacity:1;border-color:transparent}@keyframes toast-in{0%{opacity:0;transform:translate(1rem)}to{opacity:1;transform:translate(0)}}@media(max-width:480px){.toast-container{top:auto;bottom:5rem;right:.5rem;left:.5rem;max-width:none}}.offline-banner{position:fixed;top:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;background:#ef4444;color:#fff;font-size:.85rem;font-weight:700;text-align:center;animation:offline-slide-down .3s ease}@keyframes offline-slide-down{0%{transform:translateY(-100%)}to{transform:translateY(0)}}:root{--color-primary: #58cc02;--color-primary-dark: #46a302;--color-primary-light: #89e219;--color-secondary: #ce82ff;--color-secondary-dark: #a568cc;--color-accent: #ff9600;--color-accent-dark: #cc7800;--color-danger: #ff4b4b;--color-danger-dark: #d42c2c;--color-info: #1cb0f6;--color-info-dark: #1899d6;--color-background: #ffffff;--color-surface: #f7f7f7;--color-text: #3c3c3c;--color-text-light: #777777;--color-border: #e5e5e5;--font-family: "Nunito", "Segoe UI", "Roboto", "Helvetica", "Arial", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-size-base: 16px;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 2px 0 var(--color-border);--shadow-md: 0 4px 0 var(--color-border);--shadow-lg: 0 6px 0 var(--color-border);--min-touch-target: 44px;--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-top: env(safe-area-inset-top, 0px)}@media(max-width:480px){:root{--font-size-base: 14px;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--spacing-lg: 1rem;--spacing-xl: 1.5rem}}:root.dark{--color-background: #131f24;--color-surface: #202f36;--color-text: #ffffff;--color-text-light: #dce6ea;--color-border: #37464f}:root.forest{--color-primary: #2d6a4f;--color-primary-dark: #1b4332;--color-primary-light: #40916c;--color-background: #d8f3dc;--color-surface: #b7e4c7;--color-text: #081c15;--color-text-light: #2d6a4f;--color-border: #95d5b2}:root.dark .feature-item,:root.dark .summary-card,:root.dark .option-card,:root.dark .time-option,:root.dark .level-option,:root.dark .welcome-features .feature,:root.dark .social-proof{background:var(--color-surface, #1e293b);border-color:var(--color-border, #334155)}:root.dark .option-card span,:root.dark .time-label,:root.dark .level-label,:root.dark .summary-item strong,:root.dark .book-name{color:#f1f5f9}:root.dark .time-desc,:root.dark .level-desc,:root.dark .summary-item span,:root.dark .feature-item span,:root.dark .social-proof span{color:#94a3b8}:root.dark input,:root.dark select,:root.dark textarea{background:var(--color-surface, #1e293b);color:var(--color-text, #f1f5f9);border-color:var(--color-border, #334155)}:root.dark input::placeholder,:root.dark textarea::placeholder{color:#64748b}:root.dark .nav-btn.back,:root.dark .cta-btn.secondary{background:var(--color-surface, #1e293b);border-color:var(--color-border, #334155);color:#94a3b8}:root.dark .modal-overlay,:root.dark .feedback-overlay{background:#000c}:root.dark .modal-content,:root.dark .feedback-content{background:var(--color-surface, #1e293b);color:var(--color-text, #f1f5f9)}:root.dark .progress-bar{background:var(--color-border, #334155)}:root.dark .badge{background:var(--color-surface, #1e293b)}:root.dark table{background:var(--color-surface, #1e293b)}:root.dark th{background:#ffffff0d;color:#f1f5f9}:root.dark td{border-color:var(--color-border, #334155);color:var(--color-text, #e2e8f0)}:root.dark tr:hover{background:#ffffff0d}:root.dark .dropdown-menu,:root.dark .select-dropdown{background:var(--color-surface, #1e293b);border-color:var(--color-border, #334155)}:root.dark .dropdown-item:hover{background:#ffffff1a}:root.dark .tooltip{background:#0f172a;color:#f1f5f9}:root.dark ::-webkit-scrollbar-track{background:var(--color-background, #131f24)}:root.dark ::-webkit-scrollbar-thumb{background:var(--color-border, #334155)}:root.dark ::-webkit-scrollbar-thumb:hover{background:#475569}:root.dark .card,:root.dark .panel,:root.dark [class*=shadow]{box-shadow:0 4px 12px #0000004d}:root.dark a:not([class]){color:var(--color-primary, #58cc02)}:root.dark a:not([class]):hover{color:var(--color-primary-light, #89e219)}:root.dark code,:root.dark pre{background:#0000004d;color:#e2e8f0}:root.dark hr{border-color:var(--color-border, #334155)}:root.dark blockquote{border-left-color:var(--color-primary, #58cc02);background:#58cc021a;color:#e2e8f0}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%;overflow-x:hidden;max-width:100vw}body{font-family:var(--font-family);background-color:var(--color-background);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s,color .3s;overflow-x:hidden;max-width:100vw;width:100%;-webkit-tap-highlight-color:transparent;touch-action:manipulation}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;width:100%;max-width:100vw;overflow-x:hidden}button{font-family:inherit;border:none;cursor:pointer;background:none;touch-action:manipulation}a{text-decoration:none;color:inherit;touch-action:manipulation}ul,ol{list-style:none}input,select,textarea{font-size:16px!important}.touch-target{min-height:var(--min-touch-target, 44px);min-width:var(--min-touch-target, 44px)}@media(max-width:767px){.hide-mobile{display:none!important}}@media(min-width:768px){.hide-desktop{display:none!important}}@media(max-width:480px){.mobile-p-sm{padding:var(--spacing-sm)!important}.mobile-p-md{padding:var(--spacing-md)!important}.mobile-px-sm{padding-left:var(--spacing-sm)!important;padding-right:var(--spacing-sm)!important}.mobile-py-sm{padding-top:var(--spacing-sm)!important;padding-bottom:var(--spacing-sm)!important}}.overflow-hidden-x{overflow-x:hidden}.scroll-x{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.scroll-y{overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.scroll-hidden::-webkit-scrollbar{display:none}.scroll-hidden{-ms-overflow-style:none;scrollbar-width:none}.flex-col-mobile{display:flex;flex-direction:column}@media(min-width:768px){.flex-col-mobile{flex-direction:row}}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.safe-area-top{padding-top:var(--safe-area-top, env(safe-area-inset-top, 0px))}.safe-area-bottom{padding-bottom:var(--safe-area-bottom, env(safe-area-inset-bottom, 0px))}.safe-area-left{padding-left:var(--safe-area-left, env(safe-area-inset-left, 0px))}.safe-area-right{padding-right:var(--safe-area-right, env(safe-area-inset-right, 0px))}.card-base{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);transition:transform .2s,box-shadow .2s}.card-base:active{transform:scale(.98)}.btn-touch:active{transform:scale(.95);opacity:.9}.grid-auto-fit{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr));gap:var(--spacing-md)}@media(max-width:480px){.grid-auto-fit{grid-template-columns:1fr}}.stack-sm>*+*{margin-top:var(--spacing-sm)}.stack-md>*+*{margin-top:var(--spacing-md)}.stack-lg>*+*{margin-top:var(--spacing-lg)}.text-responsive{font-size:clamp(.875rem,2.5vw,1rem)}.heading-responsive{font-size:clamp(1.25rem,4vw,2rem)}.ptr-area{min-height:60px;display:flex;align-items:center;justify-content:center}.skeleton{background:linear-gradient(90deg,var(--color-border) 25%,var(--color-surface) 50%,var(--color-border) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:var(--radius-md)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.animate-pop{animation:pop .3s cubic-bezier(.175,.885,.32,1.275)}.animate-slide-in{animation:slideInRight .5s ease-out}.animate-fade-in{animation:fadeIn .5s ease-out}
