@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";.game-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}@media(max-width:768px){.game-stats{grid-template-columns:1fr}}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);position:relative;overflow:hidden;transition:all var(--transition-base)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.stat-points-card:before{background:linear-gradient(90deg,var(--color-points),#fbbf24)}.stat-hearts-card:before{background:linear-gradient(90deg,var(--color-hearts),#f472b6)}.stat-streak-card:before{background:linear-gradient(90deg,var(--color-streak),#fb923c)}.stat-points-card{color:var(--color-points)}.stat-hearts-card{color:var(--color-hearts)}.stat-streak-card{color:var(--color-streak)}.stat-icon{padding:var(--spacing-md);background:var(--bg-glass);border-radius:var(--radius-full)}.stat-info{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:2rem;font-weight:700}.stat-label{font-size:.875rem;color:var(--text-muted)}.hearts-display{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.heart-filled{color:var(--color-hearts);animation:heartBeat .3s ease-in-out}.heart-empty{color:var(--text-muted);opacity:.3}@keyframes heartBeat{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.streak-fire{font-size:1.5rem;animation:flicker .5s ease-in-out infinite alternate}@keyframes flicker{0%{transform:scale(1) rotate(-5deg)}to{transform:scale(1.1) rotate(5deg)}}.game-stats-compact{display:flex;gap:var(--spacing-sm)}.stat-badge{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:.875rem;font-weight:600}.stat-points{background:#eab30826;color:var(--color-points);border:1px solid rgba(234,179,8,.3)}.stat-hearts{background:#ec489926;color:var(--color-hearts);border:1px solid rgba(236,72,153,.3)}.stat-streak{background:#f9731626;color:var(--color-streak);border:1px solid rgba(249,115,22,.3)}.points-display,.streak-display{display:flex;align-items:center;gap:var(--spacing-xs)}.points-icon{color:var(--color-points)}.points-value{font-weight:600;color:var(--color-points)}.streak-icon{color:var(--color-streak)}.streak-value{font-weight:600;color:var(--color-streak)}.streak-bonus{animation:flicker .5s ease-in-out infinite alternate}.hearts-display-inline{display:flex;gap:2px}.hearts-display-inline .heart-filled{color:var(--color-hearts)}.hearts-display-inline .heart-empty{color:var(--text-muted);opacity:.3}.layout{min-height:100vh;display:flex;flex-direction:column;padding-bottom:0}.header{position:sticky;top:0;z-index:100;background:#0f0f1af2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color)}.header-content{max-width:1400px;margin:0 auto;padding:var(--spacing-md) var(--spacing-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xl)}.logo{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.5rem;font-weight:800;color:var(--text-primary);text-decoration:none}.logo svg{color:var(--color-primary-500)}.nav-links{display:flex;gap:var(--spacing-md)}.nav-link{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);font-weight:500}.nav-link:hover{color:var(--text-primary);background:var(--bg-glass)}.nav-link.active{color:var(--color-primary-400);background:#6366f126}.study-buddy-link{background:linear-gradient(135deg,#10b9811a,#0596691a);border:1px solid rgba(16,185,129,.2)}.study-buddy-link:hover,.study-buddy-link.active{background:linear-gradient(135deg,#10b98133,#05966933);border-color:#10b98166;color:#10b981}.header-right{display:flex;align-items:center;gap:var(--spacing-lg)}.user-menu{display:flex;align-items:center;gap:var(--spacing-md)}.user-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-full);text-decoration:none;transition:all var(--transition-fast)}.user-info:hover{border-color:var(--color-primary-400)}.avatar{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-500);border-radius:var(--radius-full);color:#fff}.username{font-weight:500;color:var(--text-primary)}.logout-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.logout-btn:hover{background:#ef444433;border-color:var(--color-error-500);color:var(--color-error-500)}.profile-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.profile-btn:hover{background:#6366f133;border-color:var(--color-primary-400);color:var(--color-primary-400)}.avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.auth-buttons{display:flex;gap:var(--spacing-sm)}.main-content{flex:1;padding:var(--spacing-xl) var(--spacing-lg);max-width:1400px;margin:0 auto;width:100%}.footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);margin-top:auto}.footer-content{max-width:1400px;margin:0 auto;padding:var(--spacing-lg);text-align:center}.footer-content p{color:var(--text-muted);font-size:.875rem}.bottom-nav{display:none}@media(max-width:1024px){.header-content{padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-md)}.nav-link span{display:none}.nav-link{padding:var(--spacing-sm)}.username{display:none}.main-content{padding:var(--spacing-lg) var(--spacing-md)}}@media(max-width:768px){.layout{padding-bottom:70px}.desktop-nav{display:none!important}.header-content{padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-sm)}.logo span{display:none}.logo svg{width:32px;height:32px}.game-stats-compact{display:none!important}.user-info{padding:var(--spacing-xs) var(--spacing-sm)}.username{display:none}.avatar{width:28px;height:28px}.logout-btn{width:32px;height:32px}.auth-buttons .btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem}.main-content{padding:var(--spacing-md)}.footer{display:none}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:70px;background:#0f0f1afa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--border-color);z-index:1000;justify-content:space-around;align-items:center;padding:var(--spacing-xs) 0;padding-bottom:env(safe-area-inset-bottom,var(--spacing-xs))}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:var(--spacing-xs) var(--spacing-sm);color:var(--text-muted);text-decoration:none;font-size:.7rem;font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-fast);min-width:60px}.bottom-nav-item:hover,.bottom-nav-item:active{color:var(--text-secondary)}.bottom-nav-item.active{color:var(--color-primary-400)}.bottom-nav-item.active svg{transform:scale(1.1)}.bottom-nav-item svg{transition:transform var(--transition-fast)}}@media(max-width:375px){.bottom-nav-item{min-width:50px;padding:var(--spacing-xs) 4px;font-size:.65rem}.bottom-nav-item svg{width:20px;height:20px}.auth-buttons{flex-direction:column;gap:4px}.auth-buttons .btn{padding:4px 8px;font-size:.8rem}}.home-page{padding-bottom:var(--spacing-2xl)}.hero{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-2xl);align-items:center;min-height:70vh;padding:var(--spacing-2xl) 0}@media(max-width:968px){.hero{grid-template-columns:1fr;text-align:center}}.hero-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.hero-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:var(--radius-full);color:var(--color-primary-400);font-size:.875rem;font-weight:500;width:fit-content}@media(max-width:968px){.hero-badge{margin:0 auto}}.hero-title{font-size:3.5rem;font-weight:800;line-height:1.1;color:var(--text-primary)}@media(max-width:640px){.hero-title{font-size:2.5rem}}.hero-subtitle{font-size:1.25rem;color:var(--text-secondary);line-height:1.7;max-width:500px}@media(max-width:968px){.hero-subtitle{margin:0 auto}}.hero-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg)}@media(max-width:968px){.hero-actions{justify-content:center}}@media(max-width:480px){.hero-actions{flex-direction:column}}.hero-visual{position:relative;height:400px}@media(max-width:968px){.hero-visual{display:none}}.floating-card{position:absolute;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);font-weight:600;animation:float 3s ease-in-out infinite}.card-1{top:20%;left:10%;color:var(--color-points);animation-delay:0s}.card-2{top:50%;right:10%;color:var(--color-streak);animation-delay:.5s}.card-3{bottom:20%;left:20%;color:var(--color-success-400);animation-delay:1s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.features{padding:var(--spacing-2xl) 0}.section-title{font-size:2rem;font-weight:700;text-align:center;margin-bottom:var(--spacing-2xl)}.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-lg)}@media(max-width:1024px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.features-grid{grid-template-columns:1fr}}.feature-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-xl);text-align:center;transition:all var(--transition-base)}.feature-card:hover{transform:translateY(-8px);border-color:var(--color-primary-500);box-shadow:var(--shadow-lg),var(--shadow-glow)}.feature-icon{display:inline-flex;padding:var(--spacing-md);background:linear-gradient(135deg,var(--color-primary-500),var(--color-secondary-500));border-radius:var(--radius-lg);color:#fff;margin-bottom:var(--spacing-md)}.feature-card h3{font-size:1.125rem;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.feature-card p{font-size:.9rem;color:var(--text-muted);line-height:1.6}.auth-page{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.auth-container{width:100%;max-width:440px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-2xl);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.auth-header{text-align:center;margin-bottom:var(--spacing-2xl)}.auth-header h1{font-size:1.75rem;font-weight:700;margin-bottom:var(--spacing-sm)}.auth-header p{color:var(--text-muted)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.auth-error{padding:var(--spacing-md);background:#ef444426;border:1px solid var(--color-error-500);border-radius:var(--radius-md);color:var(--color-error-400);font-size:.9rem;text-align:center}.input-wrapper{position:relative}.input-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-muted)}.input-wrapper .input{padding-left:calc(var(--spacing-md) * 2 + 18px)}.auth-footer{margin-top:var(--spacing-xl);text-align:center}.auth-footer p{color:var(--text-muted)}.auth-footer a{color:var(--color-primary-400);font-weight:500}.auth-footer a:hover{text-decoration:underline}.auth-divider{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-lg) 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.auth-divider span{color:var(--text-muted);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.btn-google{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-weight:500;font-size:1rem;cursor:pointer;transition:all .2s ease}.btn-google:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--text-muted)}.btn-google:disabled{opacity:.6;cursor:not-allowed}.auth-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding:4px;background:var(--bg-tertiary);border-radius:var(--radius-md)}.auth-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);font-weight:500;cursor:pointer;transition:all .2s ease}.auth-tab:hover{color:var(--text-primary)}.auth-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 3px #0000001a}.form-hint{display:block;margin-top:var(--spacing-xs);font-size:.75rem;color:var(--text-muted)}.otp-input{letter-spacing:.5em;text-align:center;font-size:1.25rem;font-weight:600}.btn-text{background:transparent;border:none;color:var(--color-primary-400);font-weight:500;cursor:pointer;padding:var(--spacing-sm);margin-top:var(--spacing-sm)}.btn-text:hover{text-decoration:underline}.course-card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;text-decoration:none;transition:all var(--transition-base)}.course-card:hover{transform:translateY(-6px);border-color:var(--color-primary-500);box-shadow:var(--shadow-lg),var(--shadow-glow)}.course-thumbnail{position:relative;aspect-ratio:16 / 9;background:var(--bg-tertiary);overflow:hidden}.course-thumbnail img{width:100%;height:100%;object-fit:cover}.course-thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-800),var(--color-primary-900));color:var(--color-primary-300)}.enrolled-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-success-500);color:#fff;font-size:.75rem;font-weight:600;border-radius:var(--radius-sm)}.course-content{flex:1;padding:var(--spacing-lg)}.course-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm);line-height:1.4}.course-description{font-size:.875rem;color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:var(--spacing-md)}.course-meta{display:flex;gap:var(--spacing-md)}.meta-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--text-muted)}.course-action{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color)}.course-action .btn{width:100%}.dashboard-page{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--spacing-lg)}.dashboard-header h1{font-size:2rem;margin-bottom:var(--spacing-xs)}.dashboard-header p{color:var(--text-muted)}.section-title{font-size:1.25rem;font-weight:700;margin-bottom:var(--spacing-lg)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.section-header .section-title{margin-bottom:0}.progress-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}@media(max-width:768px){.progress-grid{grid-template-columns:1fr}}.progress-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.progress-card .progress-icon{display:inline-flex;padding:var(--spacing-sm);background:var(--bg-glass);border-radius:var(--radius-md);color:var(--color-primary-400);margin-bottom:var(--spacing-md)}.progress-info{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.progress-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.progress-label{font-size:.875rem;color:var(--text-muted)}.progress-bar-container{height:8px;background:var(--bg-glass);border-radius:var(--radius-full);overflow:hidden}.progress-bar-container .progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary-500),var(--color-secondary-500));border-radius:var(--radius-full);transition:width .5s ease}.courses-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}@media(max-width:1024px){.courses-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.courses-grid{grid-template-columns:1fr}}.empty-courses{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);text-align:center;gap:var(--spacing-md);color:var(--text-muted)}.empty-courses h3{margin-top:var(--spacing-md)}.empty-courses p{margin-bottom:var(--spacing-md)}.courses-page,.course-detail-page{padding-bottom:var(--spacing-2xl)}.page-header{margin-bottom:var(--spacing-2xl)}.page-header h1{font-size:2rem;margin-bottom:var(--spacing-sm)}.courses-list-grid{display:flex;flex-direction:column;gap:var(--spacing-md)}.course-item{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);text-decoration:none;transition:all var(--transition-base)}.course-item:hover{transform:translate(8px);border-color:var(--color-primary-500);box-shadow:var(--shadow-md)}.course-item-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-700));border-radius:var(--radius-md);color:#fff;flex-shrink:0}.course-item-content{flex:1}.course-item-content h3{font-size:1.125rem;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.course-item-content p{font-size:.875rem;color:var(--text-muted)}.course-item-arrow{color:var(--text-muted);transition:transform var(--transition-fast)}.course-item:hover .course-item-arrow{transform:translate(4px);color:var(--color-primary-400)}.course-hero{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-2xl);margin-bottom:var(--spacing-2xl)}.course-hero-content h1{font-size:2rem;margin-bottom:var(--spacing-md)}.course-hero-content p{font-size:1.125rem;color:var(--text-secondary);margin-bottom:var(--spacing-xl);max-width:600px}.enrolled-status{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:#22c55e26;border:1px solid var(--color-success-500);border-radius:var(--radius-full);color:var(--color-success-400);font-weight:600}.modules-section h2{font-size:1.5rem;margin-bottom:var(--spacing-xl)}.module-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;margin-bottom:var(--spacing-lg)}.module-header{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.module-number{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-primary-500);border-radius:var(--radius-md);color:#fff;font-weight:700;flex-shrink:0}.module-info h3{font-size:1.125rem;margin-bottom:var(--spacing-xs)}.module-info p{font-size:.875rem;color:var(--text-muted)}.module-content-list{padding:var(--spacing-md)}.content-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-fast);color:var(--text-primary)}.content-item:hover:not(.locked){background:var(--bg-glass)}.content-item.locked{opacity:.5;cursor:not-allowed}.content-item.completed .content-icon{color:var(--color-success-500)}.content-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-glass);border-radius:var(--radius-md);color:var(--color-primary-400);flex-shrink:0}.content-title{flex:1;font-weight:500}.content-type{font-size:.75rem;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-glass);border-radius:var(--radius-sm);color:var(--text-muted)}.content-item.assessment .content-icon{color:var(--color-warning-500)}.content-item.practice{background:linear-gradient(135deg,#8b5cf61a,#06b6d41a);border:1px dashed rgba(139,92,246,.3);margin-top:var(--spacing-sm)}.content-item.practice:hover:not(.locked){background:linear-gradient(135deg,#8b5cf633,#06b6d433);border-color:#8b5cf680}.content-item.practice .practice-icon{background:linear-gradient(135deg,var(--color-primary-500),#06b6d4);color:#fff}.content-item.practice .practice-type{background:linear-gradient(135deg,#8b5cf64d,#06b6d44d);color:var(--color-primary-400)}.empty-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--text-muted);gap:var(--spacing-md)}@media(max-width:1024px){.course-hero{padding:var(--spacing-xl)}.course-hero-content h1{font-size:1.75rem}.module-header{gap:var(--spacing-md)}}@media(max-width:768px){.courses-page,.course-detail-page{padding-bottom:var(--spacing-lg)}.page-header{margin-bottom:var(--spacing-lg)}.page-header h1{font-size:1.5rem}.course-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md)}.course-item:hover{transform:translate(0);transform:translateY(-4px)}.course-item-arrow{align-self:flex-end}.course-hero{padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);border-radius:var(--radius-lg)}.course-hero-content h1{font-size:1.5rem}.course-hero-content p{font-size:1rem}.enrolled-status{padding:var(--spacing-xs) var(--spacing-md);font-size:.875rem}.modules-section h2{font-size:1.25rem;margin-bottom:var(--spacing-lg)}.module-card{border-radius:var(--radius-lg)}.module-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md)}.module-number{width:36px;height:36px;font-size:.875rem}.module-info h3{font-size:1rem}.content-item{padding:var(--spacing-sm) var(--spacing-md)}.content-icon{width:28px;height:28px}.content-type{font-size:.65rem}}@media(max-width:480px){.course-item-content h3{font-size:1rem}.course-hero{padding:var(--spacing-md)}.course-hero-content h1{font-size:1.25rem}.course-hero-content p{font-size:.875rem;margin-bottom:var(--spacing-lg)}.enrolled-status{width:100%;justify-content:center}.module-content-list{padding:var(--spacing-sm)}.content-item{padding:var(--spacing-xs) var(--spacing-sm);gap:var(--spacing-sm)}.content-title{font-size:.875rem}.empty-state,.error-state{padding:var(--spacing-lg)}}.lottie-player{position:relative;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.lottie-animation-container{width:100%;aspect-ratio:16 / 9;background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.lottie-animation-container:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 0%,rgba(0,0,0,.3) 100%);pointer-events:none}.lottie-controls{padding:var(--spacing-md) var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md);background:var(--bg-tertiary)}.lottie-progress{width:100%;height:4px;background:var(--bg-glass);border-radius:var(--radius-full);overflow:hidden}.lottie-progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary-500),var(--color-secondary-500));border-radius:var(--radius-full);transition:width .1s linear}.lottie-buttons{display:flex;justify-content:center;align-items:center;gap:var(--spacing-md)}.lottie-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.lottie-btn:hover:not(:disabled){background:var(--color-primary-500);border-color:var(--color-primary-500);transform:scale(1.1)}.lottie-btn:disabled{opacity:.3;cursor:not-allowed}.lottie-btn.play-btn{width:56px;height:56px;font-size:1rem;background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-700));border:none;box-shadow:var(--shadow-glow)}.lottie-btn.play-btn:hover{transform:scale(1.1);box-shadow:0 0 30px #8b5cf680}.lottie-slide-indicator{display:flex;justify-content:center;gap:var(--spacing-sm)}.slide-dot{width:10px;height:10px;border-radius:var(--radius-full);background:var(--bg-glass);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast)}.slide-dot:hover{background:var(--color-primary-400)}.slide-dot.active{background:var(--color-primary-500);border-color:var(--color-primary-500);transform:scale(1.2)}.lottie-slide-title{text-align:center;color:var(--text-muted);font-size:.875rem}.lottie-player-empty{padding:var(--spacing-2xl);text-align:center;color:var(--text-muted);background:var(--bg-card);border-radius:var(--radius-xl)}.lottie-start-overlay{position:absolute;inset:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;transition:all var(--transition-normal)}.lottie-start-overlay:hover{background:#0009}.lottie-start-overlay:hover .start-button{transform:scale(1.1);box-shadow:0 0 50px #8b5cf699}.start-button{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-2xl);background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-700));border-radius:var(--radius-full);box-shadow:0 0 30px #8b5cf666;transition:all var(--transition-normal)}.start-icon{font-size:1.5rem;color:#fff}.start-text{font-size:1.25rem;font-weight:600;color:#fff}.start-hint{margin-top:var(--spacing-md);color:#ffffffb3;font-size:.875rem}.animation-loading,.animation-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:200px;color:var(--text-muted);gap:var(--spacing-md)}.placeholder-icon{font-size:3rem;opacity:.5}.animation-placeholder p{font-size:.9rem}@media(max-width:1024px){.lottie-controls{padding:var(--spacing-sm) var(--spacing-md)}.lottie-btn{width:48px;height:48px}.lottie-btn.play-btn{width:60px;height:60px}.start-button{padding:var(--spacing-md) var(--spacing-xl)}.start-text{font-size:1.125rem}}@media(max-width:768px){.lottie-player{border-radius:var(--radius-lg)}.lottie-animation-container{aspect-ratio:4 / 3}.lottie-controls{padding:var(--spacing-sm);gap:var(--spacing-sm)}.lottie-buttons{gap:var(--spacing-sm)}.lottie-btn{width:44px;height:44px;font-size:.75rem}.lottie-btn.play-btn{width:52px;height:52px}.slide-dot{width:12px;height:12px}.lottie-slide-indicator{gap:var(--spacing-xs);flex-wrap:wrap;max-width:100%;justify-content:center}.lottie-slide-title{font-size:.75rem}.start-button{padding:var(--spacing-md) var(--spacing-lg);gap:var(--spacing-sm)}.start-icon{font-size:1.25rem}.start-text{font-size:1rem}.start-hint{font-size:.75rem}.animation-loading,.animation-placeholder{min-height:150px}.placeholder-icon{font-size:2.5rem}}@media(max-width:480px){.lottie-player{border-radius:var(--radius-md)}.lottie-animation-container{aspect-ratio:1 / 1}.lottie-controls{padding:var(--spacing-xs) var(--spacing-sm);gap:var(--spacing-xs)}.lottie-progress{height:3px}.lottie-buttons{gap:var(--spacing-xs)}.lottie-btn{width:40px;height:40px;font-size:.7rem}.lottie-btn.play-btn{width:48px;height:48px;font-size:.875rem}.slide-dot{width:10px;height:10px}.lottie-slide-title{font-size:.7rem}.start-button{padding:var(--spacing-sm) var(--spacing-md)}.start-icon{font-size:1rem}.start-text{font-size:.875rem}.start-hint{font-size:.7rem}.lottie-player-empty{padding:var(--spacing-lg)}}.question-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-xl);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.question-icon{color:var(--color-primary-400)}.question-points{background:var(--bg-glass);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:600;color:var(--color-points);border:1px solid rgba(234,179,8,.3)}.question-text{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xl);line-height:1.5}.answers-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.answer-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-glass);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.answer-option:hover:not(.disabled){border-color:var(--color-primary-400);background:#8b5cf61a}.answer-option.selected{border-color:var(--color-primary-500);background:#8b5cf626}.answer-option.correct{border-color:var(--color-success-500);background:#22c55e26}.answer-option.incorrect{border-color:var(--color-error-500);background:#ef444426}.answer-option.disabled{cursor:default}.answer-letter{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);background:var(--bg-tertiary);font-weight:700;font-size:.875rem;color:var(--text-secondary);flex-shrink:0}.answer-option.selected .answer-letter{background:var(--color-primary-500);color:#fff}.answer-option.correct .answer-letter{background:var(--color-success-500);color:#fff}.answer-option.incorrect .answer-letter{background:var(--color-error-500);color:#fff}.answer-text{flex:1;font-size:1rem;color:var(--text-primary)}.answer-icon{flex-shrink:0}.answer-icon.correct{color:var(--color-success-500)}.answer-icon.incorrect{color:var(--color-error-500)}.result-feedback{margin-top:var(--spacing-xl);padding:var(--spacing-lg);border-radius:var(--radius-lg);animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.result-feedback.correct{background:#22c55e26;border:1px solid var(--color-success-500)}.result-feedback.incorrect{background:#ef444426;border:1px solid var(--color-error-500)}.result-header{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-sm)}.result-feedback.correct .result-header{color:var(--color-success-400)}.result-feedback.incorrect .result-header{color:var(--color-error-400)}.result-explanation{color:var(--text-secondary);font-size:.9rem;line-height:1.6}@media(max-width:1024px){.question-card{padding:var(--spacing-lg)}}@media(max-width:768px){.question-card{padding:var(--spacing-md);border-radius:var(--radius-lg)}.question-header{margin-bottom:var(--spacing-md)}.question-text{font-size:1.125rem;margin-bottom:var(--spacing-lg)}.answers-list{gap:var(--spacing-sm)}.answer-option{padding:var(--spacing-md);gap:var(--spacing-sm);border-radius:var(--radius-md)}.answer-letter{width:28px;height:28px;font-size:.75rem}.answer-text{font-size:.9rem}.result-feedback{padding:var(--spacing-md);margin-top:var(--spacing-lg)}.result-header{font-size:1rem}.result-explanation{font-size:.85rem}}@media(max-width:480px){.question-card{padding:var(--spacing-sm);border-radius:var(--radius-md)}.question-text{font-size:1rem}.answer-option{padding:var(--spacing-sm) var(--spacing-md)}.answer-letter{width:24px;height:24px;font-size:.7rem}.answer-text{font-size:.85rem}.question-points{font-size:.75rem;padding:var(--spacing-xs) var(--spacing-sm)}}.study-buddy-widget-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:1000}.study-buddy-fab{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #6366f166;transition:all .3s ease;animation:fabPulse 2s infinite}.study-buddy-fab:hover{transform:scale(1.1);box-shadow:0 6px 30px #6366f199}.study-buddy-fab.active{animation:none;background:linear-gradient(135deg,#ef4444,#dc2626)}@keyframes fabPulse{0%,to{box-shadow:0 4px 20px #6366f166}50%{box-shadow:0 4px 30px #6366f1b3}}.study-buddy-panel{position:absolute;bottom:70px;right:0;width:360px;height:480px;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:1rem;border:1px solid rgba(255,255,255,.1);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000080;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.widget-header{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.1)}.widget-header-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);display:flex;align-items:center;justify-content:center;font-size:1.25rem}.widget-header-info{flex:1}.widget-header-info h3{color:#fff;font-size:1rem;margin:0}.widget-header-info p{color:#fff9;font-size:.75rem;margin:0}.widget-context{font-size:.7rem;color:#8b5cf6cc;background:#8b5cf626;padding:.25rem .5rem;border-radius:.25rem;margin-top:.25rem;display:inline-block}.widget-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.widget-message{display:flex;gap:.5rem;max-width:90%;animation:fadeIn .3s ease-out}.widget-message.user{align-self:flex-end;flex-direction:row-reverse}.widget-message.assistant{align-self:flex-start}.widget-message-content{padding:.75rem 1rem;border-radius:1rem;font-size:.9rem;line-height:1.5}.widget-message.user .widget-message-content{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-bottom-right-radius:.25rem}.widget-message.assistant .widget-message-content{background:#ffffff1a;color:#fff;border-bottom-left-radius:.25rem}.widget-typing{display:flex;gap:.25rem;padding:.75rem 1rem;background:#ffffff1a;border-radius:1rem 1rem 1rem .25rem;align-self:flex-start}.widget-typing span{width:6px;height:6px;background:#fff9;border-radius:50%;animation:widgetTypingBounce 1.4s infinite ease-in-out}.widget-typing span:nth-child(1){animation-delay:0s}.widget-typing span:nth-child(2){animation-delay:.2s}.widget-typing span:nth-child(3){animation-delay:.4s}@keyframes widgetTypingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.widget-input{display:flex;gap:.5rem;padding:.75rem;background:#0000004d;border-top:1px solid rgba(255,255,255,.1)}.widget-input input{flex:1;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:1.5rem;padding:.625rem 1rem;color:#fff;font-size:.9rem}.widget-input input::placeholder{color:#fff6}.widget-input input:focus{outline:none;border-color:#8b5cf680}.widget-send-btn{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.widget-send-btn:hover:not(:disabled){transform:scale(1.1)}.widget-send-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:480px){.study-buddy-panel{width:calc(100vw - 2rem);right:-.5rem;height:60vh;max-height:500px}.study-buddy-widget-container{bottom:1rem;right:1rem}.study-buddy-fab{width:56px;height:56px}}.widget-messages::-webkit-scrollbar{width:4px}.widget-messages::-webkit-scrollbar-track{background:#ffffff0d}.widget-messages::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.lesson-page{max-width:900px;margin:0 auto}.lesson-header{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);flex-wrap:wrap}.back-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.back-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.lesson-header h1{flex:1;font-size:1.5rem}.lesson-progress{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:.875rem;color:var(--text-muted)}.lesson-content,.animation-phase{display:flex;flex-direction:column;gap:var(--spacing-xl)}.no-animation{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-2xl);text-align:center}.no-animation p{margin-bottom:var(--spacing-lg);color:var(--text-muted)}.phase-actions{display:flex;justify-content:center;margin-top:var(--spacing-lg)}.question-progress-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg)}.question-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.progress-label{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.progress-count{font-size:.875rem;font-weight:700;color:var(--color-primary-400)}.question-progress-bar{width:100%;height:10px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.question-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary-500),var(--color-secondary-500));border-radius:var(--radius-full);transition:width .4s ease-out}.complete-phase{display:flex;justify-content:center;padding:var(--spacing-2xl)}.complete-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-2xl);text-align:center;max-width:500px;width:100%;animation:celebrationPop .5s ease-out}@keyframes celebrationPop{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.complete-icon{display:inline-flex;padding:var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary-500),var(--color-secondary-500));border-radius:var(--radius-full);color:#fff;margin-bottom:var(--spacing-lg);animation:float 2s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.complete-card h2{font-size:1.75rem;margin-bottom:var(--spacing-sm)}.complete-card>p{color:var(--text-muted);margin-bottom:var(--spacing-xl)}.complete-stats{display:flex;justify-content:center;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--bg-glass);border-radius:var(--radius-lg)}.complete-stats .stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.complete-stats .stat-value{font-size:2rem;font-weight:700;color:var(--color-points)}.complete-stats .stat-label{font-size:.875rem;color:var(--text-muted)}.complete-actions{display:flex;justify-content:center}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--spacing-lg)}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--color-primary-500);border-radius:50%;animation:spin 1s linear infinite}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--spacing-lg);text-align:center}@media(max-width:1024px){.lesson-page{max-width:100%;padding:0 var(--spacing-md)}.lesson-header h1{font-size:1.35rem}.complete-card{padding:var(--spacing-xl)}.complete-stats .stat-value{font-size:1.75rem}}@media(max-width:768px){.lesson-page{padding:0 var(--spacing-sm)}.lesson-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.lesson-header h1{font-size:1.25rem;order:1;width:100%}.back-btn{order:0;padding:var(--spacing-xs) var(--spacing-sm);font-size:.875rem}.lesson-progress{order:2;align-self:flex-start;font-size:.75rem;padding:var(--spacing-xs) var(--spacing-sm)}.lesson-content,.animation-phase,.questions-phase{gap:var(--spacing-lg)}.phase-actions{margin-top:var(--spacing-md)}.phase-actions .btn{width:100%;justify-content:center}.no-animation{padding:var(--spacing-xl)}.complete-phase,.complete-card{padding:var(--spacing-lg)}.complete-card h2{font-size:1.5rem}.complete-icon{padding:var(--spacing-md)}.complete-icon svg{width:48px;height:48px}.complete-stats{padding:var(--spacing-md);gap:var(--spacing-md)}.complete-stats .stat-value{font-size:1.5rem}.complete-stats .stat-label{font-size:.75rem}}@media(max-width:480px){.lesson-page{padding:0 var(--spacing-xs)}.lesson-header{gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.lesson-header h1{font-size:1.125rem}.back-btn{font-size:.75rem}.back-btn span{display:none}.complete-card{padding:var(--spacing-md);border-radius:var(--radius-lg)}.complete-card h2{font-size:1.25rem}.complete-stats .stat-value{font-size:1.35rem}.loading-container,.error-state{min-height:40vh;padding:var(--spacing-md)}}.assessment-page{max-width:800px;margin:0 auto}.assessment-header{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.assessment-header h1{font-size:1.5rem}.intro-phase{display:flex;justify-content:center;padding:var(--spacing-2xl)}.intro-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-2xl);text-align:center;max-width:500px}.intro-icon{color:var(--color-primary-400);margin-bottom:var(--spacing-lg)}.intro-card h2{margin-bottom:var(--spacing-md)}.intro-card>p{color:var(--text-muted);margin-bottom:var(--spacing-xl)}.intro-details{display:flex;justify-content:center;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--bg-glass);border-radius:var(--radius-lg)}.detail-item{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary)}.questions-phase{display:flex;flex-direction:column;gap:var(--spacing-xl)}.question-progress{display:flex;flex-direction:column;gap:var(--spacing-sm)}.progress-info{font-size:.875rem;color:var(--text-muted)}.progress-bar-container{height:6px;background:var(--bg-glass);border-radius:var(--radius-full);overflow:hidden}.progress-bar-container .progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary-500),var(--color-secondary-500));transition:width .3s ease}.assessment-question-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-xl)}.assessment-question-card .question-text{font-size:1.25rem;margin-bottom:var(--spacing-xl);line-height:1.5}.assessment-question-card .answers-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.assessment-question-card .answer-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-glass);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%;color:var(--text-primary)}.assessment-question-card .answer-option:hover{border-color:var(--color-primary-400)}.assessment-question-card .answer-option.selected{border-color:var(--color-primary-500);background:#8b5cf626}.assessment-question-card .answer-letter{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);background:var(--bg-tertiary);font-weight:700;font-size:.875rem;flex-shrink:0}.assessment-question-card .answer-option.selected .answer-letter{background:var(--color-primary-500);color:#fff}.question-navigation{display:flex;justify-content:space-between;gap:var(--spacing-md)}.question-dots{display:flex;justify-content:center;gap:var(--spacing-sm);flex-wrap:wrap}.question-dot{width:12px;height:12px;border-radius:var(--radius-full);background:var(--bg-glass);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast)}.question-dot:hover{background:var(--color-primary-400)}.question-dot.active{background:var(--color-primary-500);border-color:var(--color-primary-500);transform:scale(1.2)}.question-dot.answered{background:var(--color-success-500);border-color:var(--color-success-500)}.results-phase{display:flex;justify-content:center;padding:var(--spacing-2xl)}.results-card{background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-2xl);text-align:center;max-width:500px;width:100%}.results-card.passed{border-color:var(--color-success-500)}.results-card.failed{border-color:var(--color-error-500)}.results-icon{margin-bottom:var(--spacing-lg)}.results-card.passed .results-icon{color:var(--color-success-400)}.results-card.failed .results-icon{color:var(--color-error-400)}.results-card h2{margin-bottom:var(--spacing-sm)}.results-card>p{color:var(--text-muted);margin-bottom:var(--spacing-xl)}.results-score{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-xl)}.score-value{font-size:4rem;font-weight:800;line-height:1}.results-card.passed .score-value{color:var(--color-success-400)}.results-card.failed .score-value{color:var(--color-error-400)}.score-label{font-size:.875rem;color:var(--text-muted)}.results-stats{display:flex;justify-content:center;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--bg-glass);border-radius:var(--radius-lg)}.results-stats .stat-item{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary)}.results-actions{display:flex;justify-content:center}.leaderboard-page{max-width:800px;margin:0 auto}.page-header{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.header-icon{color:var(--color-points)}.page-header h1{margin-bottom:var(--spacing-xs)}.page-header p{color:var(--text-muted)}.leaderboard-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.leaderboard-item{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.leaderboard-item:hover{transform:translate(8px);border-color:var(--color-primary-400)}.leaderboard-item.top-1{background:linear-gradient(135deg,#ffd7001a,#ffd7000d);border-color:#ffd7004d}.leaderboard-item.top-2{background:linear-gradient(135deg,#c0c0c01a,#c0c0c00d);border-color:#c0c0c04d}.leaderboard-item.top-3{background:linear-gradient(135deg,#cd7f321a,#cd7f320d);border-color:#cd7f324d}.rank{width:40px;display:flex;justify-content:center}.rank-number{font-size:1.25rem;font-weight:700;color:var(--text-muted)}.rank .gold{color:gold}.rank .silver{color:silver}.rank .bronze{color:#cd7f32}.leaderboard-item .user-info{flex:1;display:flex;align-items:center;gap:var(--spacing-md)}.leaderboard-item .avatar{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-500);border-radius:var(--radius-full);font-weight:700;color:#fff}.leaderboard-item .username{font-weight:600;color:var(--text-primary)}.stats{display:flex;gap:var(--spacing-lg)}.stat{display:flex;align-items:center;gap:var(--spacing-xs);font-weight:600}.stat.points{color:var(--color-points)}.stat.streak{color:var(--color-streak)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--text-muted);text-align:center;gap:var(--spacing-md)}.textbook-questions-page{min-height:100vh;background:linear-gradient(135deg,#0f0f23,#1a1a3e,#0f0f23);padding:0 0 2rem;color:#fff}.textbook-header{background:linear-gradient(180deg,rgba(139,92,246,.2) 0%,transparent 100%);padding:1.5rem 2rem;border-bottom:1px solid rgba(139,92,246,.3);display:flex;align-items:center;gap:1.5rem}.back-btn{background:#8b5cf633;border:1px solid rgba(139,92,246,.5);color:#8b5cf6;padding:.75rem 1.25rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.back-btn:hover{background:#8b5cf666;transform:translate(-2px)}.header-content h1{font-size:2rem;margin:0;background:linear-gradient(135deg,#8b5cf6,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-content h2{font-size:1.2rem;margin:.5rem 0 0;color:#ffffffb3;font-weight:400}.exercises-container{max-width:1200px;margin:0 auto;padding:2rem}.exercise-section{margin-bottom:2.5rem}.exercise-title{font-size:1.5rem;color:#8b5cf6;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid rgba(139,92,246,.3)}.questions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.question-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.25rem;cursor:pointer;transition:all .3s ease}.question-card:hover{transform:translateY(-4px);background:#ffffff14;border-color:#8b5cf680;box-shadow:0 8px 25px #8b5cf633}.question-card.easy{border-left:4px solid #10b981}.question-card.medium{border-left:4px solid #f59e0b}.question-card.hard{border-left:4px solid #ef4444}.question-number{font-size:1.1rem;font-weight:700;color:#8b5cf6;margin-bottom:.5rem}.question-preview{font-size:.9rem;color:#fffc;line-height:1.5;min-height:4rem;white-space:pre-wrap}.question-meta{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.difficulty-badge{font-size:.75rem;padding:.25rem .75rem;border-radius:12px;font-weight:600;text-transform:capitalize}.difficulty-badge.easy{background:#10b98133;color:#10b981}.difficulty-badge.medium{background:#f59e0b33;color:#f59e0b}.difficulty-badge.hard{background:#ef444433;color:#ef4444}.question-type{font-size:.75rem;padding:.25rem .75rem;border-radius:12px;background:#06b6d433;color:#06b6d4;text-transform:capitalize}.question-modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.question-modal{background:linear-gradient(145deg,#1e1e3f,#0f0f23);border:1px solid rgba(139,92,246,.4);border-radius:16px;width:100%;max-width:700px;max-height:85vh;overflow-y:auto;padding:2rem;position:relative;box-shadow:0 25px 50px #00000080}.close-modal{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all .2s}.close-modal:hover{background:#ef44444d}.modal-header{margin-bottom:1.5rem}.modal-exercise{display:inline-block;background:#8b5cf633;color:#8b5cf6;padding:.25rem .75rem;border-radius:8px;font-size:.9rem;margin-bottom:.5rem}.modal-header h2{font-size:1.5rem;margin:.5rem 0 0;color:#fff}.modal-question{background:#ffffff0d;padding:1.5rem;border-radius:12px;margin-bottom:1.5rem;border-left:4px solid #8b5cf6}.modal-question p{font-size:1rem;line-height:1.7;margin:0;white-space:pre-wrap;color:#ffffffe6}.modal-solution h3{font-size:1.25rem;color:#10b981;margin-bottom:1rem}.solution-steps{display:flex;flex-direction:column;gap:1rem}.solution-step{display:flex;gap:1rem;background:#ffffff08;padding:1.25rem;border-radius:12px;border:1px solid rgba(16,185,129,.2)}.step-number{flex-shrink:0;width:32px;height:32px;background:linear-gradient(135deg,#10b981,#06b6d4);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff}.step-content h4{margin:0 0 .5rem;color:#10b981;font-size:1rem}.step-content p{margin:0;color:#fffc;line-height:1.6;white-space:pre-wrap}.no-solution{color:#ffffff80;font-style:italic;text-align:center;padding:2rem}.show-animation-btn{width:100%;background:linear-gradient(135deg,#10b981,#06b6d4);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.show-animation-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #10b98166}.solution-animation-container{background:#0006;border-radius:16px;padding:1rem;margin-bottom:1.5rem;border:1px solid rgba(16,185,129,.3);min-height:400px}.solution-animation-container .lottie-player{border-radius:12px;overflow:hidden}.solution-steps h4{font-size:1rem;color:#10b981;margin:0 0 1rem}.step-content h5{margin:0 0 .5rem;color:#10b981;font-size:.95rem}.step-explanation{margin:0 0 .75rem;color:#fffc;line-height:1.6;white-space:pre-wrap}.step-result{background:linear-gradient(135deg,#10b98126,#06b6d426);border:1px solid rgba(16,185,129,.4);border-radius:8px;padding:.75rem 1rem;color:#34d399;font-family:Courier New,monospace;white-space:pre-wrap;word-break:break-word}.step-result strong{color:#10b981;display:block;margin-bottom:.25rem}.textbook-loading,.textbook-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0f23,#1a1a3e);color:#fff}.loading-spinner{width:50px;height:50px;border:4px solid rgba(139,92,246,.2);border-top-color:#8b5cf6;border-radius:50%;animation:spin 1s linear infinite}.textbook-error h2{font-size:1.5rem;margin-bottom:.5rem}.textbook-error button{background:#8b5cf6;color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;cursor:pointer;font-weight:600;margin-top:1rem}@media(max-width:768px){.textbook-header{flex-direction:column;align-items:flex-start}.header-content h1{font-size:1.5rem}.exercises-container{padding:1rem}.questions-grid{grid-template-columns:1fr}.question-modal{padding:1.5rem}}.arivu-nanba-page{min-height:100vh;padding:0;position:relative;overflow:hidden;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.fun-bg-decorations{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.floating-emoji{position:absolute;font-size:2rem;opacity:.15;animation:floatAround 20s ease-in-out infinite}.emoji-1{top:10%;left:5%;animation-delay:0s}.emoji-2{top:20%;right:10%;animation-delay:3s}.emoji-3{top:60%;left:8%;animation-delay:5s}.emoji-4{bottom:20%;right:5%;animation-delay:8s}.emoji-5{top:40%;right:15%;animation-delay:12s}@keyframes floatAround{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-20px) rotate(5deg)}50%{transform:translateY(0) rotate(-3deg)}75%{transform:translateY(15px) rotate(3deg)}}.arivu-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.5rem;background:#0f0f1ae6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:2px solid rgba(139,92,246,.3);position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:.5rem}.header-right{display:flex;align-items:center;gap:.75rem}.menu-btn,.back-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;background:#8b5cf633;border:1px solid rgba(139,92,246,.3);border-radius:12px;color:#a78bfa;cursor:pointer;transition:all .3s ease}.menu-btn:hover,.back-btn:hover{background:#8b5cf64d;transform:translate(-2px)}.credits-badge{display:flex;align-items:center;gap:.4rem;padding:.5rem .85rem;background:linear-gradient(135deg,#f59e0b40,#fbbf2426);border:1px solid rgba(251,191,36,.4);border-radius:12px;color:#fbbf24;font-weight:600;font-size:.9rem;animation:creditsPulse 3s ease-in-out infinite}.credits-badge svg{color:#f59e0b}.credits-count{font-weight:700}@keyframes creditsPulse{0%,to{box-shadow:0 0 5px #fbbf2433}50%{box-shadow:0 0 15px #fbbf2466}}.chat-sidebar{position:fixed;top:0;left:-300px;width:280px;height:100vh;background:#0f0f1afa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid rgba(139,92,246,.3);z-index:200;display:flex;flex-direction:column;transition:left .3s ease}.chat-sidebar.open{left:0}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;border-bottom:1px solid rgba(139,92,246,.2)}.sidebar-header h3{color:#e5e7eb;font-size:1.1rem;margin:0}.close-sidebar-btn{display:flex;align-items:center;justify-content:center;padding:.4rem;background:#8b5cf633;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:#a78bfa;cursor:pointer;transition:all .2s ease}.close-sidebar-btn:hover{background:#ef44444d;border-color:#ef444466;color:#f87171}.new-chat-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:1rem;padding:.75rem 1rem;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:12px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease}.new-chat-btn:hover{transform:translateY(-2px);box-shadow:0 5px 20px #8b5cf666}.sessions-list{flex:1;overflow-y:auto;padding:.5rem}.sessions-loading,.no-sessions{text-align:center;color:#6b7280;padding:2rem 1rem;font-size:.9rem}.session-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;border-radius:10px;color:#9ca3af;cursor:pointer;transition:all .2s ease;position:relative}.session-item:hover{background:#8b5cf626;color:#e5e7eb}.session-item.active{background:#8b5cf640;color:#e5e7eb;border:1px solid rgba(139,92,246,.3)}.session-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.9rem}.delete-session-btn{display:flex;align-items:center;justify-content:center;padding:.35rem;background:transparent;border:none;border-radius:6px;color:#6b7280;cursor:pointer;opacity:0;transition:all .2s ease}.session-item:hover .delete-session-btn{opacity:1}.delete-session-btn:hover{background:#ef444433;color:#f87171}.sidebar-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:150;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.back-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;background:#8b5cf633;border:1px solid rgba(139,92,246,.3);border-radius:12px;color:#a78bfa;cursor:pointer;transition:all .3s ease}.back-btn:hover{background:#8b5cf64d;transform:translate(-2px)}.header-title{display:flex;align-items:center;gap:.75rem;flex:1}.title-icon{font-size:2.5rem;animation:bounce 2s ease-in-out infinite}.title-text h1{font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,#f59e0b,#fbbf24,#f59e0b);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:0}.title-text .subtitle{font-size:.75rem;color:#a78bfa;font-weight:500}.sparkle-icon{color:#fbbf24;animation:sparkle 1.5s ease-in-out infinite}@keyframes sparkle{0%,to{transform:scale(1) rotate(0);opacity:1}50%{transform:scale(1.2) rotate(10deg);opacity:.8}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.language-selector{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#6366f126;border:1px solid rgba(99,102,241,.3);border-radius:12px;color:#a5b4fc}.language-dropdown{background:transparent;border:none;color:#e5e7eb;font-size:.9rem;cursor:pointer;outline:none}.language-dropdown option{background:#1a1a2e;color:#e5e7eb}.chat-container.fun-chat{display:flex;flex-direction:column;height:calc(100vh - 80px);position:relative;z-index:1;max-width:900px;margin:0 auto;background:#0f0f1a80;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:24px 24px 0 0;margin-top:1rem;border:1px solid rgba(139,92,246,.2);border-bottom:none}.messages-container{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.welcome-state.fun-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.welcome-mascot{position:relative;margin-bottom:1.5rem}.mascot-emoji{font-size:5rem;animation:bounce 2s ease-in-out infinite}.mascot-sparkles{position:absolute;inset:0}.star{position:absolute;color:#fbbf24;animation:twinkle 1.5s ease-in-out infinite}.star-1{top:-10px;right:-5px;animation-delay:0s}.star-2{top:50%;right:-15px;animation-delay:.5s}.star-3{bottom:0;left:-10px;animation-delay:1s}@keyframes twinkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.fun-welcome h2{font-size:1.5rem;color:#f59e0b;margin-bottom:.5rem}.fun-welcome p{color:#9ca3af}.message.fun-message{display:flex;gap:1rem;animation:slideIn .4s ease-out}.message.user{flex-direction:row-reverse}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.message-avatar.fun-avatar{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:linear-gradient(135deg,#8b5cf6,#6366f1);box-shadow:0 4px 15px #8b5cf666;flex-shrink:0;animation:avatarPop .5s ease-out}.message-avatar.user-avatar{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 15px #10b98166;flex-shrink:0}@keyframes avatarPop{0%{transform:scale(0)}80%{transform:scale(1.1)}to{transform:scale(1)}}.message-bubble{max-width:75%;background:#1e1e32cc;border:1px solid rgba(139,92,246,.2);border-radius:20px;padding:1rem 1.25rem;position:relative}.message.user .message-bubble{background:linear-gradient(135deg,#10b98133,#05966926);border-color:#10b9814d}.message.assistant .message-bubble:before{content:"";position:absolute;top:15px;left:-8px;width:0;height:0;border:8px solid transparent;border-right-color:#8b5cf633}.message-content{color:#e5e7eb;line-height:1.7}.markdown-content p{margin:0 0 1rem}.markdown-content p:last-child{margin-bottom:0}.markdown-content strong{color:#f59e0b;font-weight:600}.markdown-content em{color:#a78bfa;font-style:italic}.markdown-content ul,.markdown-content ol{margin:.75rem 0;padding-left:1.5rem}.markdown-content li{margin:.5rem 0;position:relative}.markdown-content li::marker{color:#a78bfa}.markdown-content code{background:#8b5cf633;color:#fbbf24;padding:.2rem .5rem;border-radius:6px;font-family:Monaco,Menlo,monospace;font-size:.9em}.markdown-content pre{background:#0006;border:1px solid rgba(139,92,246,.2);border-radius:12px;padding:1rem;overflow-x:auto;margin:1rem 0}.markdown-content pre code{background:none;padding:0}.markdown-content h1,.markdown-content h2,.markdown-content h3{color:#f59e0b;margin:1rem 0 .5rem}.markdown-content blockquote{border-left:3px solid #8b5cf6;padding-left:1rem;margin:1rem 0;color:#9ca3af;font-style:italic}.message-sources{margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(139,92,246,.2)}.message-sources h4{font-size:.8rem;color:#a78bfa;margin:0 0 .5rem}.source-item{font-size:.75rem;color:#9ca3af;padding:.25rem 0}.suggestions-section{margin-top:1.5rem;padding:1.5rem;background:#8b5cf60d;border-radius:16px;border:1px dashed rgba(139,92,246,.3)}.suggestions-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:#fbbf24;font-weight:600}.suggested-questions.fun-suggestions{display:flex;flex-wrap:wrap;gap:.75rem}.suggestion-chip.fun-chip{padding:.75rem 1.25rem;background:linear-gradient(135deg,#8b5cf633,#6366f126);border:1px solid rgba(139,92,246,.3);border-radius:20px;color:#e5e7eb;font-size:.9rem;cursor:pointer;transition:all .3s ease;animation:popIn .4s ease-out backwards}.suggestion-chip.fun-chip:hover{background:linear-gradient(135deg,#8b5cf666,#6366f14d);transform:translateY(-3px) scale(1.02);box-shadow:0 5px 20px #8b5cf64d}@keyframes popIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.typing-indicator.fun-typing{display:flex;gap:1rem;align-items:flex-start}.typing-bubble{background:#1e1e32cc;border:1px solid rgba(139,92,246,.2);border-radius:20px;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.5rem}.typing-text{color:#9ca3af;font-size:.85rem}.typing-dots{display:flex;gap:.5rem}.typing-dots span{font-size:1.2rem;animation:thinkEmoji 1.5s ease-in-out infinite}.typing-dots span:nth-child(1){animation-delay:0s}.typing-dots span:nth-child(2){animation-delay:.3s}.typing-dots span:nth-child(3){animation-delay:.6s}@keyframes thinkEmoji{0%,to{transform:translateY(0) scale(1);opacity:.5}50%{transform:translateY(-8px) scale(1.2);opacity:1}}.input-container.fun-input{padding:1rem 1.5rem 1.5rem;background:#0f0f1af2;border-top:1px solid rgba(139,92,246,.2)}.input-wrapper{display:flex;gap:1rem;align-items:flex-end;background:#1e1e32cc;border:2px solid rgba(139,92,246,.3);border-radius:20px;padding:.5rem;transition:all .3s ease}.input-wrapper:focus-within{border-color:#8b5cf6;box-shadow:0 0 20px #8b5cf633}.input-wrapper textarea{flex:1;background:transparent;border:none;color:#e5e7eb;font-size:1rem;padding:.75rem 1rem;resize:none;outline:none;font-family:inherit;min-height:24px;max-height:150px}.input-wrapper textarea::placeholder{color:#6b7280}.send-button.fun-send{width:50px;height:50px;border-radius:16px;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;position:relative;overflow:hidden}.send-button.fun-send:hover:not(:disabled){transform:scale(1.05);box-shadow:0 5px 25px #8b5cf680}.send-button.fun-send:disabled{opacity:.5;cursor:not-allowed}.send-sparkle{position:absolute;top:5px;right:5px;font-size:.75rem;opacity:0;transition:opacity .3s ease}.send-button.fun-send:hover:not(:disabled) .send-sparkle{opacity:1}@media(max-width:768px){.arivu-nanba-page{padding-bottom:70px}.arivu-header{padding:.75rem 1rem;flex-wrap:wrap;gap:.5rem}.title-icon{font-size:2rem}.title-text h1{font-size:1.2rem}.title-text .subtitle,.sparkle-icon{display:none}.language-selector{padding:.4rem .6rem;font-size:.85rem}.chat-container.fun-chat{height:calc(100vh - 140px);margin-top:0;border-radius:0;border:none}.messages-container{padding:1rem}.message-avatar.fun-avatar,.message-avatar.user-avatar{width:40px;height:40px;font-size:1.2rem}.message-bubble{max-width:85%;padding:.75rem 1rem}.suggestions-section{padding:1rem}.suggested-questions.fun-suggestions{flex-direction:column}.suggestion-chip.fun-chip{text-align:center}.input-container.fun-input{padding:.75rem 1rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom,0))}.send-button.fun-send{width:45px;height:45px}.floating-emoji{font-size:1.5rem}}@media(max-width:375px){.title-text h1{font-size:1rem}.message-bubble{padding:.6rem .8rem}}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-track{background:#8b5cf60d}.messages-container::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:3px}.messages-container::-webkit-scrollbar-thumb:hover{background:#8b5cf680}.profile-page{min-height:100vh;padding:2rem 1rem;background:linear-gradient(135deg,#0f0f23,#1a1a3e,#0f0f23)}.profile-container{max-width:700px;margin:0 auto}.profile-header{text-align:center;margin-bottom:2rem;position:relative}.back-button{position:absolute;left:0;top:0;display:flex;align-items:center;gap:.5rem;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);color:#a78bfa;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.875rem;transition:all .3s ease}.back-button:hover{background:#8b5cf633;border-color:#8b5cf680}.profile-header h1{font-size:2rem;font-weight:700;color:#fff;margin-bottom:.5rem;background:linear-gradient(135deg,#a78bfa,#818cf8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.profile-header p{color:#94a3b8;font-size:1rem}.message{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:12px;margin-bottom:1.5rem;font-size:.9rem;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.message.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#4ade80}.message.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171}.message.info{background:#3b82f61a;border:1px solid rgba(59,130,246,.3);color:#60a5fa}.profile-form{background:#1e1e3c99;border:1px solid rgba(139,92,246,.2);border-radius:20px;padding:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.avatar-section{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding-bottom:2rem;border-bottom:1px solid rgba(139,92,246,.2);margin-bottom:2rem}.avatar-wrapper{position:relative;width:120px;height:120px}.avatar-display{width:120px;height:120px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,#4f46e5,#7c3aed);border:4px solid rgba(139,92,246,.5);box-shadow:0 0 30px #8b5cf64d}.avatar-image{width:100%;height:100%;object-fit:cover}.avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#ffffffb3}.avatar-overlay{position:absolute;bottom:0;right:0;width:36px;height:36px;background:linear-gradient(135deg,#7c3aed,#a78bfa);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;border:3px solid #1e1e3c;cursor:pointer;transition:transform .3s ease}.avatar-overlay:hover{transform:scale(1.1)}.avatar-input-group{width:100%;max-width:400px}.avatar-input-group label{display:block;color:#a78bfa;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.avatar-input-group input{width:100%;padding:.75rem 1rem;background:#0f0f23cc;border:1px solid rgba(139,92,246,.3);border-radius:10px;color:#fff;font-size:.9rem;transition:all .3s ease}.avatar-input-group input:focus{outline:none;border-color:#a78bfa;box-shadow:0 0 0 3px #8b5cf61a}.avatar-input-group small{display:block;color:#64748b;font-size:.75rem;margin-top:.5rem}.form-section{margin-bottom:2rem}.form-section h2{font-size:1.125rem;font-weight:600;color:#fff;margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}.form-section h2:before{content:"";width:4px;height:20px;background:linear-gradient(180deg,#7c3aed,#a78bfa);border-radius:2px}.section-description{color:#94a3b8;font-size:.875rem;margin-bottom:1rem}.form-group{margin-bottom:1.25rem}.form-group label{display:flex;align-items:center;gap:.5rem;color:#a78bfa;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-group input{width:100%;padding:.875rem 1rem;background:#0f0f23cc;border:1px solid rgba(139,92,246,.3);border-radius:12px;color:#fff;font-size:1rem;transition:all .3s ease}.form-group input:focus{outline:none;border-color:#a78bfa;box-shadow:0 0 0 3px #8b5cf61a}.form-group input::placeholder{color:#64748b}.password-section{padding:1.5rem;background:#0f0f2380;border-radius:12px;border:1px solid rgba(139,92,246,.1)}.password-reset-btn{width:100%;justify-content:center}.form-actions{display:flex;gap:1rem;padding-top:1.5rem;border-top:1px solid rgba(139,92,246,.2)}.form-actions .btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.btn-primary{background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff;box-shadow:0 4px 15px #7c3aed4d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #7c3aed66}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#8b5cf61a;color:#a78bfa;border:1px solid rgba(139,92,246,.3)}.btn-secondary:hover:not(:disabled){background:#8b5cf633;border-color:#8b5cf680}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.account-info{margin-top:2rem;background:#1e1e3c66;border:1px solid rgba(139,92,246,.15);border-radius:16px;padding:1.5rem}.account-info h3{font-size:1rem;font-weight:600;color:#a78bfa;margin-bottom:1rem}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:.9rem;color:#e2e8f0;font-weight:500}.info-value.status.active{color:#4ade80}.info-value.status.inactive{color:#f87171}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem;color:#a78bfa}.loading-spinner{width:40px;height:40px;border:3px solid rgba(139,92,246,.2);border-top-color:#a78bfa;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.profile-page{padding:1rem .75rem}.profile-header{padding-top:3rem}.back-button{position:relative;margin-bottom:1rem}.profile-header h1{font-size:1.5rem}.profile-form{padding:1.25rem;border-radius:16px}.avatar-section{gap:1rem}.avatar-wrapper,.avatar-display{width:100px;height:100px}.form-actions{flex-direction:column}.info-grid{grid-template-columns:1fr}}@media(max-width:480px){.profile-header h1{font-size:1.25rem}.profile-form{padding:1rem}.form-group input{padding:.75rem;font-size:.9rem}}:root{--color-primary-50: #f5f3ff;--color-primary-100: #ede9fe;--color-primary-200: #ddd6fe;--color-primary-300: #c4b5fd;--color-primary-400: #a78bfa;--color-primary-500: #8b5cf6;--color-primary-600: #7c3aed;--color-primary-700: #6d28d9;--color-primary-800: #5b21b6;--color-primary-900: #4c1d95;--color-secondary-400: #22d3ee;--color-secondary-500: #06b6d4;--color-secondary-600: #0891b2;--color-success-400: #4ade80;--color-success-500: #22c55e;--color-success-600: #16a34a;--color-warning-400: #fbbf24;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-error-400: #f87171;--color-error-500: #ef4444;--color-error-600: #dc2626;--color-hearts: #ec4899;--color-points: #eab308;--color-streak: #f97316;--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-tertiary: #252542;--bg-card: rgba(30, 30, 50, .8);--bg-glass: rgba(255, 255, 255, .05);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--text-muted: rgba(255, 255, 255, .5);--border-color: rgba(255, 255, 255, .1);--border-focus: var(--color-primary-500);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(139, 92, 246, .3);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--font-sans: "Inter", system-ui, -apple-system, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 20%,rgba(139,92,246,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(6,182,212,.1) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(236,72,153,.05) 0%,transparent 50%);pointer-events:none;z-index:-1}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-primary-600);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-500)}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:var(--text-primary)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}p{color:var(--text-secondary)}a{color:var(--color-primary-400);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-300)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);outline:none}.btn-primary{background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-700));color:#fff;box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 30px #8b5cf666}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-glass);color:var(--text-primary);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-secondary:hover{background:#ffffff1a;border-color:var(--color-primary-400)}.btn-success{background:linear-gradient(135deg,var(--color-success-500),var(--color-success-600));color:#fff}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:1.125rem}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:.875rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:all var(--transition-base)}.card:hover{border-color:var(--color-primary-500);box-shadow:var(--shadow-lg),var(--shadow-glow);transform:translateY(-4px)}.card-glass{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.input{width:100%;padding:var(--spacing-md);background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #8b5cf633}.input::placeholder{color:var(--text-muted)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--text-secondary)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.grid{display:grid;gap:var(--spacing-lg)}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media(max-width:1024px){.grid-cols-4,.grid-cols-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.grid-cols-4,.grid-cols-3,.grid-cols-2{grid-template-columns:1fr}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem;font-weight:600;border-radius:var(--radius-full);background:var(--bg-glass);border:1px solid var(--border-color)}.badge-points{background:linear-gradient(135deg,#eab30833,#eab3081a);border-color:var(--color-points);color:var(--color-points)}.badge-hearts{background:linear-gradient(135deg,#ec489933,#ec48991a);border-color:var(--color-hearts);color:var(--color-hearts)}.badge-streak{background:linear-gradient(135deg,#f9731633,#f973161a);border-color:var(--color-streak);color:var(--color-streak)}.progress{width:100%;height:8px;background:var(--bg-glass);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary-500),var(--color-secondary-500));border-radius:var(--radius-full);transition:width var(--transition-slow)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn .5s ease-out}.animate-pulse{animation:pulse 2s infinite}.animate-bounce{animation:bounce 1s infinite}.text-center{text-align:center}.text-gradient{background:linear-gradient(135deg,var(--color-primary-400),var(--color-secondary-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}
