body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.animate-on-scroll{opacity:0;transition:all .8s cubic-bezier(.16,1,.3,1)}.fade-up{transform:translateY(60px)}.fade-left{transform:translateX(-60px)}.fade-right{transform:translateX(60px)}.animate-on-scroll.animate-in{opacity:1;transform:translateY(0) translateX(0)}.landing-page{background:#f4f1eb;color:#18192b;font-family:Plus Jakarta Sans,sans-serif;min-height:100vh;overflow-x:hidden;position:relative;transition:background-color .3s ease,color .3s ease}.landing-page.dark{background:#0d0f18;color:#e0e4f8}.landing-page:before{background:radial-gradient(circle at 20% 30%,#5b8dee1f 0,#0000 50%),radial-gradient(circle at 80% 70%,#7c85ff1a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;transition:background .3s ease;z-index:0}.landing-page.dark:before{background:radial-gradient(circle at 20% 30%,#7c85ff14 0,#0000 50%),radial-gradient(circle at 80% 70%,#5b8dee0f 0,#0000 50%)}.landing-page{--landing-bg:#f4f1eb;--landing-bg2:#fff;--landing-bg3:#edeae3;--landing-bg4:#e5e1d8;--landing-border:#ddd9d1;--landing-border2:#c4bfb5;--landing-text:#18192b;--landing-text2:#52556e;--landing-text3:#8f93a8;--landing-text4:#c2c5d4;--landing-accent:#5b8dee;--landing-accent2:#4a7dd9;--landing-card:#fff;--landing-card2:#f9f7f3;--landing-radius:16px;--landing-space:24px}.landing-page.dark{--landing-bg:#0d0f18;--landing-bg2:#13151f;--landing-bg3:#181b27;--landing-bg4:#1e2130;--landing-border:#232638;--landing-border2:#2e3248;--landing-text:#e0e4f8;--landing-text2:#8a90b8;--landing-text3:#525875;--landing-text4:#303550;--landing-accent:#7c85ff;--landing-accent2:#9199ff;--landing-card:#13151f;--landing-card2:#171a26}.landing-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#f4f1ebe6;border-bottom:1px solid #ddd9d180;position:-webkit-sticky;position:sticky;top:0;transition:all .3s ease;z-index:100}.landing-page.dark .landing-nav{background:#0d0f18e6;border-bottom:1px solid #23263880}.nav-container{justify-content:space-between;margin:0 auto;max-width:1200px;padding:1.25rem 2rem}.nav-container,.nav-logo{align-items:center;display:flex}.nav-logo{gap:.875rem;transition:transform .2s ease}.nav-logo:hover{transform:scale(1.02)}.nav-logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--landing-text),var(--landing-accent));-webkit-background-clip:text;background-clip:text;color:var(--landing-text);display:inline-block;font-family:Plus Jakarta Sans,sans-serif;font-size:1.375rem;font-weight:800;letter-spacing:-.025em;padding:0 .05em}.nav-desktop{align-items:center;display:flex;gap:1.25rem}.nav-auth-buttons{display:flex;gap:.875rem}.dm-toggle{background:var(--landing-bg3);border:2px solid var(--landing-border2);border-radius:15px;box-shadow:inset 0 2px 4px #0000001a;cursor:pointer;height:30px;padding:0;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1);width:52px}.dm-toggle:hover{box-shadow:inset 0 2px 4px #00000026,0 4px 12px #5b8dee33;transform:scale(1.05)}.dm-knob{align-items:center;background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:50%;box-shadow:0 2px 8px #00000026;display:flex;font-size:.75rem;height:24px;justify-content:center;left:2px;line-height:1;position:absolute;top:2px;transition:all .3s cubic-bezier(.16,1,.3,1);width:24px}.dm-knob.dark{background:linear-gradient(135deg,#1a1a2e,#16213e);color:gold;transform:translateX(22px)}.mobile-menu-btn{background:none;border:none;border-radius:12px;cursor:pointer;display:none;padding:.75rem;transition:all .2s ease}.mobile-menu-btn:hover{background:var(--landing-bg3)}.hamburger{display:flex;flex-direction:column;height:20px;position:relative;width:26px}.hamburger span{background:var(--landing-text);border-radius:2px;display:block;height:3px;transform-origin:center;transition:all .3s cubic-bezier(.16,1,.3,1);width:100%}.hamburger span:first-child,.hamburger span:nth-child(2){margin-bottom:5px}.hamburger.open span:first-child{transform:rotate(45deg) translate(7px,7px)}.hamburger.open span:nth-child(2){opacity:0;transform:scale(0)}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}.mobile-menu{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--landing-card);border-bottom:2px solid var(--landing-border);box-shadow:0 8px 32px #18192b1a;left:0;opacity:0;position:absolute;right:0;top:100%;transform:translateY(-100%);transition:all .4s cubic-bezier(.16,1,.3,1);visibility:hidden}.dark .mobile-menu{box-shadow:0 8px 32px #0000004d}.mobile-menu.open{opacity:1;transform:translateY(0);visibility:visible}.mobile-menu-content{display:flex;flex-direction:column;gap:1.25rem;padding:2rem}.dm-toggle.mobile{background:var(--landing-bg3);border:2px solid var(--landing-border);border-radius:12px;color:var(--landing-text);font-family:Plus Jakarta Sans,sans-serif;font-weight:600;height:auto;padding:1rem 1.25rem;text-align:left;transition:all .3s ease;width:auto}.dm-toggle.mobile:hover{background:var(--landing-bg4);transform:translateY(-1px)}.btn-primary{align-items:center;background:linear-gradient(135deg,var(--landing-accent),var(--landing-accent2));border-radius:10px;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;gap:.5rem;padding:1rem 2rem;text-decoration:none;transition:all .2s ease}.btn-primary:hover{box-shadow:0 4px 12px #5b8dee4d;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#0000;border:2px solid var(--landing-accent);border-radius:10px;color:var(--landing-accent);font-family:Plus Jakarta Sans,sans-serif;padding:.875rem 1.75rem;text-decoration:none;transition:all .2s ease}.btn-secondary:hover{background:var(--landing-accent);color:#fff;transform:translateY(-2px)}.btn-primary.mobile,.btn-secondary.mobile{justify-content:center;width:100%}.hero-section{align-items:center;display:flex;justify-content:center;overflow:hidden;padding:6rem 2rem 4rem;position:relative}.hero-container{margin:0 auto;max-width:1200px;position:relative;z-index:2}.hero-content-centered{margin:0 auto;max-width:700px;text-align:center}.hero-title{color:var(--landing-text);font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(2.5rem,6vw,4rem);font-weight:800;letter-spacing:-.02em;line-height:1.2;margin-bottom:1.25rem}.hero-subtitle{color:var(--landing-text2);font-size:clamp(1rem,2.5vw,1.25rem);font-weight:500;line-height:1.5;margin-bottom:2rem}.hero-cta-container{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.hero-cta{font-size:1rem;padding:1rem 2rem}.hero-cta-secondary{font-size:1rem;padding:.875rem 1.75rem}.features-section{background:var(--landing-bg2);padding:4rem 2rem;position:relative}.features-container{margin:0 auto;max-width:1200px;position:relative;z-index:1}.features-header{margin-bottom:3rem;text-align:center}.features-title{color:var(--landing-text);font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(1.75rem,3vw,2.5rem);font-weight:700;letter-spacing:-.02em;margin-bottom:0}.features-subtitle{color:var(--landing-text2);font-size:1.125rem;font-weight:500;line-height:1.6;margin:0 auto;max-width:650px}.features-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:3rem}.feature-card:first-child{transition-delay:.1s}.feature-card:nth-child(2){transition-delay:.2s}.feature-card:nth-child(3){transition-delay:.3s}.feature-card:nth-child(4){transition-delay:.4s}.feature-card{background:var(--landing-card);border:1.5px solid var(--landing-border);border-radius:12px;overflow:hidden;padding:1.75rem;position:relative;transition:all .2s ease}.feature-card:hover{border-color:var(--landing-accent);box-shadow:0 8px 24px #18192b1a;transform:translateY(-4px)}.dark .feature-card:hover{box-shadow:0 8px 24px #0003}.feature-card.highlight{border-color:var(--landing-accent)}.feature-content h3{color:var(--landing-text);font-size:1.125rem;font-weight:700;line-height:1.3;margin-bottom:.75rem}.feature-description{font-size:.95rem;line-height:1.6}.trust-indicators{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center}.trust-item{align-items:center;background:var(--landing-card);border:1.5px solid var(--landing-border);border-radius:8px;display:flex;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s ease}.trust-item:hover{border-color:var(--landing-accent);transform:translateY(-2px)}.trust-text{color:var(--landing-text);font-size:.875rem;font-weight:600}.landing-footer{background:var(--landing-bg3);border-top:1.5px solid var(--landing-border);padding:3rem 2rem 2rem;position:relative}.footer-container{margin:0 auto;max-width:1200px;position:relative;z-index:1}.footer-content{gap:2rem;margin-bottom:2rem;text-align:center}.footer-brand,.footer-content{align-items:center;display:flex;flex-direction:column}.footer-brand{gap:1rem}.footer-logo{align-items:center;display:flex;gap:.75rem}.footer-logo-text{color:var(--landing-text);font-family:Plus Jakarta Sans,sans-serif;font-size:1.125rem;font-weight:700}.footer-tagline{color:var(--landing-text2);font-size:.9rem;font-weight:500;line-height:1.5}.footer-links{align-items:center;display:flex;flex-direction:column;gap:1rem}.footer-section-title{color:var(--landing-text);font-size:.85rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.footer-link-list{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;gap:2rem;justify-content:center;list-style:none;width:100%}.footer-link-list,.footer-link-list li{margin:0;padding:0}.footer-link{background:none;border:none;color:var(--landing-text2);cursor:pointer;display:inline-block;font-family:inherit;font-size:.9rem;font-weight:500;padding:0;text-decoration:none;transition:color .2s ease}.footer-link:hover{color:var(--landing-accent)}.footer-bottom{align-items:center;border-top:1px solid var(--landing-border);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding-top:2rem}.footer-copyright p,.footer-made{color:var(--landing-text3);font-size:.875rem;font-weight:500}html{scroll-behavior:smooth}.landing-page::-webkit-scrollbar{width:8px}.landing-page::-webkit-scrollbar-track{background:var(--bg3);border-radius:10px}.landing-page::-webkit-scrollbar-thumb{background:linear-gradient(135deg,var(--accent),var(--accent2));border:2px solid var(--bg3);border-radius:10px}.landing-page::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,var(--accent2),var(--accent))}@media (max-width:768px){.nav-desktop{display:none}.mobile-menu-btn{display:block}.hero-content{gap:4rem;grid-template-columns:1fr;text-align:center}.hero-section{padding:5rem 1.5rem 4rem}.hero-title{font-size:clamp(2.25rem,8vw,3.5rem)}.hero-subtitle{font-size:clamp(1rem,4vw,1.25rem)}.hero-mockup{max-width:350px;transform:none}.hero-mockup:hover{transform:scale(1.02)}.features-section{padding:6rem 1.5rem}.features-grid{gap:2rem;grid-template-columns:1fr}.features-title{font-size:clamp(2rem,6vw,2.75rem)}.trust-indicators{align-items:center;flex-direction:column;gap:2rem}.trust-item{justify-content:center;max-width:280px;padding:1rem 1.5rem;width:100%}.footer-content{gap:2rem}.footer-link-list{gap:1.5rem}.footer-bottom{flex-direction:column;gap:1rem;text-align:center}.bg-circle{height:250px;right:-20%;width:250px}.bg-circle-2{height:200px;left:-15%;width:200px}.bg-circle-3{height:150px;width:150px}}@media (max-width:480px){.nav-container{padding:1rem 1.5rem}.hero-section{padding:4rem 1rem 3rem}.hero-content{gap:3rem}.hero-cta{font-size:1rem;padding:1.25rem 2rem}.features-section{padding:5rem 1rem}.feature-card{padding:2rem 1.5rem}.trust-indicators{align-items:center;flex-direction:column}.trust-item{max-width:260px;width:100%}.mockup-content{padding:1.5rem}.mockup-assignment{gap:1rem;padding:1rem}}.detailed-features-section{background:var(--landing-bg);padding:8rem 2rem}.detailed-features-container{margin:0 auto;max-width:1200px}.detailed-feature{grid-gap:6rem;align-items:center;display:grid;gap:6rem;grid-template-columns:1fr 1fr;margin-bottom:10rem;padding:4rem 0}.detailed-feature.reverse{direction:rtl}.detailed-feature.reverse>*{direction:ltr}.feature-content{max-width:500px}.feature-title{color:var(--landing-text);font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(2rem,4vw,2.75rem);font-weight:800;letter-spacing:-.02em;line-height:1.2;margin-bottom:1.5rem}.feature-description{color:var(--landing-text2);font-size:1.125rem;font-weight:500;line-height:1.7;margin-bottom:2rem}.feature-list{list-style:none;margin:0;padding:0}.feature-list-item{align-items:center;color:var(--landing-text2);display:flex;font-size:1rem;font-weight:500;gap:1rem;margin-bottom:1rem}.feature-check{background:linear-gradient(135deg,var(--landing-accent),var(--landing-accent2));border-radius:50%;color:#fff;flex-shrink:0;font-size:.75rem;font-weight:700;height:24px;width:24px}.feature-check,.feature-visual{align-items:center;display:flex;justify-content:center}.feature-mockup{max-width:450px;perspective:1000px;width:100%}.feature-mockup .mockup-window{background:var(--landing-card);border:2px solid var(--landing-border);border-radius:20px;box-shadow:0 20px 60px #18192b26,0 0 0 1px #ffffff0d;overflow:hidden;transition:transform .3s ease}.dark .feature-mockup .mockup-window{box-shadow:0 20px 60px #0000004d,0 0 0 1px #ffffff1a}.feature-mockup:hover .mockup-window{transform:translateY(-8px)}.feature-mockup .mockup-header{align-items:center;background:linear-gradient(135deg,var(--landing-bg3),var(--landing-bg4));border-bottom:1px solid var(--landing-border);display:flex;gap:1rem;padding:1rem 1.25rem}.feature-mockup .mockup-title-bar{color:var(--landing-text2);font-size:.9rem;font-weight:600}.feature-mockup .mockup-content{padding:1.5rem}.assignment-list{display:flex;flex-direction:column;gap:1rem}.assignment-item{align-items:center;background:var(--landing-bg3);border:1px solid var(--landing-border);border-radius:12px;display:flex;gap:1rem;padding:1rem;transition:all .2s ease}.assignment-item:hover{box-shadow:0 4px 12px #18192b1a;transform:translateY(-2px)}.dark .assignment-item:hover{box-shadow:0 4px 12px #0003}.assignment-stripe{border-radius:2px;height:40px}.assignment-stripe.red{background:linear-gradient(135deg,#ef4444,#dc2626)}.assignment-stripe.orange{background:linear-gradient(135deg,#f97316,#ea580c)}.assignment-stripe.green{background:linear-gradient(135deg,#22c55e,#16a34a)}.assignment-content h4{color:var(--landing-text);font-size:.9rem;font-weight:700;margin-bottom:.25rem}.assignment-content p{color:var(--landing-text3);font-size:.8rem;margin-bottom:.5rem}.assignment-tags{display:flex;gap:.5rem}.tag{border-radius:12px;font-size:.7rem;font-weight:600;padding:.25rem .5rem}.tag.urgent{background:#fef2f2;color:#dc2626}.dark .tag.urgent{background:#dc262633;color:#fca5a5}.tag.medium{background:#fff7ed;color:#ea580c}.dark .tag.medium{background:#ea580c33;color:#fdba74}.tag.completed{background:#f0fdf4;color:#16a34a}.dark .tag.completed{background:#16a34a33;color:#86efac}.tag.history,.tag.math,.tag.science{background:var(--landing-bg4);color:var(--landing-text3)}.assignment-progress,.progress-circle{align-items:center;display:flex;justify-content:center}.progress-circle{background:var(--landing-bg4);border-radius:50%;color:var(--landing-text3);font-size:.75rem;font-weight:700;height:40px;width:40px}.progress-circle.partial{background:linear-gradient(135deg,var(--landing-accent) 65%,var(--landing-bg4) 65%);color:#fff}.check-mark{align-items:center;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;color:#fff;display:flex;font-size:1.25rem;font-weight:700;height:40px;justify-content:center;width:40px}.sync-status{margin-bottom:1.5rem}.sync-indicator{align-items:center;background:var(--landing-bg3);border:1px solid var(--landing-border);border-radius:12px;display:flex;gap:.75rem;padding:.75rem 1rem}.sync-indicator.active{background:linear-gradient(135deg,#5b8dee1a,#7c85ff0d);border-color:var(--landing-accent)}.sync-icon{animation:spin 2s linear infinite;font-size:1.25rem}.imported-assignments h4{color:var(--landing-text);font-size:.9rem;font-weight:700;margin-bottom:1rem}.import-item{align-items:center;background:var(--landing-bg4);border-radius:8px;display:flex;gap:1rem;margin-bottom:.5rem;padding:.75rem}.import-icon{font-size:1.25rem}.import-details{flex:1 1}.import-details span{color:var(--landing-text);display:block;font-size:.85rem;font-weight:600}.import-details small{color:var(--landing-text3);font-size:.75rem}.import-status{color:#16a34a;font-size:1.25rem;font-weight:700}.analytics-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin-bottom:1.5rem}.stat-card{background:var(--landing-bg3);border:1px solid var(--landing-border);border-radius:12px;padding:1rem;text-align:center}.stat-number{color:var(--landing-accent);font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.stat-label{color:var(--landing-text3);margin-bottom:.5rem}.stat-label,.stat-trend{font-size:.7rem;font-weight:600}.stat-trend.up{color:#16a34a}.chart-area{background:var(--landing-bg3);border:1px solid var(--landing-border);border-radius:12px;padding:1rem}.chart-title{color:var(--landing-text);font-size:.85rem;font-weight:600;margin-bottom:1rem}.mini-chart{height:60px}.chart-bars,.mini-chart{align-items:end;display:flex}.chart-bars{gap:.5rem;height:100%;width:100%}.bar{background:linear-gradient(135deg,var(--landing-accent),var(--landing-accent2));border-radius:2px;flex:1 1;min-height:20%}.timer-display{margin-bottom:2rem;text-align:center}.timer-circle{align-items:center;background:var(--landing-bg3);border:4px solid var(--landing-border);border-radius:50%;display:flex;height:120px;justify-content:center;margin:0 auto 1rem;position:relative;width:120px}.timer-progress{background:conic-gradient(var(--landing-accent) 75%,#0000 75%);border-radius:50%;bottom:-4px;left:-4px;position:absolute;right:-4px;top:-4px}.timer-time{color:var(--landing-text);font-size:1.5rem;font-weight:700;z-index:1}.separator{opacity:.5}.timer-label{color:var(--landing-text2);font-size:.9rem;font-weight:600;margin-bottom:1rem}.timer-controls{display:flex;gap:.75rem;justify-content:center}.timer-btn{background:var(--landing-bg3);border:1px solid var(--landing-border);border-radius:8px;color:var(--landing-text);cursor:pointer;font-size:.8rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease}.timer-btn:hover{background:var(--landing-bg4)}.timer-btn.start{background:var(--landing-accent);border-color:var(--landing-accent);color:#fff}.session-stats{display:flex;flex-direction:column;gap:.75rem}.session-item{align-items:center;background:var(--landing-bg3);border-radius:8px;color:var(--landing-text2);display:flex;font-size:.85rem;font-weight:500;gap:.75rem;padding:.75rem}.session-icon{font-size:1.25rem}.learn-more-main{position:relative;z-index:1}.learn-more-hero{background:radial-gradient(ellipse at top,#5b8dee1a 0,#0000 50%),radial-gradient(ellipse at bottom,#f5a62314 0,#0000 50%);padding:8rem 2rem 6rem;text-align:center}.learn-more-container{margin:0 auto;max-width:1200px}.learn-more-header{margin:0 auto;max-width:800px}.learn-more-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--landing-text) 0,var(--landing-accent) 100%);-webkit-background-clip:text;background-clip:text;color:var(--landing-text);font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(2.5rem,5vw,4rem);font-weight:800;letter-spacing:-.02em;margin-bottom:1.5rem}.learn-more-subtitle{color:var(--landing-text2);font-size:clamp(1.125rem,2.5vw,1.375rem);font-weight:500;line-height:1.6}.problem-section{background:var(--landing-bg2);padding:6rem 2rem}.problem-content h2{color:var(--landing-text);font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:800;margin-bottom:3rem;text-align:center}.problem-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:900px}.problem-item{background:var(--landing-card);border:2px solid var(--landing-border);border-radius:20px;padding:2rem;text-align:center;transition:all .3s ease}.problem-item:hover{border-color:var(--landing-accent);box-shadow:0 20px 40px #18192b1a;transform:translateY(-8px)}.dark .problem-item:hover{box-shadow:0 20px 40px #0003}.problem-icon{display:block;font-size:3rem;margin-bottom:1rem}.problem-item h3{color:var(--landing-text);font-size:1.25rem;font-weight:700;margin-bottom:1rem}.problem-item p{color:var(--landing-text2);font-weight:500;line-height:1.6}.solution-section{background:var(--landing-bg);padding:6rem 2rem}.solution-content h2{color:var(--landing-text);font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:800;margin-bottom:3rem;text-align:center}.solution-features{margin:0 auto;max-width:800px}.solution-feature{align-items:flex-start;display:flex;gap:2rem;margin-bottom:3rem}.solution-number{align-items:center;background:linear-gradient(135deg,var(--landing-accent),var(--landing-accent2));border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.25rem;font-weight:700;height:60px;justify-content:center;width:60px}.solution-details h3{color:var(--landing-text);font-size:1.375rem;font-weight:700;margin-bottom:.75rem}.solution-details p{color:var(--landing-text2);font-size:1.05rem;font-weight:500;line-height:1.7}.benefits-section{background:var(--landing-bg2);padding:6rem 2rem}.benefits-content h2{color:var(--landing-text);font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:800;margin-bottom:3rem;text-align:center}.benefits-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.benefit-card{background:var(--landing-card);border:2px solid var(--landing-border);border-radius:20px;padding:2.5rem 2rem;text-align:center;transition:all .3s ease}.benefit-card:hover{border-color:var(--landing-accent);box-shadow:0 20px 40px #18192b1a;transform:translateY(-8px)}.dark .benefit-card:hover{box-shadow:0 20px 40px #0003}.benefit-stat{color:var(--landing-accent);font-family:Plus Jakarta Sans,sans-serif;font-size:3rem;font-weight:800;margin-bottom:.5rem}.benefit-label{color:var(--landing-text);font-size:1.125rem;font-weight:700;margin-bottom:1rem}.benefit-card p{color:var(--landing-text2);font-weight:500;line-height:1.6}.how-it-works-section{background:var(--landing-bg);padding:6rem 2rem}.how-it-works-content h2{color:var(--landing-text);font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:800;margin-bottom:3rem;text-align:center}.steps-container{align-items:center;display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin:0 auto;max-width:1000px}.step{flex:1 1;min-width:250px;text-align:center}.step-number{align-items:center;background:linear-gradient(135deg,var(--landing-accent),var(--landing-accent2));border-radius:50%;color:#fff;display:flex;font-size:1.5rem;font-weight:700;height:60px;justify-content:center;margin:0 auto 1.5rem;width:60px}.step-content h3{color:var(--landing-text);font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.step-content p{color:var(--landing-text2);font-weight:500;line-height:1.6}.step-arrow{color:var(--landing-accent);font-size:2rem;font-weight:700}.cta-section{background:linear-gradient(135deg,var(--landing-bg2) 0,var(--landing-bg) 100%),radial-gradient(ellipse at center,#5b8dee0d 0,#0000 70%);padding:6rem 2rem;text-align:center}.cta-content h2{color:var(--landing-text);font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:800;margin-bottom:1rem}.cta-content>p{color:var(--landing-text2);font-size:1.25rem;font-weight:500;margin-bottom:2.5rem}.cta-buttons{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;margin-bottom:1.5rem}.btn-primary.large,.btn-secondary.large{font-size:1.125rem;padding:1.375rem 2.75rem}.cta-note{color:var(--landing-text3);font-size:.95rem;font-weight:500}.back-btn{margin-right:1rem}@media (max-width:768px){.detailed-feature{gap:3rem;grid-template-columns:1fr;margin-bottom:6rem;text-align:center}.detailed-feature.reverse{direction:ltr}.feature-content{max-width:none}.feature-mockup{max-width:350px}.hero-cta-container{flex-direction:column;gap:1rem}.hero-cta,.hero-cta-secondary{max-width:300px;width:100%}.benefits-grid,.problem-grid{grid-template-columns:1fr}.solution-feature{flex-direction:column;gap:1.5rem;text-align:center}.steps-container{flex-direction:column;gap:3rem}.step-arrow{transform:rotate(90deg)}.cta-buttons{flex-direction:column;gap:1rem}.btn-primary.large,.btn-secondary.large{max-width:300px;width:100%}.analytics-grid{grid-template-columns:1fr}}@media (max-width:480px){.detailed-feature{margin-bottom:4rem;padding:2rem 0}.feature-mockup{max-width:300px}.feature-mockup .mockup-content{padding:1rem}.assignment-item{gap:.75rem;padding:.75rem}.timer-circle{height:100px;width:100px}.timer-time{font-size:1.25rem}}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.releases-list-container{display:flex;flex-direction:column;gap:2rem;margin:0 auto;max-width:1000px}.release-note-card{background:var(--landing-card);border:2px solid var(--landing-border);border-radius:24px;overflow:hidden;padding:2.5rem 3rem;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1)}.release-note-card:before{background:linear-gradient(135deg,#ffffff0d,#0000 50%);bottom:0;content:"";left:0;opacity:0;pointer-events:none;position:absolute;right:0;top:0;transition:opacity .3s ease}.release-note-card:hover{border-color:var(--landing-accent);box-shadow:0 12px 40px #18192b1f;transform:translateY(-4px)}.dark .release-note-card:hover{box-shadow:0 12px 40px #0000004d}.release-note-card:hover:before{opacity:1}.release-note-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.release-note-version-info{align-items:center;display:flex;gap:.75rem}.release-note-version-badge{background:linear-gradient(135deg,var(--landing-accent),var(--landing-accent2));border-radius:20px;box-shadow:0 4px 12px #5b8dee4d;color:#fff;font-size:.85rem;font-weight:700;letter-spacing:.02em;padding:.5rem 1.25rem}.release-note-latest-badge{background:var(--landing-bg3);border:2px solid var(--landing-accent);border-radius:16px;color:var(--landing-accent);font-size:.75rem;font-weight:700;padding:.375rem 1rem}.release-note-date{color:var(--landing-text3);font-size:.9rem;font-weight:600}.release-note-title{color:var(--landing-text);font-family:Plus Jakarta Sans,sans-serif;font-size:1.75rem;font-weight:800;letter-spacing:-.02em;line-height:1.3;margin:0 0 1.75rem}.release-note-changes{display:flex;flex-direction:column;gap:1rem;list-style:none;margin:0;padding:0}.release-note-change{align-items:flex-start;color:var(--landing-text2);display:flex;font-size:1rem;font-weight:500;gap:1rem;line-height:1.7;padding-left:2rem;position:relative}.release-note-change:before{background:var(--landing-accent);border-radius:50%;box-shadow:0 0 0 4px #5b8dee26;content:"";height:10px;left:0;position:absolute;top:.65rem;width:10px}@media (max-width:768px){.release-note-card{border-radius:20px;padding:2rem 1.5rem}.release-note-title{font-size:1.35rem}.release-note-change{font-size:.95rem;padding-left:1.75rem}.release-note-header{align-items:flex-start;flex-direction:column;gap:.75rem}}@media (max-width:480px){.release-note-card{padding:1.5rem 1.25rem}.release-note-title{font-size:1.2rem}.release-note-version-badge{font-size:.8rem;padding:.4rem 1rem}.release-note-change{font-size:.9rem;padding-left:1.5rem}}.mobile-container{background:var(--bg);display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.mobile-content{-webkit-overflow-scrolling:touch;flex:1 1;overflow-x:hidden;overflow-y:auto;padding-bottom:80px}.mobile-header-new{background:var(--bg);background:rgba(var(--bg-rgb),.95);padding:max(env(safe-area-inset-top),12px) 16px 12px}.mobile-header-top{justify-content:space-between}.mobile-header-top,.mobile-header-user{align-items:center;display:flex;gap:12px}.mobile-header-user{flex:1 1;min-width:0}.mobile-header-avatar{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.1rem;font-weight:700;height:44px;justify-content:center;width:44px}.mobile-header-info{flex:1 1;min-width:0}.mobile-header-greeting{color:var(--text3);font-size:.75rem;font-weight:500}.mobile-header-name{color:var(--text);font-size:1.1rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-header-streak{border-radius:20px;font-size:.85rem;font-weight:700;padding:6px 12px}.mobile-header-btn{-webkit-tap-highlight-color:transparent;align-items:center;background:var(--card);border:none;border-radius:12px;cursor:pointer;display:flex;font-size:1.1rem;height:40px;justify-content:center;transition:all .2s;width:40px}.mobile-header-btn:active{background:var(--bg3);transform:scale(.95)}.mobile-nav-bottom{background:var(--card);border-top:1px solid var(--border);bottom:0;box-shadow:0 -2px 12px #00000014;display:flex;justify-content:space-around;left:0;padding:8px max(env(safe-area-inset-right),8px) max(env(safe-area-inset-bottom),8px) max(env(safe-area-inset-left),8px);position:fixed;right:0;z-index:100}.mobile-nav-item{flex:1 1;flex-direction:column;gap:4px;max-width:100px;padding:8px 16px;transition:all .3s cubic-bezier(.4,0,.2,1)}.mobile-nav-icon{font-size:1.5rem;position:relative;transition:transform .3s cubic-bezier(.4,0,.2,1)}.mobile-nav-item.active .mobile-nav-icon{transform:translateY(-2px)}.mobile-nav-badge{background:#ef4444;border-radius:10px;color:#fff;font-size:.65rem;font-weight:700;min-width:18px;padding:2px 5px;position:absolute;right:-8px;text-align:center;top:-4px}.mobile-nav-label{color:var(--text3);font-size:.7rem;font-weight:600;transition:all .3s}.mobile-nav-item.active .mobile-nav-label{color:var(--accent);font-weight:700}.mobile-nav-indicator{animation:slideIn .3s cubic-bezier(.4,0,.2,1);background:var(--accent);border-radius:3px 3px 0 0;bottom:0;height:3px;left:50%;position:absolute;transform:translateX(-50%);width:32px}@keyframes slideIn{0%{opacity:0;width:0}to{opacity:1;width:32px}}.feed-card{-webkit-tap-highlight-color:transparent;background:var(--card);border:1.5px solid var(--border);border-radius:16px;display:flex;gap:12px;margin-bottom:12px;padding:16px;transition:all .2s}.feed-card:active{transform:scale(.98)}.feed-card-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;font-size:1.5rem;height:48px;justify-content:center;width:48px}.feed-card-content{flex:1 1;min-width:0}.feed-card-header{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:4px}.feed-card-title{color:var(--text);font-size:1rem;font-weight:700;margin:0}.feed-card-badge{background:var(--bg3);border-radius:12px;color:var(--text3);font-size:.7rem;font-weight:700;padding:3px 8px}.feed-card-subtitle{color:var(--text3);font-size:.85rem;margin:0}.feed-card-quest{background:linear-gradient(135deg,#fffbeb,#fff8d6);border-color:#fde68a}.dark .feed-card-quest{background:linear-gradient(135deg,#221600,#1a1200);border-color:#6a3800}.swipeable-card-container{border-radius:16px;margin-bottom:12px;overflow:hidden;position:relative}.swipeable-card-background{align-items:center;display:flex;inset:0;justify-content:space-between;padding:0 24px;position:absolute;transition:background-color .2s}.swipeable-action{align-items:center;color:#fff;display:flex;font-weight:700;gap:8px}.swipeable-action-icon{font-size:1.5rem}.swipeable-action-label{font-size:.9rem}.swipeable-card{background:var(--card);border:1.5px solid var(--border);border-radius:16px;position:relative;touch-action:pan-y;will-change:transform}.swipeable-card.dragging{cursor:grabbing}.assignment-card{cursor:pointer;display:flex;gap:12px;padding:16px}.assignment-card.urgent{background:#ef44440d}.assignment-stripe{border-radius:4px;flex-shrink:0;width:4px}.assignment-content{flex:1 1;min-width:0}.assignment-title{color:var(--text);font-size:1rem;font-weight:700;line-height:1.3;margin:0 0 6px}.assignment-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.assignment-subject{color:var(--text2);font-size:.8rem;font-weight:600}.assignment-due{background:var(--bg3);border-radius:12px;color:var(--text3);font-size:.75rem;font-weight:700;padding:3px 8px}.assignment-due.urgent{background:#fef2f2;color:#ef4444}.dark .assignment-due.urgent{background:#1c0000;color:#ff7070}.bottom-sheet-overlay{animation:fadeIn .3s;background:#00000080;inset:0;position:fixed;z-index:200}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.bottom-sheet{animation:slideUp .3s cubic-bezier(.4,0,.2,1);background:var(--card);border-radius:24px 24px 0 0;bottom:0;box-shadow:0 -4px 24px #00000026;display:flex;flex-direction:column;left:0;position:fixed;right:0;transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:201}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bottom-sheet.dragging{transition:none}.bottom-sheet-handle-area{cursor:grab;display:flex;justify-content:center;padding:12px}.bottom-sheet-handle-area:active{cursor:grabbing}.bottom-sheet-handle{background:var(--border2);border-radius:2px;height:4px;width:40px}.bottom-sheet-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:0 20px 16px}.bottom-sheet-title{color:var(--text);font-size:1.3rem;font-weight:700;margin:0}.bottom-sheet-close{align-items:center;background:var(--bg3);border:none;border-radius:50%;color:var(--text2);cursor:pointer;display:flex;font-size:1.2rem;height:36px;justify-content:center;transition:all .2s;width:36px}.bottom-sheet-close:active{background:var(--bg4);transform:scale(.95)}.bottom-sheet-content{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;padding:20px}.mobile-view{min-height:100%;padding:16px}.home-stats{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.home-stat{background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:12px 8px;text-align:center}.home-stat-value{color:var(--text);font-size:1.3rem;font-weight:700;margin-bottom:4px}.home-stat-label{color:var(--text3);font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.quest-progress{display:flex;gap:8px;margin-top:12px}.quest-pip{align-items:center;background:var(--card);border:2.5px solid #fde68a;border-radius:50%;display:flex;font-size:1rem;font-weight:700;height:36px;justify-content:center;transition:all .3s;width:36px}.quest-pip.completed{background:#f59e0b;border-color:#f59e0b;box-shadow:0 2px 12px #f59e0b66;color:#fff}.feed-section{margin-bottom:24px}.feed-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.feed-section-title{color:var(--text);font-size:1.1rem;font-weight:700;margin:0}.feed-section-count{background:var(--bg3);border-radius:12px;color:var(--text3);font-size:.85rem;font-weight:700;padding:4px 10px}.tasks-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.tasks-title{color:var(--text);font-size:1.8rem;font-weight:700;margin:0}.tasks-count{color:var(--text3);font-size:.9rem;font-weight:700}.filter-pills{-webkit-overflow-scrolling:touch;display:flex;gap:8px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none}.filter-pills::-webkit-scrollbar{display:none}.filter-pill{-webkit-tap-highlight-color:transparent;align-items:center;background:var(--card);border:1.5px solid var(--border);border-radius:20px;color:var(--text2);cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:6px;padding:8px 16px;transition:all .2s;white-space:nowrap}.filter-pill:active{transform:scale(.95)}.filter-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.sort-bar{align-items:center;background:var(--bg3);border-radius:12px;display:flex;gap:8px;margin-bottom:16px;padding:12px}.sort-label{color:var(--text3)}.sort-label,.sort-select{font-size:.85rem;font-weight:600}.sort-select{background:var(--card);border:1.5px solid var(--border);border-radius:8px;color:var(--text);flex:1 1;font-family:inherit;padding:6px 10px}.task-card{cursor:pointer;display:flex;gap:12px;padding:16px;position:relative}.task-card.completed{opacity:.6}.task-priority-indicator{border-radius:4px;flex-shrink:0;width:4px}.task-content{flex:1 1;min-width:0}.task-title{color:var(--text);font-size:1rem;font-weight:700;line-height:1.3;margin:0 0 6px}.task-card.completed .task-title{text-decoration:line-through}.task-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.task-subject{color:var(--text2);font-size:.8rem;font-weight:600}.task-due{background:var(--bg3);border-radius:12px;color:var(--text3);font-size:.75rem;font-weight:700;padding:3px 8px}.task-due.overdue{background:#fef2f2;color:#ef4444}.task-due.today{background:#fff7ed;color:#f59e0b}.task-due.soon{background:#eff6ff;color:#3b82f6}.task-progress{align-items:center;display:flex;gap:8px}.task-progress-bar{background:var(--bg3);border-radius:3px;flex:1 1;height:6px;overflow:hidden}.task-progress-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .3s}.task-progress-text{color:var(--text3);font-size:.75rem;font-weight:700}.task-completed-badge{background:#10b981;flex-shrink:0;font-size:1.1rem;font-weight:700;height:32px;width:32px}.fab,.task-completed-badge{align-items:center;border-radius:50%;color:#fff;display:flex;justify-content:center}.fab{-webkit-tap-highlight-color:transparent;background:var(--accent);border:none;bottom:calc(80px + max(env(safe-area-inset-bottom), 16px));box-shadow:0 4px 16px #6366f166;cursor:pointer;font-size:2rem;font-weight:300;height:56px;position:fixed;right:16px;transition:all .3s cubic-bezier(.4,0,.2,1);width:56px;z-index:90}.fab:active{transform:scale(.9)}.empty-state{padding:48px 24px;text-align:center}.empty-state-icon{font-size:4rem;margin-bottom:16px}.empty-state-title{color:var(--text);font-size:1.3rem;font-weight:700;margin:0 0 8px}.empty-state-text{color:var(--text3);font-size:.95rem;margin:0 0 24px}.btn-primary{-webkit-tap-highlight-color:transparent;background:var(--accent);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:700;padding:12px 24px;transition:all .2s}.btn-primary:active{transform:scale(.95)}@media (min-width:769px){.mobile-container,.mobile-header-new,.mobile-nav-bottom{display:none}}.mobile-header-new{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--card);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:50}.mobile-header-content{align-items:center;display:flex;gap:12px;justify-content:space-between;padding:12px 16px}.mobile-header-hamburger{-webkit-tap-highlight-color:transparent;align-items:center;background:#0000;border:none;border-radius:10px;color:var(--text);cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s;width:40px}.mobile-header-hamburger:active{background:var(--bg3);transform:scale(.95)}.mobile-header-title{color:var(--text);flex:1 1;font-size:1.1rem;font-weight:700;margin:0;text-align:center}.mobile-header-title-text{display:inline}@media (max-width:360px){.mobile-header-title-text{display:none}}@media (min-width:361px){.mobile-header-title-text{display:inline}}.mobile-header-actions{align-items:center;display:flex;gap:8px}@media (max-width:360px){.mobile-header-actions{gap:4px}.mobile-header-icon-btn{height:32px;width:32px}.mobile-header-streak{display:none}}.mobile-header-points,.mobile-header-streak{align-items:center;border-radius:20px;display:flex;font-size:.85rem;font-weight:700;gap:4px;padding:6px 10px}.mobile-header-streak{background:linear-gradient(135deg,#fff7f0,#fddcb5);border:1.5px solid #fb923c;color:#ea580c}.dark .mobile-header-streak{background:linear-gradient(135deg,#200e00,#7a3000);border-color:#7a3000;color:#fb923c}.mobile-header-points{background:linear-gradient(135deg,#fffbeb,#fde68a);border:1.5px solid #f59e0b;color:#d97706}.dark .mobile-header-points{background:linear-gradient(135deg,#231800,#8a5000);border-color:#8a5000;color:#f59e0b}.mobile-header-icon-btn{-webkit-tap-highlight-color:transparent;align-items:center;background:var(--bg3);border:none;border-radius:10px;color:var(--text2);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.mobile-header-icon-btn:active{background:var(--bg4);transform:scale(.95)}.mobile-header-icon-btn.danger{color:#ef4444}.mobile-header-icon-btn.danger:active{background:#ef44441a}.mobile-nav-overlay{animation:fadeIn .3s;background:#00000080;inset:0;position:fixed;z-index:100}.mobile-nav-drawer{animation:slideInLeft .3s cubic-bezier(.4,0,.2,1);background:var(--card);bottom:0;box-shadow:2px 0 24px #00000026;display:flex;flex-direction:column;left:0;max-width:75vw;position:fixed;top:0;width:130px;z-index:101}@keyframes slideInLeft{0%{transform:translateX(-100%)}to{transform:translateX(0)}}.mobile-nav-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:14px 12px}.mobile-nav-header-btn{-webkit-tap-highlight-color:transparent;background:#0000;border:none;cursor:pointer;padding:0}.mobile-nav-title{color:var(--text);font-size:1.1rem;font-weight:700;margin:0}.mobile-nav-header-actions{display:flex;gap:6px}.mobile-nav-close{display:none}.mobile-nav-items{flex:1 1;overflow-y:auto;padding:6px 8px}.mobile-nav-footer{display:none}.mobile-nav-item{-webkit-tap-highlight-color:transparent;align-items:center;background:#0000;border:none;border-radius:10px;color:var(--text2);cursor:pointer;display:flex;font-family:inherit;font-size:.9rem;font-weight:600;gap:12px;margin-bottom:2px;padding:9px 12px;position:relative;text-align:left;transition:all .2s;width:100%}.mobile-nav-item:active{transform:scale(.98)}.mobile-nav-item.active{background:var(--accent);color:#fff}.mobile-nav-item:not(.active):hover{background:var(--bg3);color:var(--text)}.mobile-nav-item-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.mobile-nav-item-label{flex:1 1}.mobile-nav-item-badge{background:#ef4444e6;border-radius:10px;color:#fff;font-size:.7rem;font-weight:700;min-width:20px;padding:2px 6px;text-align:center}.mobile-nav-item.active .mobile-nav-item-badge{background:#ffffff4d}.mobile-nav-footer{border-top:1px solid var(--border);display:flex;gap:8px;justify-content:center;padding:10px 12px}.mobile-nav-action-icon{-webkit-tap-highlight-color:transparent;align-items:center;background:var(--bg3);border:none;border-radius:10px;color:var(--text2);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.mobile-nav-action-icon:active{transform:scale(.95)}.mobile-nav-action-icon:hover{background:var(--bg4);color:var(--text)}.mobile-nav-action-icon.danger{color:#ef4444}.mobile-nav-action-icon.danger:hover{background:#ef44441a;color:#dc2626}.mobile-nav-bottom{display:none!important}.mobile-content{padding-bottom:20px}.grades-title{color:var(--text);font-size:1.8rem;font-weight:700;margin:0 0 20px}.grades-overall{align-items:center;background:var(--card);border:1.5px solid var(--border);border-radius:20px;display:flex;gap:24px;margin-bottom:24px;padding:24px}.grades-overall-circle{flex-shrink:0}.grades-overall-stats{display:flex;flex:1 1;flex-direction:column;gap:16px}.grades-overall-stat{display:flex;flex-direction:column;gap:4px}.grades-overall-value{color:var(--text);font-size:1.8rem;font-weight:700}.grades-overall-label{color:var(--text3);font-size:.85rem;font-weight:600}.grades-section-title{color:var(--text);font-size:1.1rem;font-weight:700;margin:0 0 12px}.grades-subjects{margin-bottom:24px}.grades-subject-card{background:var(--card);border:1.5px solid var(--border);border-radius:16px;margin-bottom:12px;padding:16px}.grades-subject-header{align-items:center;display:flex;gap:12px;margin-bottom:12px}.grades-subject-dot{border-radius:50%;flex-shrink:0;height:12px;width:12px}.grades-subject-name{color:var(--text);flex:1 1;font-size:1rem;font-weight:700;margin:0}.grades-subject-rate{color:var(--accent);font-size:1.1rem;font-weight:700}.grades-subject-progress{background:var(--bg3);border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden}.grades-subject-fill{border-radius:4px;height:100%;transition:width .3s}.grades-subject-stats{color:var(--text3);font-size:.85rem}.schedule-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.schedule-title{color:var(--text);font-size:1.8rem;font-weight:700;margin:0}.btn-icon{align-items:center;background:var(--card);border:1.5px solid var(--border);border-radius:10px;color:var(--text2);cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s;width:40px}.btn-icon:active{background:var(--bg3);transform:scale(.95)}.schedule-today{margin-bottom:24px}.schedule-section-title{color:var(--text);font-size:1.1rem;font-weight:700;margin:0 0 12px}.schedule-classes{display:flex;flex-direction:column;gap:8px}.schedule-class-card{background:var(--card);border:1.5px solid var(--border);border-radius:14px;display:flex;gap:12px;padding:14px}.schedule-class-card.today{background:rgba(var(--accent-rgb),.05);border-color:var(--accent)}.schedule-class-indicator{border-radius:4px;flex-shrink:0;width:4px}.schedule-class-content{flex:1 1;min-width:0}.schedule-class-name{color:var(--text);font-size:1rem;font-weight:700;margin:0 0 6px}.schedule-class-meta{display:flex;flex-direction:column;gap:4px}.schedule-class-room,.schedule-class-time{align-items:center;color:var(--text3);display:flex;font-size:.85rem;gap:6px}.schedule-week{margin-bottom:24px}.schedule-day{background:var(--card);border:1.5px solid var(--border);border-radius:14px;margin-bottom:8px;padding:14px}.schedule-day.today{border-color:var(--accent)}.schedule-day-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.schedule-day-name{color:var(--text);font-size:1rem;font-weight:700;margin:0}.schedule-day-count{background:var(--bg3);border-radius:12px;color:var(--text3);font-size:.85rem;font-weight:700;padding:4px 10px}.schedule-day-classes{display:flex;flex-direction:column;gap:6px}.schedule-class-mini{align-items:center;background:var(--bg3);border-radius:10px;display:flex;gap:10px;padding:8px}.schedule-class-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.schedule-class-mini-name{color:var(--text);flex:1 1;font-size:.9rem;font-weight:600}.schedule-class-mini-time{color:var(--text3);font-size:.8rem;font-weight:600}.schedule-day-empty{color:var(--text4);font-size:.9rem;padding:12px;text-align:center}.buddy-title{color:var(--text);font-size:1.8rem;font-weight:700;margin:0 0 20px}.buddy-creature-card{background:var(--card);border:1.5px solid var(--border);border-radius:20px;margin-bottom:20px;padding:24px;text-align:center}.buddy-creature-stage{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.buddy-stage-name{color:var(--text);font-size:1.2rem;font-weight:700}.buddy-stage-level{background:var(--bg3);border-radius:12px;color:var(--text3);font-size:.85rem;font-weight:700;padding:4px 12px}.buddy-creature-container{height:200px;margin:0 auto 16px;width:180px}.buddy-stage-desc{color:var(--text3);font-size:.9rem;margin:0 0 16px}.buddy-progress{margin-top:16px}.buddy-progress-label{color:var(--text3);display:flex;font-size:.85rem;font-weight:600;justify-content:space-between;margin-bottom:8px}.buddy-progress-bar{background:var(--bg3);border-radius:4px;height:8px;overflow:hidden}.buddy-progress-fill{background:linear-gradient(90deg,#f5a623,#ffd060);border-radius:4px;height:100%;transition:width .6s}.buddy-stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:20px}.buddy-stat-card{background:var(--card);border:1.5px solid var(--border);border-radius:16px;padding:16px;text-align:center}.buddy-stat-icon{align-items:center;background:var(--bg3);border-radius:12px;color:var(--accent);display:flex;height:40px;justify-content:center;margin:0 auto 12px;width:40px}.buddy-stat-value{color:var(--text);font-size:1.5rem;font-weight:700;margin-bottom:4px}.buddy-stat-label{color:var(--text3);font-size:.8rem;font-weight:600}.buddy-quest-card{background:linear-gradient(135deg,#fffbeb,#fff8d6);border:1.5px solid #fde68a;border-radius:16px;margin-bottom:20px;padding:18px}.dark .buddy-quest-card{background:linear-gradient(135deg,#221600,#1a1200);border-color:#6a3800}.buddy-quest-header{align-items:center;color:#d97706;display:flex;gap:8px;margin-bottom:8px}.buddy-quest-title{font-size:1rem;font-weight:700;margin:0}.buddy-quest-desc{color:var(--text2);font-size:.9rem;margin:0 0 16px}.buddy-quest-progress{align-items:center;display:flex;gap:10px}.buddy-quest-pip{align-items:center;background:var(--card);border:2.5px solid #fde68a;border-radius:50%;display:flex;height:40px;justify-content:center;transition:all .3s;width:40px}.buddy-quest-pip.completed{background:#f59e0b;border-color:#f59e0b;box-shadow:0 2px 12px #f59e0b66;color:#fff}.buddy-quest-status{color:var(--text2);flex:1 1;font-size:.85rem;font-weight:600}.buddy-quest-complete{color:#f59e0b;font-weight:700}.buddy-points-info{background:var(--card);border:1.5px solid var(--border);border-radius:16px;padding:18px}.buddy-section-title{color:var(--text);font-size:1rem;font-weight:700;margin:0 0 16px}.buddy-points-row{align-items:center;display:flex;justify-content:space-between;padding:8px 0}.buddy-points-action{color:var(--text2);font-size:.9rem}.buddy-points-value{color:#f59e0b;font-size:1rem;font-weight:700}.buddy-points-divider{background:var(--border);height:1px;margin:8px 0}.buddy-points-note{color:var(--text4);font-size:.85rem;margin:8px 0 0}.shop-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.shop-title{color:var(--text);font-size:1.8rem;font-weight:700;margin:0}.shop-points{align-items:center;background:linear-gradient(135deg,#fffbeb,#fde68a);border:1.5px solid #f59e0b;border-radius:20px;color:#d97706;display:flex;font-size:1rem;font-weight:700;gap:6px;padding:8px 14px}.dark .shop-points{background:linear-gradient(135deg,#231800,#8a5000);border-color:#8a5000;color:#f59e0b}.shop-grid-mobile{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.shop-card-mobile{align-items:center;background:var(--card);border:1.5px solid var(--border);border-radius:16px;display:flex;flex-direction:column;padding:14px;position:relative;text-align:center}.shop-badge-mobile{border-radius:12px;color:#fff;font-size:.7rem;padding:4px 8px;right:8px}.shop-badge-mobile,.shop-rarity-mobile{font-weight:700;position:absolute;top:8px}.shop-rarity-mobile{border-radius:10px;font-size:.65rem;left:8px;padding:3px 8px;text-transform:uppercase}.shop-icon-mobile{font-size:3rem;margin:16px 0 12px}.shop-name-mobile{color:var(--text);font-size:.95rem;font-weight:700;margin-bottom:4px}.shop-cat-mobile{color:var(--text3);font-size:.75rem;font-weight:600;margin-bottom:6px;text-transform:capitalize}.shop-desc-mobile{color:var(--text3);flex:1 1;font-size:.8rem;line-height:1.4;margin-bottom:12px}.btn-shop-mobile{-webkit-tap-highlight-color:transparent;border:none;border-radius:10px;cursor:pointer;font-size:.85rem;font-weight:700;padding:8px 12px;transition:all .2s;width:100%}.btn-shop-mobile.equipped{background:var(--accent);color:#fff}.btn-shop-mobile:not(.equipped):not(.buy){background:#16a34a;color:#fff}.btn-shop-mobile:active{transform:scale(.95)}.timer-header-mobile{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.timer-title-mobile{color:var(--text);font-size:1.8rem;font-weight:700;margin:0}.timer-sessions-mobile{align-items:center;color:var(--text3);display:flex;font-size:.85rem;font-weight:600;gap:6px;margin-bottom:20px}.timer-display-card{background:var(--card);border:1.5px solid var(--border);border-radius:20px;margin-bottom:20px;padding:28px 20px;text-align:center}.timer-mode-label{align-items:center;color:var(--text3);display:flex;font-size:.9rem;font-weight:600;gap:8px;justify-content:center;margin-bottom:16px}.timer-mode-icon{font-size:1.2rem}.timer-display-mobile{color:var(--accent);font-family:monospace;font-size:3.5rem;font-weight:800;letter-spacing:.05em;margin-bottom:24px}.timer-mode-pills{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:24px}.timer-mode-pill{-webkit-tap-highlight-color:transparent;align-items:center;background:var(--bg2);border:1.5px solid var(--border);border-radius:20px;color:var(--text2);cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:6px;padding:8px 14px;transition:all .2s}.timer-mode-pill:active{transform:scale(.95)}.timer-mode-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.timer-controls-mobile{display:flex;gap:12px;justify-content:center}.btn-timer-mobile{-webkit-tap-highlight-color:transparent;align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;flex:1 1;font-size:.95rem;font-weight:700;gap:8px;justify-content:center;max-width:140px;padding:12px 24px;transition:all .2s}.btn-timer-mobile.start{background:var(--accent);color:#fff}.btn-timer-mobile.pause{background:#f59e0b;color:#fff}.btn-timer-mobile.reset{background:var(--bg3);border:1.5px solid var(--border);color:var(--text2)}.btn-timer-mobile:active{transform:scale(.95)}.timer-settings-mobile{background:var(--card);border:1.5px solid var(--border);border-radius:16px;margin-bottom:20px;padding:18px}.timer-settings-title{color:var(--text);font-size:1rem;font-weight:700;margin:0 0 16px}.timer-setting-item{margin-bottom:14px}.timer-setting-item:last-child{margin-bottom:0}.timer-setting-item label{color:var(--text3);display:block;font-size:.8rem;font-weight:600;margin-bottom:6px}.timer-input-mobile{background:var(--bg2);border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-family:inherit;font-size:.9rem;padding:10px 12px;width:100%}.timer-tips-mobile{background:var(--bg2);border:1.5px solid var(--border2);border-radius:14px;padding:16px}.timer-tips-title{color:var(--text);font-size:.95rem;font-weight:700;margin-bottom:10px}.timer-tips-text{color:var(--text3);font-size:.85rem;line-height:1.7}.ai-view-mobile{display:flex;flex-direction:column;height:calc(100vh - 120px);padding-bottom:0!important}.ai-title-mobile{color:var(--text);font-size:1.8rem;font-weight:700;margin:0 0 16px}.ai-empty-state{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.ai-empty-icon{color:var(--accent);margin-bottom:20px;opacity:.8}.ai-empty-title{color:var(--text);font-size:1.3rem;font-weight:700;margin-bottom:8px}.ai-empty-text{color:var(--text3);font-size:.95rem;line-height:1.6;margin-bottom:24px;max-width:300px}.ai-suggestions{display:flex;flex-direction:column;gap:10px;max-width:320px;width:100%}.ai-suggestion-chip{-webkit-tap-highlight-color:transparent;background:var(--card);border:1.5px solid var(--border);border-radius:12px;color:var(--text2);cursor:pointer;font-size:.9rem;font-weight:600;padding:12px 16px;text-align:left;transition:all .2s}.ai-suggestion-chip:active{background:var(--bg3);transform:scale(.98)}.ai-messages-mobile{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;padding-bottom:20px}.ai-message-mobile{align-items:flex-start;display:flex;gap:10px;margin-bottom:16px}.ai-message-mobile.user{flex-direction:row-reverse}.ai-message-avatar{align-items:center;background:var(--accent);border-radius:50%;color:#fff;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.ai-message-content{background:var(--card);border:1.5px solid var(--border);border-radius:16px;color:var(--text);font-size:.9rem;line-height:1.6;max-width:75%;padding:12px 14px}.ai-message-mobile.user .ai-message-content{background:var(--accent);border-color:var(--accent);color:#fff}.ai-typing-indicator{display:flex;gap:4px;padding:4px 0}.ai-typing-indicator span{animation:typing 1.4s infinite;background:var(--text3);border-radius:50%;height:8px;width:8px}.ai-typing-indicator span:nth-child(2){animation-delay:.2s}.ai-typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.5;transform:translateY(0)}30%{opacity:1;transform:translateY(-8px)}}.ai-input-container-mobile{align-items:flex-end;background:var(--bg);border-top:1.5px solid var(--border);bottom:0;display:flex;gap:10px;left:0;padding:12px 16px;position:-webkit-sticky;position:sticky;right:0}.ai-input-mobile{background:var(--card);border:1.5px solid var(--border);border-radius:12px;color:var(--text);flex:1 1;font-family:inherit;font-size:.9rem;max-height:100px;min-height:42px;padding:10px 14px;resize:none}.ai-input-mobile:focus{border-color:var(--accent);outline:none}.ai-send-btn-mobile{-webkit-tap-highlight-color:transparent;align-items:center;background:var(--accent);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:42px;justify-content:center;transition:all .2s;width:42px}.ai-send-btn-mobile:disabled{background:var(--bg3);color:var(--text4);cursor:not-allowed}.ai-send-btn-mobile:not(:disabled):active{transform:scale(.95)}.ai-mode-selector{-webkit-overflow-scrolling:touch;display:flex;gap:6px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none}.ai-mode-selector::-webkit-scrollbar{display:none}.ai-mode-btn{-webkit-tap-highlight-color:transparent;align-items:center;background:var(--card);border:1.5px solid var(--border);border-radius:8px;color:var(--text2);cursor:pointer;display:flex;font-size:.85rem;font-weight:600;justify-content:center;padding:10px 16px;transition:all .2s;white-space:nowrap}.ai-mode-btn:active{transform:scale(.95)}.ai-mode-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.ai-chat-container{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.ai-avatar{align-items:center;background:var(--accent);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;height:28px;justify-content:center;width:28px}.ai-homework-container{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto}.hw-analyzing-card,.hw-checking-card,.hw-upload-card{background:var(--card);border:1.5px solid var(--border);border-radius:16px;margin-bottom:16px;padding:32px 20px;text-align:center}.hw-icon{font-size:3rem;margin-bottom:16px}.hw-title{color:var(--text);font-size:1.1rem;font-weight:700;margin-bottom:8px}.hw-desc{color:var(--text3);font-size:.9rem;line-height:1.5;margin-bottom:20px}.hw-spinner{animation:spin .8s linear infinite;border:3px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:40px;margin:20px auto;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.hw-status{color:var(--text2);font-size:.9rem;font-weight:600;margin-top:12px}.hw-answer-upload-card,.hw-explanation-card,.hw-feedback-card,.hw-image-card{background:var(--card);border:1.5px solid var(--border);border-radius:16px;margin-bottom:16px;padding:16px}.hw-explanation-card{border-color:var(--accent);border-width:2px}.hw-feedback-card{border-color:#16a34a;border-width:2px}.hw-card-header{align-items:center;color:var(--text);display:flex;font-size:.9rem;font-weight:600;justify-content:space-between;margin-bottom:12px}.btn-reset{-webkit-tap-highlight-color:transparent;background:var(--bg3);border:1.5px solid var(--border);border-radius:8px;color:var(--text2);cursor:pointer;font-size:.8rem;font-weight:600;padding:6px 12px;transition:all .2s}.btn-reset:active{transform:scale(.95)}.hw-image{border:1px solid var(--border);border-radius:12px;width:100%}.hw-card-title{color:var(--text);font-size:1rem;font-weight:700;margin-bottom:12px}.hw-explanation-text,.hw-feedback-text{color:var(--text);font-size:.9rem;line-height:1.7}.ai-flashcards-container{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto}.flashcard-input-card{background:var(--card);border:1.5px solid var(--border);border-radius:16px;margin-bottom:20px;padding:20px}.flashcard-title{font-size:1rem;font-weight:700}.flashcard-input,.flashcard-title{color:var(--text);margin-bottom:12px}.flashcard-input{background:var(--bg2);border:1.5px solid var(--border);border-radius:10px;font-family:inherit;font-size:.9rem;padding:12px 14px;width:100%}.flashcard-input:focus{border-color:var(--accent);outline:none}.flashcards-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr}.flashcard{-webkit-tap-highlight-color:transparent;cursor:pointer;height:200px;perspective:1000px;position:relative}.flashcard-back,.flashcard-front{align-items:center;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:var(--card);border:1.5px solid var(--border);border-radius:16px;display:flex;flex-direction:column;height:100%;justify-content:center;padding:20px;position:absolute;transition:transform .6s;width:100%}.flashcard-front{transform:rotateY(0deg)}.flashcard-back,.flashcard.flipped .flashcard-front{transform:rotateY(180deg)}.flashcard.flipped .flashcard-back{transform:rotateY(0deg)}.flashcard-label{color:var(--accent);font-size:.75rem;font-weight:700;letter-spacing:.05em;margin-bottom:12px;text-transform:uppercase}.flashcard-back .flashcard-label{color:#16a34a}.flashcard-text{align-items:center;color:var(--text);display:flex;flex:1 1;font-size:.95rem;font-weight:500;justify-content:center;line-height:1.5;text-align:center}.flashcard-hint{color:var(--text4);font-size:.75rem;margin-top:12px}.ai-writing-container{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto}.writing-feedback-card,.writing-input-card{background:var(--card);border:1.5px solid var(--border);border-radius:16px;margin-bottom:16px;padding:20px}.writing-title{font-size:1rem;font-weight:700}.writing-textarea,.writing-title{color:var(--text);margin-bottom:12px}.writing-textarea{background:var(--bg2);border:1.5px solid var(--border);border-radius:10px;font-family:inherit;font-size:.9rem;line-height:1.6;padding:12px 14px;resize:vertical;width:100%}.writing-textarea:focus{border-color:var(--accent);outline:none}.writing-feedback-title{align-items:center;color:var(--text);display:flex;font-size:1rem;font-weight:700;gap:8px;margin-bottom:12px}.writing-feedback-text{color:var(--text);font-size:.9rem;line-height:1.7}.ai-insights-container{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto}.insights-card,.insights-result-card{background:var(--card);border:1.5px solid var(--border);border-radius:16px;margin-bottom:16px;padding:32px 20px;text-align:center}.insights-icon{font-size:3rem;margin-bottom:16px}.insights-title{color:var(--text);font-size:1.1rem;font-weight:700;margin-bottom:8px}.insights-desc{color:var(--text3);font-size:.9rem;line-height:1.5;margin-bottom:20px}.insights-result-card{text-align:left}.insights-result-title{color:var(--text);font-size:1rem;font-weight:700;margin-bottom:12px}.insights-result-text{color:var(--text);font-size:.9rem;line-height:1.7}.pull-to-refresh-indicator{align-items:center;display:flex;height:40px;justify-content:center;left:50%;opacity:0;position:absolute;top:-60px;transform:translateX(-50%);transition:top .3s,opacity .3s;width:40px;z-index:10}.pull-to-refresh-indicator.pulling{opacity:1}.pull-to-refresh-indicator.refreshing{opacity:1;top:10px}.pull-to-refresh-spinner{animation:spin .8s linear infinite;border:3px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:32px;width:32px}.pull-to-refresh-arrow{color:var(--accent);font-size:1.5rem;transition:transform .3s}.pull-to-refresh-indicator.ready .pull-to-refresh-arrow{transform:rotate(180deg)}.swipe-indicator{animation:fadeInOut 2s ease-in-out;background:#000000b3;border-radius:20px;bottom:100px;color:#fff;font-size:.85rem;font-weight:600;left:50%;padding:8px 16px;pointer-events:none;position:fixed;transform:translateX(-50%);z-index:150}@keyframes fadeInOut{0%,to{opacity:0}10%,90%{opacity:1}}.fab-container{bottom:calc(20px + max(env(safe-area-inset-bottom), 16px));position:fixed;right:16px;z-index:90}.fab-menu{bottom:70px;display:flex;flex-direction:column;gap:12px;opacity:0;pointer-events:none;position:absolute;right:0;transform:translateY(20px);transition:all .3s cubic-bezier(.4,0,.2,1)}.fab-menu.open{opacity:1;pointer-events:all;transform:translateY(0)}.fab-menu-item{-webkit-tap-highlight-color:transparent;align-items:center;background:var(--card);border:1.5px solid var(--border);border-radius:28px;box-shadow:0 4px 12px #00000026;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:all .2s;white-space:nowrap}.fab-menu-item:active{transform:scale(.95)}.fab-menu-item-icon{align-items:center;display:flex;font-size:1.2rem;height:24px;justify-content:center;width:24px}.fab-menu-item-label{color:var(--text);font-size:.9rem;font-weight:600}.fab.open{transform:rotate(45deg)}.haptic-pulse{animation:hapticPulse .3s ease-out}@keyframes hapticPulse{0%{transform:scale(1)}50%{transform:scale(.95)}to{transform:scale(1)}}.haptic-success{animation:hapticSuccess .4s ease-out}@keyframes hapticSuccess{0%,to{transform:scale(1)}25%{transform:scale(1.05)}50%{transform:scale(.95)}75%{transform:scale(1.02)}}.mobile-content.swiping{transition:none;will-change:transform}.mobile-content.transitioning{transition:transform .3s cubic-bezier(.4,0,.2,1)}.assignment-detail-sheet{max-height:85vh}.assignment-detail-header{border-bottom:1px solid var(--border);padding:20px}.assignment-detail-title{color:var(--text);font-size:1.3rem;font-weight:700;line-height:1.3;margin:0 0 8px}.assignment-detail-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.assignment-detail-badge{align-items:center;background:var(--bg3);border-radius:12px;color:var(--text3);display:inline-flex;font-size:.75rem;font-weight:700;gap:4px;padding:4px 10px}.assignment-detail-body{padding:20px}.assignment-detail-section{margin-bottom:20px}.assignment-detail-section:last-child{margin-bottom:0}.assignment-detail-label{color:var(--text3);font-size:.75rem;font-weight:700;letter-spacing:.05em;margin-bottom:6px;text-transform:uppercase}.assignment-detail-value{color:var(--text);font-size:.95rem;line-height:1.6}.assignment-detail-progress{margin-top:8px}.assignment-detail-progress-bar{background:var(--bg3);border-radius:4px;height:8px;margin-bottom:6px;overflow:hidden}.assignment-detail-progress-fill{background:var(--accent);border-radius:4px;height:100%;transition:width .3s}.assignment-detail-progress-text{color:var(--text3);font-size:.85rem;font-weight:600}.assignment-detail-actions{border-top:1px solid var(--border);display:flex;gap:10px;padding:16px 20px}.btn-detail-action{-webkit-tap-highlight-color:transparent;align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;flex:1 1;font-size:.95rem;font-weight:700;gap:6px;justify-content:center;padding:12px;transition:all .2s}.btn-detail-action.primary{background:var(--accent);color:#fff}.btn-detail-action.secondary{background:var(--bg3);border:1.5px solid var(--border);color:var(--text2)}.btn-detail-action:active{transform:scale(.95)}.offline-banner{align-items:center;animation:slideDown .3s ease-out;background:#f59e0b;color:#fff;display:flex;font-size:.85rem;font-weight:600;gap:8px;justify-content:center;left:0;padding:8px 16px;position:fixed;right:0;text-align:center;top:max(env(safe-area-inset-top),0);z-index:200}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.offline-icon{font-size:1rem}.skeleton{animation:skeleton-loading 1.5s ease-in-out infinite;background:linear-gradient(90deg,var(--bg3) 0,var(--bg4) 50%,var(--bg3) 100%);background-size:200% 100%;border-radius:8px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{height:100px;margin-bottom:12px}.skeleton-text{height:16px;margin-bottom:8px}.skeleton-text.short{width:60%}.completion-celebration{align-items:center;animation:fadeIn .3s;background:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:300}.celebration-content{animation:celebrationPop .5s cubic-bezier(.68,-.55,.265,1.55);background:var(--card);border-radius:24px;padding:40px 32px;text-align:center}@keyframes celebrationPop{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.celebration-icon{animation:celebrationBounce .6s ease-in-out;font-size:4rem;margin-bottom:16px}@keyframes celebrationBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.celebration-title{color:var(--text);font-size:1.5rem;font-weight:700;margin-bottom:8px}.celebration-points{color:#f59e0b;font-size:1.8rem;font-weight:800;margin-bottom:16px}.celebration-message{color:var(--text3);font-size:.95rem}.calendar-view-mobile{padding-bottom:80px}.calendar-title-mobile{color:var(--text);font-size:1.5rem;font-weight:700;margin-bottom:20px}.calendar-header-mobile{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px;padding:0 8px}.calendar-nav-btn{align-items:center;background:var(--card);border:1.5px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s}.calendar-nav-btn:active{background:var(--bg3);transform:scale(.95)}.calendar-month-year{color:var(--text);font-size:1.1rem;font-weight:600}.calendar-today-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;margin-bottom:16px;padding:8px 16px;transition:all .2s}.calendar-today-btn:active{opacity:.9;transform:scale(.95)}.calendar-day-names{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.calendar-day-name{color:var(--text3);font-size:.75rem;font-weight:600;padding:8px 0;text-align:center}.calendar-grid-mobile{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:20px}.calendar-day-cell{align-items:center;aspect-ratio:1;background:var(--card);border:1.5px solid var(--border);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;position:relative;transition:all .2s}.calendar-day-cell.empty{background:#0000;border:none;cursor:default}.calendar-day-cell.today{background:var(--accent-light);border-color:var(--accent)}.calendar-day-cell.selected{background:var(--accent);border-color:var(--accent)}.calendar-day-cell.selected .calendar-day-number{color:#fff;font-weight:700}.calendar-day-cell:not(.empty):active{transform:scale(.95)}.calendar-day-number{color:var(--text);font-size:.85rem;font-weight:500}.calendar-day-dots{display:flex;gap:2px;margin-top:2px}.calendar-day-dot{background:var(--accent);border-radius:50%;height:4px;width:4px}.calendar-selected-date-card{background:var(--card);border:1.5px solid var(--border);border-radius:12px;margin-bottom:20px;padding:16px}.calendar-selected-date-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.calendar-selected-date-title{color:var(--text);font-size:1rem;font-weight:600}.calendar-close-btn{align-items:center;background:none;border:none;color:var(--text3);cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;padding:0;width:32px}.calendar-assignments-list{display:flex;flex-direction:column;gap:12px}.calendar-assignment-item{background:var(--bg2);border-radius:8px;display:flex;gap:12px;padding:12px}.calendar-assignment-icon{font-size:1.2rem}.calendar-assignment-details{flex:1 1}.calendar-assignment-title{color:var(--text);font-size:.9rem;font-weight:600;margin-bottom:4px}.calendar-assignment-meta{color:var(--text3);font-size:.75rem;margin-bottom:8px}.calendar-assignment-progress{align-items:center;display:flex;gap:8px}.calendar-progress-bar{background:var(--bg3);border-radius:3px;flex:1 1;height:6px;overflow:hidden}.calendar-progress-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .3s}.calendar-progress-text{color:var(--text3);font-size:.75rem;min-width:35px;text-align:right}.calendar-no-assignments{padding:32px 16px;text-align:center}.calendar-empty-icon{font-size:3rem;margin-bottom:12px}.calendar-empty-text{color:var(--text3);font-size:.9rem}.calendar-upcoming-card{background:var(--card);border:1.5px solid var(--border);border-radius:12px;padding:16px}.calendar-upcoming-title{color:var(--text);font-size:1rem;font-weight:600;margin-bottom:12px}.calendar-upcoming-item{background:var(--bg2);border-radius:8px;display:flex;gap:12px;margin-bottom:8px;padding:12px}.calendar-upcoming-item:last-child{margin-bottom:0}.calendar-upcoming-date{color:var(--accent);font-size:.75rem;font-weight:600;min-width:50px}.calendar-upcoming-details{flex:1 1}.calendar-upcoming-title-text{color:var(--text);font-size:.85rem;font-weight:600;margin-bottom:2px}.calendar-upcoming-subject{color:var(--text3);font-size:.75rem}.calendar-upcoming-empty{color:var(--text3);font-size:.9rem;padding:24px;text-align:center}.notes-view-mobile{padding-bottom:80px;position:relative}.notes-title-mobile{color:var(--text);font-size:1.5rem;font-weight:700;margin-bottom:20px}.notes-controls-mobile{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.notes-search-container{position:relative}.notes-search-icon{color:var(--text3);left:12px;position:absolute;top:50%;transform:translateY(-50%)}.notes-search-input{background:var(--card);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.9rem;padding:10px 12px 10px 40px;width:100%}.notes-search-input::placeholder{color:var(--text3)}.notes-filter-select{background:var(--card);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.9rem;padding:10px 12px;width:100%}.notes-list-mobile{display:flex;flex-direction:column;gap:12px}.note-card-mobile{background:var(--card);border:1.5px solid var(--border);border-radius:12px;cursor:pointer;padding:16px;transition:all .2s}.note-card-mobile:active{background:var(--bg3);transform:scale(.98)}.note-card-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px}.note-card-title{color:var(--text);flex:1 1;font-size:1rem;font-weight:600}.note-card-subject{background:var(--accent-light);border-radius:4px;color:var(--accent);font-size:.75rem;font-weight:600;padding:4px 8px;white-space:nowrap}.note-card-preview{color:var(--text3);font-size:.85rem;line-height:1.4;margin-bottom:12px}.note-card-footer{align-items:center;color:var(--text4);display:flex;font-size:.75rem;justify-content:space-between}.notes-empty-state{padding:64px 32px;text-align:center}.notes-empty-icon{font-size:4rem;margin-bottom:16px}.notes-empty-title{color:var(--text);font-size:1.1rem;font-weight:600;margin-bottom:8px}.notes-empty-text{color:var(--text3);font-size:.9rem;line-height:1.4}.notes-add-btn-mobile{align-items:center;background:var(--accent);border:none;border-radius:50%;bottom:80px;box-shadow:0 4px 12px #00000026;color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:20px;transition:all .2s;width:56px;z-index:10}.notes-add-btn-mobile:active{transform:scale(.95)}.note-editor-mobile{background:var(--bg);bottom:0;display:flex;flex-direction:column;left:0;position:fixed;right:0;top:0;z-index:100}.note-editor-header{align-items:center;background:var(--card);border-bottom:1.5px solid var(--border);display:flex;justify-content:space-between;padding:16px}.note-editor-back-btn{align-items:center;background:none;border:none;color:var(--text);cursor:pointer;display:flex;justify-content:center;padding:8px}.note-editor-title-text{color:var(--text);flex:1 1;font-size:1rem;font-weight:600;text-align:center}.note-editor-save-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:8px 16px}.note-editor-content{flex:1 1;overflow-y:auto;padding:16px}.note-editor-title-input{background:var(--card);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:1.1rem;font-weight:600;margin-bottom:12px;padding:12px;width:100%}.note-editor-title-input::placeholder{color:var(--text3)}.note-editor-subject-input{background:var(--card);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.9rem;margin-bottom:12px;padding:10px 12px;width:100%}.note-editor-subject-input::placeholder{color:var(--text3)}.note-editor-textarea{background:var(--card);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.95rem;line-height:1.6;min-height:300px;padding:12px;resize:vertical;width:100%}.note-editor-textarea::placeholder{color:var(--text3)}.note-editor-footer{background:var(--card);border-top:1.5px solid var(--border);padding:16px}.note-editor-delete-btn{background:#0000;border:1.5px solid #ef4444;border-radius:8px;color:#ef4444;cursor:pointer;font-size:.9rem;font-weight:600;padding:12px;transition:all .2s;width:100%}.note-editor-delete-btn:active{background:#ef4444;color:#fff}.note-editor-delete-confirm{align-items:center;display:flex;gap:12px;justify-content:space-between}.note-editor-delete-confirm span{color:var(--text);font-size:.9rem;font-weight:600}.note-editor-confirm-yes{background:#ef4444;color:#fff}.note-editor-confirm-no,.note-editor-confirm-yes{border:none;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:600;padding:10px 16px}.note-editor-confirm-no{background:var(--bg3);color:var(--text)}.ai-questions-container{display:flex;flex-direction:column;gap:16px}.questions-input-card{background:var(--card);border:1.5px solid var(--border);border-radius:12px;padding:16px}.questions-title{color:var(--text);font-size:1rem;font-weight:600;margin-bottom:8px}.questions-desc{color:var(--text3);font-size:.85rem;margin-bottom:12px}.questions-textarea{background:var(--bg2);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.9rem;margin-bottom:12px;padding:12px;resize:vertical;width:100%}.questions-upload-btns{display:flex;gap:8px;margin-bottom:12px}.questions-image-preview{margin-bottom:12px;position:relative}.questions-image-preview img{border:1.5px solid var(--border);border-radius:8px;width:100%}.questions-remove-image{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;position:absolute;right:8px;top:8px;width:32px}.questions-list-card{background:var(--card);border:1.5px solid var(--border);border-radius:12px;padding:16px}.questions-list-title{color:var(--accent);font-size:1rem;font-weight:600;margin-bottom:16px}.question-item{background:var(--bg3);border-radius:8px;margin-bottom:16px;padding:16px}.question-item:last-child{margin-bottom:0}.question-text{color:var(--text);font-size:.95rem;font-weight:600;line-height:1.4;margin-bottom:12px}.question-options{display:flex;flex-direction:column;gap:8px}.question-option{align-items:center;background:var(--card);border:2px solid var(--border);border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:all .2s}.question-option.selected{background:var(--accent-light);border-color:var(--accent)}.question-option.correct{background:#10b98110;border-color:#10b981}.question-option.incorrect{background:#ef444410;border-color:#ef4444}.option-letter{align-items:center;border:2px solid var(--border);border-radius:50%;display:flex;flex-shrink:0;font-size:.85rem;font-weight:600;height:28px;justify-content:center;width:28px}.question-option.selected .option-letter{background:var(--accent);border-color:var(--accent);color:#fff}.question-option.correct .option-letter{background:#10b981;border-color:#10b981;color:#fff}.question-option.incorrect .option-letter{background:#ef4444;border-color:#ef4444;color:#fff}.option-text{color:var(--text);flex:1 1;font-size:.9rem}.option-icon{font-size:1.2rem;font-weight:700}.question-option.correct .option-icon{color:#10b981}.question-option.incorrect .option-icon{color:#ef4444}.btn-check-answer{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;margin-top:8px;padding:10px 16px}.question-explanation{background:var(--bg2);border-left:4px solid var(--accent);border-radius:4px;color:var(--text2);font-size:.85rem;line-height:1.4;margin-top:12px;padding:12px}.question-text-answer{display:flex;flex-direction:column;gap:12px}.answer-textarea{background:var(--card);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.9rem;padding:12px;resize:vertical;width:100%}.model-answer{background:var(--bg2);border-left:4px solid var(--accent);border-radius:4px;color:var(--text2);font-size:.85rem;line-height:1.4;padding:12px}.ai-notes-container{display:flex;flex-direction:column;gap:16px}.notes-analyzer-card{background:var(--card);border:1.5px solid var(--border);border-radius:12px;padding:16px}.notes-analyzer-title{color:var(--text);font-size:1rem;font-weight:600;margin-bottom:8px}.notes-analyzer-desc{color:var(--text3);font-size:.85rem;margin-bottom:12px}.notes-analyzer-textarea{background:var(--bg2);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.9rem;margin-bottom:12px;padding:12px;resize:vertical;width:100%}.notes-files-list,.notes-upload-btns{display:flex;gap:8px;margin-bottom:12px}.notes-files-list{flex-direction:column}.notes-file-item{align-items:center;background:var(--bg3);border-radius:6px;color:var(--text);display:flex;font-size:.85rem;justify-content:space-between;padding:10px 12px}.notes-file-item button{align-items:center;background:none;border:none;color:var(--text3);cursor:pointer;display:flex;font-size:1.5rem;height:24px;justify-content:center;padding:0;width:24px}.notes-analysis-card{background:var(--card);border:1.5px solid var(--border);border-radius:12px;padding:16px}.notes-analysis-title{color:var(--accent);font-size:1rem;font-weight:600;margin-bottom:12px}.notes-analysis-text{color:var(--text);font-size:.9rem;line-height:1.6}.notes-analysis-text h1,.notes-analysis-text h2,.notes-analysis-text h3,.notes-analysis-text h4{margin-bottom:8px;margin-top:16px}.notes-analysis-text ol,.notes-analysis-text ul{margin:8px 0;padding-left:24px}.notes-analysis-text li{margin:4px 0}.notes-analysis-text code{background:var(--bg3);border-radius:4px;font-family:monospace;font-size:.85em;padding:2px 6px}.notes-analysis-text pre{background:var(--bg3);border-radius:8px;margin:12px 0;overflow-x:auto;padding:12px}.search-container{margin-bottom:16px}.search-input-wrapper{align-items:center;display:flex;position:relative}.search-icon{color:var(--text3);font-size:1rem;left:12px;position:absolute;z-index:1}.search-input{background:var(--card);border:1.5px solid var(--border);border-radius:12px;color:var(--text);font-family:inherit;font-size:.9rem;padding:12px 40px;transition:all .2s;width:100%}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1);outline:none}.search-clear,.search-input::placeholder{color:var(--text3)}.search-clear{-webkit-tap-highlight-color:transparent;align-items:center;background:#0000;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:.9rem;height:24px;justify-content:center;position:absolute;right:12px;transition:all .2s;width:24px}.search-clear:active{background:var(--bg3);transform:scale(.9)}.btn-secondary{-webkit-tap-highlight-color:transparent;background:var(--card);border:1.5px solid var(--border);border-radius:12px;color:var(--text2);cursor:pointer;font-size:.95rem;font-weight:600;padding:12px 24px;transition:all .2s}.btn-secondary:active{background:var(--bg3);transform:scale(.95)}
/*# sourceMappingURL=main.0a4540bb.css.map*/