@import "https://fonts.googleapis.com/css2?family=Material+Symbols+Rounded:opsz,wght,FILL,GRAD@20..48,400,0,0";@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Outfit:wght@400;500;600;700;800;900&display=swap";:root{--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-display:"Outfit", var(--font-sans);--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#eff6ff;--primary-glow:#2563eb26;--neutral-50:#f8fafc;--neutral-100:#f1f5f9;--neutral-200:#e2e8f0;--neutral-300:#cbd5e1;--neutral-400:#94a3b8;--neutral-600:#475569;--neutral-700:#334155;--neutral-800:#1e293b;--neutral-900:#0f172a;--glass-bg:#ffffffbf;--glass-border:#e2e8f0cc;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000000d, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #0000000d, 0 4px 6px -4px #0000000d;--shadow-xl:0 20px 25px -5px #0000000d, 0 8px 10px -6px #0000000d;--shadow-premium:0 25px 50px -12px #0f172a14;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:24px;--content-padding-x:40px;--content-padding-y:32px}*{box-sizing:border-box}html,body{font-family:var(--font-sans);background:var(--neutral-50);color:var(--neutral-800);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;overflow-x:hidden}.app-shell{background:#f4f6f9;grid-template-columns:280px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{background:var(--neutral-900);color:#fff;border-right:1px solid #ffffff0d;flex-direction:column;padding:32px 24px;display:flex}@media (width>=1025px){.sidebar{height:100vh;position:sticky;top:0}}.sidebar h1{font-family:var(--font-display);background:linear-gradient(135deg,#fff 0%,#cbd5e1 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:10px;margin:0 0 32px;font-size:26px;font-weight:800;display:flex}.sidebar nav{gap:8px;display:grid}.sidebar a{color:#94a3b8;border-radius:var(--radius-md);align-items:center;gap:12px;padding:12px 16px;font-size:15px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.sidebar a:hover{color:#fff;background:#ffffff0d}.sidebar a.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px #2563eb4d}.content{padding:var(--content-padding-y) var(--content-padding-x);width:100%;max-width:1200px;margin:0 auto}.content section{border:1px solid var(--neutral-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);background:#fff;padding:32px}.public-shell{background:radial-gradient(at 0 0,#38bdf812 0,#0000 50%),radial-gradient(at 100% 100%,#ec48990d 0,#0000 50%),linear-gradient(#f8fafc 0%,#f1f5f9 100%);min-height:100vh;position:relative;overflow-x:hidden}.public-shell:before{content:"";z-index:0;pointer-events:none;background-image:radial-gradient(circle at 1px 1px,#6366f10a 1px,#0000 0);background-size:24px 24px;position:absolute;inset:0}html.dark .public-shell{background:radial-gradient(at 0 0,#0ea5e926 0,#0000 50%),radial-gradient(at 100% 100%,#d946ef1a 0,#0000 50%),linear-gradient(#030712 0%,#0b0f19 100%)!important}html.dark .public-shell:before{background-image:radial-gradient(circle at 1px 1px,#6366f112 1px,#0000 0)!important}.landing-container{z-index:1;position:relative}.landing-header{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:0 0 var(--radius-md) var(--radius-md);background:#ffffffb3;border-bottom:1px solid #e2e8f080;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:20px 24px;display:flex;position:sticky;top:0}.landing-logo{font-family:var(--font-display);color:var(--neutral-900);align-items:center;gap:8px;font-size:24px;font-weight:900;text-decoration:none;display:flex}.landing-logo span.material-symbols-rounded{color:var(--primary);font-size:26px}.landing-nav{align-items:center;gap:24px;display:flex}.landing-nav-link{color:var(--neutral-600);font-size:15px;font-weight:500;text-decoration:none;transition:color .2s}.landing-nav-link:hover{color:var(--primary)}.landing-auth-buttons{align-items:center;gap:12px;display:flex}.landing-hero{text-align:center;max-width:1000px;margin:0 auto;padding:100px 24px 60px;position:relative}.landing-badge{color:var(--primary);-webkit-backdrop-filter:blur(8px);background:#2563eb12;border:1px solid #2563eb26;border-radius:999px;align-items:center;gap:8px;margin-bottom:28px;padding:6px 16px;font-size:14px;font-weight:600;display:inline-flex;box-shadow:0 4px 12px #2563eb0d}html.dark .landing-badge{color:#38bdf8!important;background:#0ea5e91a!important;border-color:#0ea5e933!important}.landing-hero h1{font-family:var(--font-display);color:var(--neutral-900);letter-spacing:-.03em;margin:0 0 24px;font-size:clamp(36px,6vw,54px);font-weight:900;line-height:1.15}.landing-hero h1 span{background:linear-gradient(135deg,#2563eb 0%,#06b6d4 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.landing-hero p.hero-subtitle{color:var(--neutral-600);max-width:720px;margin:0 auto 40px;font-size:19px;line-height:1.65}.hero-ctas{justify-content:center;align-items:center;gap:18px;margin-bottom:80px;display:flex}.hero-ctas .primary-button{border-radius:999px!important;padding:14px 28px!important;font-size:16px!important;transition:transform .2s,box-shadow .2s!important;box-shadow:0 8px 20px #2563eb33!important}.hero-ctas .primary-button:hover{transform:translateY(-2px);box-shadow:0 12px 24px #2563eb4d!important}.hero-ctas .secondary-button{-webkit-backdrop-filter:blur(8px);border:1px solid var(--neutral-300)!important;background:#fff9!important;border-radius:999px!important;padding:14px 28px!important;font-size:16px!important;transition:transform .2s,background-color .2s!important}.hero-ctas .secondary-button:hover{transform:translateY(-2px);background:#fffc!important}html.dark .hero-ctas .secondary-button{background:#0f172a99!important;border-color:#334155cc!important}html.dark .hero-ctas .secondary-button:hover{background:#0f172acc!important}.landing-search-section{max-width:840px;margin:0 auto 90px;padding:0 24px}.landing-search-card{-webkit-backdrop-filter:blur(16px)saturate(180%);border-radius:var(--radius-xl);text-align:left;background:#ffffffb3;border:1px solid #e2e8f0cc;padding:40px;box-shadow:0 15px 35px -10px #0000000d,0 5px 15px -5px #00000005,inset 0 1px #fff9}html.dark .landing-search-card{background:#0f172a99!important;border-color:#33415580!important;box-shadow:0 15px 35px -10px #0000004d,inset 0 1px #ffffff0d!important}.landing-search-card h3{font-family:var(--font-display);margin:0 0 12px;font-size:26px;font-weight:800}.landing-search-card .dictionary-search-row{border:1px solid var(--neutral-300);background:#fff;border-radius:999px;align-items:center;gap:12px;padding:6px 6px 6px 18px;transition:border-color .2s,box-shadow .2s;display:flex;box-shadow:inset 0 2px 4px #00000005}.landing-search-card .dictionary-search-row:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px #2563eb26,inset 0 2px 4px #00000005}.landing-search-card .dictionary-search-row input{flex:1;box-shadow:none!important;background:0 0!important;border:none!important;margin:0!important;padding:0!important;font-size:16px!important}.landing-search-card .dictionary-search-row button{box-shadow:none!important;border-radius:999px!important;margin:0!important;padding:12px 28px!important;font-weight:700!important}html.dark .landing-search-card .dictionary-search-row{background:#0f172acc!important;border-color:#334155cc!important}.landing-features{max-width:1140px;margin:0 auto;padding:60px 24px 90px}.section-title{text-align:center;margin-bottom:56px}.section-title h2{font-family:var(--font-display);letter-spacing:-.02em;margin:0 0 16px;font-size:38px;font-weight:800}.section-title p{color:var(--neutral-600);max-width:600px;margin:0 auto;font-size:17px}.features-grid{grid-template-columns:repeat(3,1fr);gap:28px;display:grid}@media (width<=960px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.features-grid{grid-template-columns:1fr}}.feature-card{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-lg);background:#fff9;border:1px solid #e2e8f0cc;flex-direction:column;gap:18px;padding:32px;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #00000005,0 2px 4px -1px #00000003}.feature-card:after{content:"";background:0 0;width:100%;height:4px;transition:background .3s;position:absolute;top:0;left:0}.feature-card--indigo:after{background:linear-gradient(90deg,#6366f1,#4f46e5)}.feature-card--emerald:after{background:linear-gradient(90deg,#10b981,#059669)}.feature-card--violet:after{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.feature-card--amber:after{background:linear-gradient(90deg,#f59e0b,#d97706)}.feature-card--rose:after{background:linear-gradient(90deg,#f43f5e,#e11d48)}.feature-card--cyan:after{background:linear-gradient(90deg,#06b6d4,#0891b2)}.feature-card--double{grid-column:span 2}@media (width<=640px){.feature-card--double{grid-column:span 1}}.feature-card:hover{border-color:#6366f140;transform:translateY(-6px);box-shadow:0 20px 25px -5px #0000000d,0 10px 10px -5px #00000005}html.dark .feature-card{background:#1e293b73!important;border-color:#33415566!important;box-shadow:0 4px 6px -1px #0000001a!important}html.dark .feature-card:hover{border-color:#8b5cf64d!important;box-shadow:0 20px 25px -5px #0003,0 10px 10px -5px #0000001a!important}.feature-icon-wrapper{border-radius:var(--radius-md);justify-content:center;align-items:center;width:52px;height:52px;transition:transform .3s;display:flex}.feature-card:hover .feature-icon-wrapper{transform:scale(1.1)rotate(5deg)}.feature-card--indigo .feature-icon-wrapper{color:#6366f1;background:#6366f114}.feature-card--emerald .feature-icon-wrapper{color:#10b981;background:#10b98114}.feature-card--violet .feature-icon-wrapper{color:#8b5cf6;background:#8b5cf614}.feature-card--amber .feature-icon-wrapper{color:#f59e0b;background:#f59e0b14}.feature-card--rose .feature-icon-wrapper{color:#f43f5e;background:#f43f5e14}.feature-card--cyan .feature-icon-wrapper{color:#06b6d4;background:#06b6d414}html.dark .feature-card--indigo .feature-icon-wrapper{color:#818cf8;background:#6366f126}html.dark .feature-card--emerald .feature-icon-wrapper{color:#34d399;background:#10b98126}html.dark .feature-card--violet .feature-icon-wrapper{color:#a78bfa;background:#8b5cf626}html.dark .feature-card--amber .feature-icon-wrapper{color:#fbbf24;background:#f59e0b26}html.dark .feature-card--rose .feature-icon-wrapper{color:#fb7185;background:#f43f5e26}html.dark .feature-card--cyan .feature-icon-wrapper{color:#22d3ee;background:#06b6d426}.feature-card h4{font-family:var(--font-display);margin:0;font-size:19px;font-weight:700}.feature-card p{color:var(--neutral-600);margin:0;font-size:14.5px;line-height:1.55}.feature-header-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.bento-badge{text-transform:uppercase;letter-spacing:.08em;border-radius:999px;padding:4px 10px;font-size:10px;font-weight:700}.bento-badge--emerald{color:#10b981;background:#10b9811a;border:1px solid #10b98133}.bento-badge--violet{color:#8b5cf6;background:#8b5cf61a;border:1px solid #8b5cf633}.bento-badge--cyan{color:#06b6d4;background:#06b6d41a;border:1px solid #06b6d433}.landing-steps{color:#fff;background:#090d16;border-top:1px solid #ffffff08;border-bottom:1px solid #ffffff08;padding:90px 24px;position:relative}html.dark .landing-steps{background:#020617!important}.steps-container{max-width:1000px;margin:0 auto}.steps-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:28px;margin-top:56px;display:grid;position:relative}.step-item{text-align:center;border-radius:var(--radius-lg);background:#ffffff08;border:1px solid #ffffff0d;padding:36px 24px;transition:transform .3s,background-color .3s,border-color .3s;position:relative}.step-item:hover{background:#ffffff0d;border-color:#ffffff1a;transform:translateY(-5px);box-shadow:0 12px 24px -10px #0006}.step-number{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 24px;font-size:20px;font-weight:800;display:flex;box-shadow:0 0 20px #2563eb4d}.step-item h5{font-family:var(--font-display);color:#fff;margin:0 0 12px;font-size:19px;font-weight:700}.step-item p{color:#94a3b8;margin:0;font-size:14.5px;line-height:1.5}.landing-cta-section{max-width:940px;margin:90px auto;padding:0 24px}.cta-box{-webkit-backdrop-filter:blur(12px);color:#fff;border-radius:var(--radius-xl);text-align:center;background:linear-gradient(135deg,#1e293be6 0%,#0f172ae6 100%);border:1px solid #ffffff14;padding:70px 40px;position:relative;overflow:hidden;box-shadow:0 20px 40px -15px #0000004d,0 0 50px -10px #6366f126}html.dark .cta-box{background:linear-gradient(135deg,#1e293b73 0%,#0f172a73 100%)!important;border-color:#ffffff0d!important;box-shadow:0 20px 40px -15px #00000080,0 0 50px -10px #8b5cf626!important}.cta-box h2{font-family:var(--font-display);color:#fff;margin:0 0 20px;font-size:38px;font-weight:800}.cta-box p{color:#cbd5e1;max-width:640px;margin:0 auto 36px;font-size:18px;line-height:1.65}.landing-footer{border-top:1px solid var(--neutral-200);z-index:1;background:#fff;padding:80px 24px 40px;position:relative}html.dark .landing-footer{background:#090d16!important;border-top-color:#1e293b!important}.footer-container{text-align:left;grid-template-columns:2.2fr repeat(4,1fr);gap:40px;max-width:1200px;margin:0 auto 60px;display:grid}@media (width<=1024px){.footer-container{grid-template-columns:1fr 1fr;gap:32px}.footer-brand-column{grid-column:span 2}}@media (width<=550px){.footer-container{grid-template-columns:1fr;gap:24px}.footer-brand-column{grid-column:span 1}}.footer-brand-column{flex-direction:column;gap:16px;display:flex}.footer-logo{align-self:flex-start;display:inline-block}.footer-description{color:var(--neutral-600);max-width:380px;margin:0;font-size:14px;line-height:1.6}html.dark .footer-description{color:#94a3b8}.footer-contact-info{flex-direction:column;gap:10px;margin-top:4px;display:flex}.footer-contact-item{color:var(--neutral-600);align-items:flex-start;gap:8px;font-size:13.5px;line-height:1.5;display:flex}html.dark .footer-contact-item{color:#94a3b8}.footer-contact-item .icon{color:var(--primary);justify-content:center;align-items:center;margin-top:1px;font-size:18px;display:flex}html.dark .footer-contact-item .icon{color:#38bdf8}.footer-badges{margin-top:8px}.bocongthuong-badge{transition:transform .2s;display:inline-block}.bocongthuong-badge:hover{transform:scale(1.03)}.footer-socials{gap:12px;margin-top:8px;display:flex}.social-icon-btn{border:1px solid var(--neutral-300);width:38px;height:38px;color:var(--neutral-600);background:0 0;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.social-icon-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light);transform:translateY(-2px)}.social-icon-btn svg{display:block}html.dark .social-icon-btn{color:#94a3b8;border-color:#ffffff14}html.dark .social-icon-btn:hover{color:#38bdf8;background:#0ea5e91a;border-color:#38bdf8}.footer-links-column{flex-direction:column;gap:20px;display:flex}.footer-links-column h5{font-family:var(--font-display);color:var(--neutral-900);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:14px;font-weight:700}html.dark .footer-links-column h5{color:#f1f5f9}.footer-links-column ul{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.footer-links-column ul li a{color:var(--neutral-600);font-size:14px;font-weight:500;text-decoration:none;transition:color .2s}html.dark .footer-links-column ul li a{color:#94a3b8}.footer-links-column ul li a:hover{color:var(--primary)}html.dark .footer-links-column ul li a:hover{color:#38bdf8}.footer-bottom{border-top:1px solid var(--neutral-200);text-align:center;max-width:1200px;margin:0 auto;padding-top:30px}html.dark .footer-bottom{border-top-color:#ffffff0d}.footer-bottom p{color:var(--neutral-500);margin:0;font-size:13.5px}.auth-split-container{background:#fff;width:100%;min-height:100vh;display:flex}.auth-split-left{background-color:#0b1528;flex-direction:column;flex:1.2;display:flex;position:relative;overflow:hidden}.auth-split-container{background:#fff;width:100%;height:100vh;min-height:100vh;display:flex;overflow:hidden}.auth-split-left{background-color:#0b1528;flex-direction:column;flex:1.2;height:100%;display:flex;position:relative;overflow:hidden}.auth-split-image{object-fit:cover;opacity:.85;filter:brightness(.9);width:100%;height:100%}.auth-split-overlay{background:linear-gradient(#0b152866 0%,#0b1528cc 100%);flex-direction:column;justify-content:space-between;padding:36px;display:flex;position:absolute;inset:0}.auth-logo-link{color:#fff;font-family:var(--font-display);align-items:center;gap:10px;font-size:24px;font-weight:900;text-decoration:none;display:flex}.auth-logo-link span.material-symbols-rounded{color:#60a5fa;font-size:28px}.auth-quote{color:#fffffff2;max-width:440px;margin-bottom:12px}.auth-quote h3{font-family:var(--font-display);color:#fff;margin:0 0 8px;font-size:26px;font-weight:800;line-height:1.3}.auth-quote p{color:var(--neutral-300);margin:0;font-size:15px;line-height:1.5}.auth-split-right{background:#fff;flex:1;justify-content:center;align-items:center;height:100%;padding:24px 32px;display:flex;position:relative;overflow-y:auto}.auth-theme-toggle-container{z-index:10;position:absolute;top:20px;right:24px}.auth-split-form-wrapper{flex-direction:column;gap:20px;width:100%;max-width:380px;display:flex}.auth-split-header{text-align:center;flex-direction:column;align-items:center;gap:6px;display:flex}.auth-split-header h2{font-family:var(--font-display);color:var(--neutral-900);margin:0;font-size:26px;font-weight:800}.auth-split-header p.dictionary-intro{color:var(--neutral-500);margin:0;font-size:14px;line-height:1.4}.auth-logo-mobile{color:var(--neutral-900);font-family:var(--font-display);align-items:center;gap:8px;margin-bottom:8px;font-size:22px;font-weight:900;text-decoration:none;display:none}.auth-logo-mobile span.material-symbols-rounded{color:var(--primary);font-size:26px}.auth-split-form{flex-direction:column;gap:12px;display:flex}.auth-split-form label{color:var(--neutral-850);flex-direction:column;gap:4px;font-size:13px;font-weight:600;display:flex}.auth-split-form input{border-radius:var(--radius-lg);border:1px solid var(--neutral-300);background-color:var(--neutral-50);color:var(--neutral-900);margin-top:4px;padding:10px 14px;font-size:14px;transition:border-color .2s,box-shadow .2s,background-color .2s}.auth-split-form input:focus{border-color:var(--primary);background-color:#fff;outline:none;box-shadow:0 0 0 3px #2563eb26}.auth-split-form button{border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);color:#fff;cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;margin-top:4px;padding:12px;font-size:14px;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex}.auth-split-form button:hover{box-shadow:var(--shadow-premium-hover);transform:translateY(-1px)}.auth-split-form button:disabled{background:var(--neutral-300);cursor:not-allowed;box-shadow:none;transform:none}.auth-split-footer{text-align:center;color:var(--neutral-500);font-size:13px}.auth-split-footer p{margin:0}.auth-split-footer a{color:var(--primary);font-weight:700;text-decoration:none;transition:color .2s}.auth-split-footer a:hover{color:var(--primary-hover);text-decoration:underline}@media (width<=960px){.auth-split-left{display:none}.auth-logo-mobile{display:flex}.auth-split-right{padding:40px 24px}.auth-split-form-wrapper{max-width:380px;margin:0 auto}}@media (width<=480px){.auth-split-right{padding:32px 20px}}.password-input-container{align-items:center;width:100%;margin-top:6px;display:flex;position:relative}.password-input-container input{width:100%;margin-top:0!important;padding-right:46px!important}.password-toggle-btn{color:var(--neutral-500)!important;cursor:pointer!important;box-shadow:none!important;background:0 0!important;border:none!important;border-radius:0!important;justify-content:center!important;align-items:center!important;width:auto!important;height:auto!important;min-height:0!important;margin:0!important;padding:0!important;display:flex!important;position:absolute!important;top:50%!important;right:14px!important;transform:translateY(-50%)!important}.password-toggle-btn:hover{color:var(--neutral-800)!important;box-shadow:none!important;background:0 0!important;transform:translateY(-50%)!important}.password-toggle-btn span.material-symbols-rounded{color:var(--neutral-500)!important;font-size:20px!important}.auth-remember-me{justify-content:space-between;align-items:center;margin-top:-8px;margin-bottom:8px;display:flex}.auth-remember-me label.checkbox-label{color:var(--neutral-600);cursor:pointer;-webkit-user-select:none;user-select:none;flex-direction:row;align-items:center;gap:8px;margin:0;font-size:14px;font-weight:500;display:flex}.auth-remember-me label.checkbox-label input[type=checkbox]{width:15px;height:15px;accent-color:var(--primary);cursor:pointer;margin:0}.auth-divider{text-align:center;color:var(--neutral-400);-webkit-user-select:none;user-select:none;align-items:center;margin:8px 0;font-size:13px;display:flex}.auth-divider:before,.auth-divider:after{content:"";border-bottom:1px solid var(--neutral-200);flex:1}.auth-divider:not(:empty):before{margin-right:12px}.auth-divider:not(:empty):after{margin-left:12px}.google-auth-btn{border-radius:var(--radius-lg)!important;border:1px solid var(--neutral-300)!important;color:var(--neutral-800)!important;cursor:pointer!important;box-shadow:none!important;background:#fff!important;justify-content:center!important;align-items:center!important;gap:12px!important;width:100%!important;margin-top:0!important;padding:12px 16px!important;font-size:15px!important;font-weight:600!important;transition:border-color .2s,box-shadow .2s!important;display:flex!important}.google-auth-btn:hover{border-color:var(--neutral-400)!important;background:#fff!important;transform:none!important;box-shadow:0 1px 3px #0000000d!important}.google-icon{flex-shrink:0;width:20px;height:20px}h2{font-family:var(--font-display);color:var(--neutral-900);font-weight:800}h3,h4,h5{font-family:var(--font-display);color:var(--neutral-900)}label{color:var(--neutral-700);gap:8px;margin:16px 0;display:grid}input,textarea,select{border:1px solid var(--neutral-300);border-radius:var(--radius-md);width:100%;font-family:var(--font-sans);background:#fff;padding:12px 14px;font-size:15px;transition:all .2s}input:focus,textarea:focus,select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb1f}button{background:var(--primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:0;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:15px;font-weight:700;transition:all .2s;display:inline-flex}button:hover{background:var(--primary-hover);box-shadow:0 4px 12px #2563eb40}button:disabled{background:var(--neutral-400);cursor:wait;box-shadow:none}.secondary-button{background:var(--neutral-200);color:var(--neutral-800)}.secondary-button:hover{background:var(--neutral-300);box-shadow:none}.primary-button{background:var(--primary);color:#fff;border-radius:var(--radius-md);align-items:center;gap:8px;padding:12px 20px;font-weight:700;text-decoration:none;display:inline-flex}.primary-button:hover{background:var(--primary-hover);box-shadow:0 4px 12px #2563eb40}.dictionary-page{overflow:hidden}.dictionary-intro{color:var(--neutral-600);margin:10px 0 22px;font-size:16px;line-height:1.6}.dictionary-page form label{font-weight:700}.dictionary-search-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.dictionary-hint{color:var(--neutral-400);margin:8px 0 0;font-size:14px;line-height:1.5}.empty-state,.loading-state{border:1px dashed var(--neutral-300);background:var(--neutral-50);border-radius:var(--radius-lg);color:var(--neutral-600);text-align:center;margin-top:20px;padding:24px}.empty-state strong{color:var(--neutral-800);margin-top:8px;display:block}.empty-state p{margin:4px 0 12px}.dictionary-result{border:1px solid var(--neutral-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#fff;margin-top:28px;padding:28px}.dictionary-result h3{font-family:var(--font-display);color:var(--neutral-900);margin:4px 0;font-size:38px;font-weight:800}.dictionary-result h4{margin:0 0 12px;font-size:18px;font-weight:700}.dictionary-result ul{margin:0;padding-left:20px}.dictionary-result li{margin-bottom:8px;line-height:1.6}.dictionary-result audio{max-width:100%;margin-top:10px;display:block}.eyebrow{color:var(--primary);letter-spacing:.06em;text-transform:uppercase;margin:0 0 8px;font-size:13px;font-weight:800}.ipa{color:var(--neutral-600);font-size:16px;font-weight:700}.fallback-note{border-radius:var(--radius-sm);color:#92400e;background:#fffbeb;border-left:4px solid #f59e0b;margin:16px 0;padding:12px 14px;line-height:1.55}.result-block{border-top:1px solid var(--neutral-100);margin-top:24px;padding-top:20px}.definition-meta{color:var(--neutral-400);margin:6px 0;font-size:14px}.definition-examples{background:var(--neutral-50);border-radius:var(--radius-sm);margin-top:10px;padding:12px 16px}.definition-examples strong{color:var(--neutral-700);margin-bottom:6px;font-size:14px;display:block}.definition-examples ul{list-style-type:none;padding-left:0!important}.definition-examples li{font-size:14px;margin-bottom:4px!important}.error-message{color:#991b1b;border-radius:var(--radius-sm);background:#fef2f2;border-left:4px solid #dc2626;margin:16px 0;padding:12px 14px;line-height:1.55}.save-word-panel{border:1px solid var(--neutral-200);background:var(--neutral-50);border-radius:var(--radius-md);flex-wrap:wrap;align-items:center;gap:12px;margin-top:24px;padding:20px;display:flex}.save-word-panel p{color:var(--neutral-600);flex-basis:100%;margin:0 0 10px}.save-word-panel a,.cta-link{color:var(--primary);font-weight:700;text-decoration:none}.saved-word-list{gap:20px;margin-top:24px;display:grid}.saved-word-card{border:1px solid var(--neutral-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;padding:24px}.saved-word-card header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.saved-word-card h3{margin:4px 0;font-size:30px;font-weight:800}.saved-word-card audio{max-width:100%;margin:10px 0;display:block}.pronunciation-block ul{flex-wrap:wrap;gap:12px 24px;margin:0;padding:0;list-style:none;display:flex}.pronunciation-block li{align-items:center;gap:8px;display:flex}.pronunciation-label{color:var(--neutral-700);text-transform:uppercase;font-size:13px;font-weight:800}.pronunciation-block audio{max-width:220px;height:30px;margin:0}.pronunciation-block.compact{margin:12px 0}.pronunciation-block.compact li{font-size:14px}.pronunciation-block.compact audio{max-width:180px;height:28px}.ai-helper-panel{border:1px solid var(--neutral-200);border-radius:var(--radius-lg);background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);margin-top:24px;padding:24px}.ai-helper-panel.compact{border-radius:var(--radius-md);margin-top:14px;padding:16px}.ai-helper-panel h4{font-family:var(--font-display);color:var(--neutral-900);align-items:center;gap:8px;margin:0 0 12px;font-size:18px;display:flex}.ai-helper-panel textarea{resize:vertical;background:#fff;min-height:80px;margin-top:8px}.ai-helper-panel button{background:linear-gradient(135deg,#4f46e5 0%,#3b82f6 100%);box-shadow:0 4px 12px #4f46e533}.ai-helper-panel button:hover{background:linear-gradient(135deg,#4338ca 0%,#2563eb 100%)}.ai-result{border:1px solid var(--neutral-200);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);background:#fff;margin-top:20px;padding:20px}.ai-result h5{font-family:var(--font-display);color:#4f46e5;margin:0 0 12px;font-size:16px}.content .dashboard-page{box-shadow:none!important;background:0 0!important;border:none!important;padding:0!important}.dashboard-page{gap:28px;animation:.4s ease-out fadeIn;display:grid}.daily-study-card{background:var(--neutral-50,#f9fafb);border:none;border-left:3px solid var(--primary);border-radius:var(--radius-md);padding:24px 28px}.daily-study-card h3{color:var(--neutral-800);align-items:center;gap:8px;margin:0 0 10px;font-size:18px;font-weight:700;display:flex}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin:4px 0;display:grid}.stats-grid article{background:var(--neutral-50,#f9fafb);border-radius:var(--radius-md);box-shadow:none;border:none;padding:20px;transition:background .2s}.stats-grid article:hover{background:var(--neutral-100,#f3f4f6)}.stats-grid strong{color:var(--primary);font-size:32px;font-family:var(--font-display);margin-bottom:2px;font-weight:800;line-height:1.1;display:block}.stats-grid span{color:var(--neutral-500);font-size:13px;font-weight:600}.study-actions{flex-wrap:wrap;align-items:center;gap:12px;margin:16px 0;display:flex}.mastery-badge{text-transform:uppercase;letter-spacing:.02em;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:800;display:inline-flex}.mastery-new{color:#475569;background:#f1f5f9}.mastery-need_practice{color:#991b1b;background:#fee2e2}.mastery-learning{color:#92400e;background:#fef3c7}.mastery-remembered{color:#166534;background:#dcfce7}.active-filter{outline:2px solid var(--primary)}.review-summary{text-align:center;gap:16px;padding:40px 20px;display:grid}.material-symbols-rounded{letter-spacing:normal;text-transform:none;white-space:nowrap;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased;font-variation-settings:"FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;direction:ltr;flex-shrink:0;justify-content:center;align-items:center;width:1.2em;height:1.2em;font-family:Material Symbols Rounded;font-size:20px;font-style:normal;font-weight:400;line-height:1;display:inline-flex;overflow:hidden}.auth-status{border-bottom:1px solid var(--neutral-200);z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb;border-top:none;border-left:none;border-right:none;border-radius:0;margin-bottom:32px;padding:16px 0;position:sticky;top:0;box-shadow:0 4px 20px -2px #0f172a05}.auth-status-inner{width:100%;max-width:1200px;padding:0 var(--content-padding-x);box-sizing:border-box;justify-content:space-between;align-items:center;gap:20px;margin:0 auto;display:flex}.topbar-bell-btn{cursor:pointer;justify-content:center;align-items:center;padding:8px;display:flex;position:relative;box-shadow:none!important;color:var(--neutral-600)!important;background:0 0!important;border:none!important;outline:none!important;transition:none!important;transform:none!important}.topbar-bell-btn:hover,.topbar-bell-btn:active,.topbar-bell-btn:focus{box-shadow:none!important;color:var(--neutral-600)!important;background:0 0!important;border:none!important;outline:none!important;transform:none!important}.topbar-bell-btn:hover .material-symbols-rounded{animation:.6s bell-shake}@keyframes bell-shake{0%{transform:rotate(0)}15%{transform:rotate(10deg)}30%{transform:rotate(-10deg)}45%{transform:rotate(5deg)}60%{transform:rotate(-5deg)}75%{transform:rotate(2deg)}90%{transform:rotate(-2deg)}to{transform:rotate(0)}}.topbar-bell-btn .material-symbols-rounded{transform-origin:top;font-size:22px}.bell-badge{color:#fff;background:#ef4444;border:2px solid #fff;border-radius:99px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:1;display:flex;position:absolute;top:4px;right:4px}.topbar-bell-wrapper{justify-content:center;align-items:center;display:flex;position:relative}.bell-dropdown-menu{border:1px solid var(--neutral-200);border-radius:var(--radius-md);box-shadow:var(--shadow-premium);opacity:0;visibility:hidden;z-index:999;background:#fff;flex-direction:column;min-width:320px;padding:0;transition:all .22s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:calc(100% + 12px);right:0;overflow:visible;transform:translateY(10px)}.bell-dropdown-menu.open{opacity:1;visibility:visible;transform:translateY(0)}.bell-dropdown-menu:before{content:"";z-index:1001;border-bottom:12px solid #fff;border-left:8px solid #0000;border-right:8px solid #0000;width:0;height:0;position:absolute;bottom:100%;right:12px}.bell-dropdown-menu:after{content:"";border-left:9px solid #0000;border-right:9px solid #0000;border-bottom:13px solid var(--neutral-200);z-index:1000;width:0;height:0;position:absolute;bottom:100%;right:11px}.bell-menu-header{border-bottom:1px solid var(--neutral-100);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.bell-menu-header h4{color:var(--neutral-900);margin:0;font-size:15px;font-weight:700}.mark-read-all{color:var(--primary);cursor:pointer;font-size:12px;font-weight:600;transition:opacity .15s}.mark-read-all:hover{opacity:.8}.bell-menu-list{flex-direction:column;max-height:280px;display:flex;overflow-y:auto}.bell-menu-item{border-bottom:1px solid var(--neutral-100);cursor:pointer;gap:12px;padding:12px 16px;text-decoration:none;transition:background-color .2s;display:flex}.bell-menu-item:hover{background-color:var(--neutral-50)}.bell-menu-item.unread{background-color:var(--primary-light)}.bell-menu-item.unread:hover{background-color:#2563eb14}.bell-item-icon{background:var(--neutral-100);width:32px;height:32px;color:var(--neutral-600);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.bell-item-icon span{font-size:18px}.bell-menu-item.unread .bell-item-icon{color:var(--primary);box-shadow:var(--shadow-sm);background:#fff}.bell-item-content{text-align:left;flex-direction:column;gap:2px;min-width:0;display:flex}.bell-item-text{color:var(--neutral-700);word-break:break-word;margin:0;font-size:13px;line-height:1.4}.bell-item-time{color:var(--neutral-400);font-size:11px}.bell-menu-footer{text-align:center;border-top:1px solid var(--neutral-100);color:var(--primary);cursor:pointer;background-color:var(--neutral-50);padding:12px 16px;font-size:13px;font-weight:600;transition:opacity .15s}.bell-menu-footer:hover{opacity:.8}.topbar-divider{background:var(--neutral-200);flex-shrink:0;width:1px;height:28px}.topbar-user-info{flex-direction:column;align-items:flex-end;gap:1px;min-width:0;display:flex}.topbar-user-name{color:var(--neutral-800);white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-size:14px;font-weight:700;line-height:1.2;overflow:hidden}.topbar-user-role{color:var(--neutral-500);white-space:nowrap;font-size:12px;font-weight:500;line-height:1.2}.user-avatar-trigger{background:linear-gradient(135deg, var(--primary) 0%, #3b82f6 100%);color:#fff;cursor:pointer;width:40px;height:40px;box-shadow:0 0 0 2px var(--neutral-200), var(--shadow-sm);-webkit-user-select:none;user-select:none;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;font-size:16px;font-weight:700;transition:all .22s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.user-avatar-trigger:hover{transform:none}.user-avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%;display:block}.profile-dropdown-menu{border:1px solid var(--neutral-200);border-radius:var(--radius-md);box-shadow:var(--shadow-premium);opacity:0;visibility:hidden;z-index:999;background:#fff;flex-direction:column;gap:12px;min-width:280px;padding:16px;transition:all .22s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:calc(100% + 15px);right:0;overflow:visible;transform:translateY(10px)}.profile-dropdown-menu.open{opacity:1;visibility:visible;transform:translateY(0)}.profile-dropdown-menu:before{content:"";z-index:1001;border-bottom:12px solid #fff;border-left:8px solid #0000;border-right:8px solid #0000;width:0;height:0;position:absolute;bottom:100%;right:10px}.profile-dropdown-menu:after{content:"";border-left:9px solid #0000;border-right:9px solid #0000;border-bottom:13px solid var(--neutral-200);z-index:1000;width:0;height:0;position:absolute;bottom:100%;right:9px}.profile-menu-header{border-bottom:1px solid var(--neutral-100);text-align:left;margin-bottom:4px;padding-bottom:12px}.profile-menu-header p.menu-label{color:var(--neutral-400);text-transform:uppercase;letter-spacing:.05em;margin:0 0 4px;font-size:11px;font-weight:600}.profile-menu-header p.menu-email{color:var(--neutral-800);word-break:break-all;margin:0;font-size:14px;font-weight:700}.profile-menu-item{color:var(--neutral-700);border-radius:var(--radius-sm);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.profile-menu-item:hover{background:var(--neutral-50);color:var(--neutral-900)}.profile-menu-item.logout-btn{color:#dc2626;background:#fef2f2}.profile-menu-item.logout-btn:hover{color:#b91c1c;background:#fee2e2}@media (width<=1024px){:root{--content-padding-x:24px;--content-padding-y:24px}.app-shell{grid-template-columns:1fr}.sidebar{border-bottom:1px solid #ffffff0d;border-right:none;padding:20px}.sidebar nav{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px}.sidebar a{text-align:center;justify-content:center;padding:10px;font-size:14px}}@media (width<=768px){.landing-hero h1{font-size:28px}.landing-hero p.hero-subtitle{font-size:16px}.hero-ctas{flex-direction:column;align-items:stretch;max-width:320px;margin:0 auto 40px}.landing-search-card{padding:24px}.dictionary-search-row{grid-template-columns:1fr}.dictionary-search-row button{width:100%}.landing-header{flex-direction:column;gap:16px;padding:16px}.landing-nav{flex-wrap:wrap;justify-content:center;gap:16px 20px}}.btn-filter-all:before{content:"list"}.btn-filter-due:before{content:"pending_actions"}.btn-filter-practice:before{content:"psychology"}.btn-filter-remembered:before{content:"verified"}.btn-need-practice:before{content:"close"}.btn-remembered:before{content:"check"}.btn-active-tab:before{content:"check_circle"}.btn-archived-tab:before{content:"archive"}.btn-save-class:before,.btn-save-session:before{content:"save"}.btn-join-class:before{content:"group_add"}.btn-filter-all:before,.btn-filter-due:before,.btn-filter-practice:before,.btn-filter-remembered:before,.btn-need-practice:before,.btn-remembered:before,.btn-active-tab:before,.btn-archived-tab:before,.btn-save-class:before,.btn-save-session:before,.btn-join-class:before{text-transform:none;letter-spacing:normal;word-wrap:normal;white-space:nowrap;-webkit-font-smoothing:antialiased;direction:ltr;justify-content:center;align-items:center;margin-right:8px;font-family:Material Symbols Rounded;font-size:20px;font-style:normal;font-weight:400;line-height:1;display:inline-flex}.topbar-logo-wrapper{flex:1;justify-content:flex-start;display:flex}.topbar-nav-wrapper{flex:none;justify-content:center;display:flex}.topbar-right-wrapper{flex:1;justify-content:flex-end;align-items:center;gap:20px;display:flex}.topbar-nav{align-items:center;gap:6px;display:flex}.topbar-nav-link{color:var(--neutral-900);text-transform:uppercase;letter-spacing:.05em;opacity:1;align-items:center;padding:6px 12px;font-size:13px;font-weight:600;text-decoration:none;transition:opacity .15s;display:flex;background:0 0!important;border:none!important}.topbar-nav-link:hover{color:var(--neutral-900)!important;opacity:.65!important;background:0 0!important;border:none!important}.topbar-nav-link.active{font-weight:700;color:var(--neutral-900)!important;opacity:1!important;background:0 0!important;border:none!important}.topbar-nav-link .material-symbols-rounded{display:none!important}.launchpad-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:12px;display:grid}.launchpad-card{background:var(--neutral-50,#f9fafb);border-radius:var(--radius-md);color:inherit;box-shadow:none;text-align:left;border:none;flex-direction:column;gap:10px;padding:22px;text-decoration:none;transition:background .2s;display:flex;position:relative;overflow:hidden}.launchpad-card:hover{background:var(--neutral-100,#f3f4f6)}.launchpad-card:before{content:"";background:0 0;border-radius:2px;width:3px;height:100%;transition:background .2s;position:absolute;top:0;left:0}.launchpad-card:hover:before{background:var(--primary)}.launchpad-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;transition:all .2s;display:flex}.launchpad-card:hover .launchpad-icon{transform:scale(1.05)}.launchpad-card h4{color:var(--neutral-800);margin:0;font-size:15px;font-weight:700;transition:color .2s}.launchpad-card:hover h4{color:var(--primary)}.launchpad-card p{color:var(--neutral-500);margin:0;font-size:13px;line-height:1.5}.launchpad-card:hover .launchpad-icon.bg-blue{box-shadow:0 0 12px #2563eb26}.launchpad-card:hover .launchpad-icon.bg-purple{box-shadow:0 0 12px #9333ea26}.launchpad-card:hover .launchpad-icon.bg-pink{box-shadow:0 0 12px #db277726}.launchpad-card:hover .launchpad-icon.bg-teal{box-shadow:0 0 12px #0d948826}.launchpad-card:hover .launchpad-icon.bg-amber{box-shadow:0 0 12px #d9770626}.launchpad-card:hover .launchpad-icon.bg-red{box-shadow:0 0 12px #dc262626}.launchpad-card:hover .launchpad-icon.bg-indigo{box-shadow:0 0 12px #4f46e526}.launchpad-card:hover .launchpad-icon.bg-slate{box-shadow:0 0 12px #47556926}.topbar-toggle-btn{display:none!important}@media (width<=1024px){.topbar-nav-wrapper{display:none!important}.topbar-toggle-btn{cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;margin-left:8px;transition:background-color .2s;box-shadow:none!important;color:var(--neutral-700)!important;background:0 0!important;border:none!important;display:flex!important}.topbar-toggle-btn:hover{background-color:var(--neutral-100)!important}.topbar-toggle-btn span{font-size:26px}.auth-status{padding:16px 0!important}}@media (width<=768px){:root{--content-padding-x:16px;--content-padding-y:16px}.auth-status{padding:12px 0!important}.topbar-user-info,.topbar-divider{display:none!important}input,textarea,select,.form-control,.search-input{font-size:16px!important}.bell-dropdown-menu{min-width:290px;right:-70px}.bell-dropdown-menu:before{right:81px!important}.bell-dropdown-menu:after{right:80px!important}}.mobile-nav-drawer{z-index:10000;box-sizing:border-box;background:#fff;flex-direction:column;width:100vw;height:100vh;padding:24px;display:none;position:fixed;top:0;right:0}.mobile-nav-drawer.open{animation:.35s cubic-bezier(.16,1,.3,1) forwards slideLeftDrawer;display:flex}@keyframes slideLeftDrawer{0%{transform:translate(100%)}to{transform:translate(0)}}@media (width>=1025px){.mobile-nav-drawer{display:none!important}}.drawer-header{justify-content:space-between;align-items:center;margin-bottom:40px;display:flex}.drawer-close-btn{cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:background-color .2s;display:flex;box-shadow:none!important;color:var(--neutral-700)!important;background:0 0!important;border:none!important}.drawer-close-btn:hover{background-color:var(--neutral-100)!important}.drawer-close-btn span{font-size:28px}.drawer-nav{flex-direction:column;gap:16px;display:flex}.drawer-nav .topbar-nav-link{border-radius:var(--radius-md);text-align:left;box-sizing:border-box;width:100%;display:block;padding:12px 16px!important;font-size:18px!important}.global-search-backdrop{z-index:9999;background:#0f172a73;justify-content:center;align-items:center;width:100vw;height:100vh;padding:16px;animation:.2s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.global-search-modal{border-radius:var(--radius-xl);background:#fff;border:none;flex-direction:column;gap:16px;width:100%;max-width:680px;padding:24px;animation:.25s cubic-bezier(.34,1.56,.64,1) slideDown;display:flex;overflow:hidden;box-shadow:0 20px 50px #0000001f}.modal-header{color:var(--neutral-800);border-bottom:none;justify-content:space-between;align-items:center;padding-bottom:4px;display:flex}.close-modal-btn{background:var(--neutral-50);border:1px solid var(--neutral-200);cursor:pointer;width:36px;min-width:36px;height:36px;min-height:36px;color:var(--neutral-600);box-sizing:border-box;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex}.close-modal-btn:hover{color:#dc2626;background:#fef2f2;border-color:#fee2e2}.global-search-trigger{box-shadow:var(--shadow-sm)}.global-search-trigger:hover{box-shadow:0 0 0 1px var(--primary-glow);border-color:var(--primary)!important;color:var(--neutral-700)!important;background:#fff!important}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.global-search-trigger{justify-content:center;width:40px;height:40px;border-radius:50%!important;min-width:40px!important;padding:0!important}.global-search-trigger span{display:none!important}.global-search-modal{gap:12px;max-width:95%;padding:16px}}.draggable-search-bubble{z-index:9999;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;display:flex;position:fixed}.draggable-search-bubble.dragging{cursor:grabbing;transition:transform .1s,box-shadow .1s;transform:scale(1.1)}.draggable-search-bubble:hover:not(.dragging){transform:translateY(-4px)scale(1.05)}.draggable-search-bubble:active{cursor:grabbing}.bubble-inner{background:var(--primary);color:#fff;z-index:2;border:none;border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;box-shadow:0 4px 12px #2563eb59}.bubble-inner span{font-variation-settings:"FILL" 1, "wght" 400, "GRAD" 0, "opsz" 48;font-size:28px!important}.bubble-pulse-ring{display:none}.global-search-modal .dictionary-result{box-shadow:none!important;background:0 0!important;border:none!important;margin-top:12px!important;padding:12px 0 0!important}.global-search-modal .ai-helper-panel{background:var(--neutral-50)!important;border-radius:var(--radius-md)!important;border:none!important;margin-top:12px!important;padding:16px!important}.global-search-modal .ai-result{box-shadow:none!important;background:0 0!important;border:none!important;padding:8px 0 0!important}.global-search-modal .save-word-panel{background:var(--neutral-50)!important;border-radius:var(--radius-md)!important;border:none!important;margin-top:12px!important;padding:16px!important}.draggable-ai-bubble{z-index:9999;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .25s cubic-bezier(.25,1,.5,1),box-shadow .2s;display:flex;position:fixed}.draggable-ai-bubble:hover{transform:scale(1.06)}.draggable-ai-bubble:active{transform:scale(.95)}.draggable-ai-bubble .bubble-inner{background:#4f46e5!important;border:none!important;box-shadow:0 4px 12px #4f46e54d!important}.draggable-ai-bubble.active .bubble-inner{background:var(--neutral-700)!important;box-shadow:0 4px 12px #00000026!important}.draggable-ai-bubble .bubble-inner span{transition:transform .25s cubic-bezier(.25,1,.5,1)}.draggable-ai-bubble.active .bubble-inner span{transform:rotate(90deg)}.ai-chat-widget{border-radius:var(--radius-xl);z-index:10001;border:1px solid var(--neutral-200);transform-origin:100% 100%;background:#fff;flex-direction:column;width:380px;max-width:calc(100vw - 48px);height:520px;max-height:calc(100vh - 140px);animation:.28s cubic-bezier(.34,1.56,.64,1) forwards widget-fade-in;display:flex;position:fixed;bottom:96px;right:24px;overflow:hidden;box-shadow:0 12px 40px #0000001f}@keyframes widget-fade-in{0%{opacity:0;transform:translateY(40px)scale(.3)}to{opacity:1;transform:translateY(0)scale(1)}}.widget-header{background:var(--primary);color:#fff;border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.widget-header-title{align-items:center;gap:8px;font-size:15px;font-weight:700;display:flex}.widget-close-btn{color:#ffffffd9;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.widget-close-btn:hover{color:#fff;background:#ffffff26}.widget-body{background:#f8fafc;flex-direction:column;flex:1;display:flex;overflow:hidden}.widget-messages-scroll{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.widget-message-wrapper{gap:8px;max-width:85%;display:flex}.widget-message-wrapper.user{flex-direction:row-reverse;align-self:flex-end}.widget-message-wrapper.assistant{align-self:flex-start}.widget-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;display:flex}.widget-avatar.user{background:var(--primary-light);color:var(--primary)}.widget-avatar.assistant{color:#475569;background:#e2e8f0}.widget-message-bubble{word-break:break-word;border-radius:18px;padding:10px 14px;font-size:13.5px;line-height:1.45}.widget-message-wrapper.user .widget-message-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.widget-message-wrapper.assistant .widget-message-bubble{color:var(--neutral-800);border:1px solid var(--neutral-200);background:#fff;border-bottom-left-radius:4px}.widget-presets{white-space:nowrap;border-top:1px solid var(--neutral-100);scrollbar-width:none;background:#f8fafc;gap:8px;padding:8px 16px;display:flex;overflow-x:auto}.widget-presets::-webkit-scrollbar{display:none}.widget-preset-btn{border:1px solid var(--neutral-200);color:var(--neutral-700);cursor:pointer;background:#fff;border-radius:16px;flex-shrink:0;align-items:center;gap:4px;padding:6px 12px;font-size:11.5px;transition:all .2s;display:flex}.widget-preset-btn:hover{background:var(--primary-light);border-color:var(--primary-light);color:var(--primary)}.widget-input-area{border-top:1px solid var(--neutral-200);background:#fff;align-items:flex-end;gap:8px;padding:12px;display:flex}.widget-input{border:1px solid var(--neutral-200);resize:none;border-radius:20px;outline:none;flex:1;max-height:80px;padding:8px 14px;font-size:13.5px;line-height:1.4;transition:border-color .2s}.widget-input:focus{border-color:var(--primary)}.widget-send-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background-color .2s,transform .1s;display:flex}.widget-send-btn:hover:not(:disabled){background:var(--primary-hover)}.widget-send-btn:active:not(:disabled){transform:scale(.95)}.widget-send-btn:disabled{background:var(--neutral-200);color:var(--neutral-400);cursor:not-allowed}.typing-indicator{align-items:center;gap:4px;padding:4px 8px;display:flex}.typing-dot{background:var(--neutral-400);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite both typingBounce}.typing-dot:first-child{animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}@keyframes typingBounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.floating-search-pill-container{z-index:9999;-webkit-user-select:none;user-select:none;touch-action:none;box-sizing:border-box;transition:width .35s cubic-bezier(.25,1,.5,1),left .35s cubic-bezier(.25,1,.5,1),right .35s cubic-bezier(.25,1,.5,1),transform .25s cubic-bezier(.25,1,.5,1),box-shadow .25s,opacity .2s,background-color .25s,border-color .25s;position:fixed}.floating-search-pill-container.expanded{border:1px solid var(--neutral-200);cursor:grab;background:#fff;border-radius:22px;align-items:center;width:250px;height:44px;display:flex;box-shadow:0 4px 16px #0000000f}.floating-search-pill-container.expanded:focus-within{border-color:var(--primary)!important;box-shadow:0 0 0 3px var(--primary-glow), 0 4px 16px #00000014!important}.floating-search-pill-container.expanded.dragging{cursor:grabbing;transform:scale(1.02);box-shadow:0 8px 24px #0000001a}.floating-search-pill-container.expanded:hover:not(.dragging){transform:translateY(-2px);box-shadow:0 6px 20px #00000014}.pill-content-wrapper{box-sizing:border-box;justify-content:space-between;align-items:center;width:100%;height:100%;padding:0 12px 0 16px;display:flex}.pill-search-trigger{color:var(--neutral-500);flex:1;align-items:center;gap:8px;font-size:13.5px;display:flex}.pill-search-trigger span.material-symbols-rounded{color:var(--neutral-400);font-size:18px}.pill-search-hotkey{background:var(--neutral-100);color:var(--neutral-600);border-radius:4px;margin-left:auto;padding:2px 6px;font-size:9px;font-weight:700}.pill-collapse-btn{box-shadow:none!important;color:var(--neutral-400)!important;cursor:pointer!important;background:0 0!important;border:none!important;border-radius:50%!important;flex-shrink:0!important;justify-content:center!important;align-items:center!important;width:28px!important;min-width:28px!important;height:28px!important;margin-left:8px!important;padding:0!important;transition:background-color .25s,color .25s!important;display:flex!important}.pill-collapse-btn:hover{background:var(--neutral-50)!important;color:var(--neutral-700)!important;box-shadow:none!important}.floating-search-pill-container.collapsed{border:1px solid var(--neutral-200);background:#fff;justify-content:center;align-items:center;width:36px;height:44px;display:flex;overflow:hidden;box-shadow:0 4px 12px #0000000d}.floating-search-pill-container.collapsed.right{border-right:none;border-top-left-radius:22px;border-bottom-left-radius:22px;transform:translate(1px)}.floating-search-pill-container.collapsed.left{border-left:none;border-top-right-radius:22px;border-bottom-right-radius:22px;transform:translate(-1px)}.floating-search-pill-container.collapsed:hover{transform:translate(0);background:var(--neutral-50)!important}.pill-expand-arrow-btn{box-shadow:none!important;color:var(--neutral-500)!important;cursor:pointer!important;background:0 0!important;border:none!important;flex-shrink:0!important;justify-content:center!important;align-items:center!important;width:100%!important;min-width:0!important;height:100%!important;padding:0!important;transition:color .25s!important;display:flex!important}.pill-expand-arrow-btn:hover{color:var(--neutral-800)!important;box-shadow:none!important;background:0 0!important}.pill-expand-arrow-btn span.material-symbols-rounded{font-size:20px}.pill-search-input{color:var(--neutral-800);width:100%;font-size:13.5px;box-shadow:none!important;-webkit-user-select:text!important;user-select:text!important;background:0 0!important;border:none!important;border-radius:0!important;outline:none!important;height:24px!important;margin:0!important;padding:0!important;line-height:24px!important}.pill-search-input:focus{box-shadow:none!important;background:0 0!important;border:none!important;outline:none!important}.pill-search-input::placeholder{color:var(--neutral-400)}.card-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;display:grid}.card-grid.large{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}.card-grid.compact{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.admin-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:24px;display:grid}.ai-chat-container{grid-template-columns:1fr 2.5fr;gap:24px;display:grid}.speaking-container{grid-template-columns:1.2fr 1fr;gap:32px;display:grid}.teacher-details-columns{grid-template-columns:1fr 2fr;gap:32px;display:grid}.topbar-left{align-items:center;gap:16px;display:flex}.topbar-right{align-items:center;gap:20px;display:flex}@media (width<=768px){.content section{border-radius:var(--radius-md)!important;padding:16px!important}.features-grid{grid-template-columns:1fr!important;gap:20px!important}.launchpad-grid,.card-grid,.card-grid.large,.card-grid.compact,.admin-grid,.ai-chat-container{grid-template-columns:1fr!important;gap:16px!important}.speaking-container{grid-template-columns:1fr!important;gap:20px!important}.teacher-details-columns{grid-template-columns:1fr!important;gap:24px!important}.speaking-practice-page{padding:16px!important}.speaking-visualizer-card{padding:20px 16px!important}.state-machine-card{padding:16px!important}.saved-word-card header{flex-wrap:wrap!important;gap:12px!important}.saved-word-card{padding:16px!important}.saved-word-card h3{font-size:24px!important}.word-card{padding:16px!important}.topbar-right-wrapper{gap:12px!important}.topbar-logo img{height:26px!important}}@media (width<=576px){.auth-status-inner .topbar-left{display:none!important}.auth-status-inner{justify-content:center!important}}.speaking-practice-page{border-radius:var(--radius-lg);border:1px solid var(--neutral-200);background:#fff;padding:32px}.speaking-visualizer-card{background:var(--neutral-50);border-radius:var(--radius-md);border:1px solid var(--neutral-100);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:32px 24px;display:flex}.spec-info-card{border-top:1px solid var(--neutral-200);text-align:left;width:100%;color:var(--neutral-700);margin-top:24px;padding-top:20px;font-size:14px}.spec-info-card p{margin:0 0 8px;line-height:1.5}.spec-info-card p:last-child{margin-bottom:0}.spec-info-card p span.material-symbols-rounded{vertical-align:text-bottom;margin-right:6px;display:inline-flex}.state-machine-card{border:1px solid var(--neutral-200);border-radius:var(--radius-md);flex-direction:column;gap:16px;padding:24px;display:flex}.content-wrapper{box-sizing:border-box;width:100%;max-width:100%;overflow-x:hidden}.classes-header-actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.classes-header-actions .filter-row{gap:8px;display:flex}@media (width<=576px){.classes-header-actions{flex-direction:column;align-items:stretch;gap:12px}.classes-header-actions .primary-button,.classes-header-actions .filter-row{justify-content:center}}.content .profile-page{animation:.4s ease-out fadeIn;box-shadow:none!important;background:0 0!important;border:none!important;padding:0!important}.profile-grid{grid-template-columns:1fr 1.5fr;align-items:start;gap:32px;display:grid}.profile-left-col,.profile-right-col{flex-direction:column;gap:24px;display:flex}.profile-card{background:var(--neutral-50,#f9fafb);border-radius:var(--radius-lg);box-shadow:none;padding:28px;transition:background .2s;border:none!important}.profile-card:hover{background:var(--neutral-100,#f3f4f6)}.user-info-card{background:var(--neutral-50,#f9fafb)}.user-card-header{align-items:center;gap:20px;margin-bottom:24px;padding-bottom:12px;display:flex;border-bottom:none!important}.user-avatar-wrapper{flex-direction:column;align-items:center;gap:8px;display:flex}.profile-avatar-container{cursor:pointer;border-radius:50%;position:relative}.profile-avatar-large{background:linear-gradient(135deg, var(--primary) 0%, #3b82f6 100%);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;font-size:32px;font-weight:800;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 12px #2563eb26}.user-avatar-img-large{object-fit:cover;border-radius:50%;width:100%;height:100%}.avatar-hover-overlay{color:#fff;opacity:0;background:#0006;border-radius:50%;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.profile-avatar-large:hover .avatar-hover-overlay{opacity:1}.avatar-hover-overlay .material-symbols-rounded{font-size:24px;color:#fff!important}.remove-avatar-btn{color:var(--neutral-500);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:600;transition:background .2s,color .2s;display:flex}.remove-avatar-btn:hover{background:var(--neutral-100);color:#ef4444}html.dark .remove-avatar-btn:hover{background:var(--neutral-800)}.user-card-meta h3{color:var(--neutral-900);margin:0 0 6px;font-size:22px;font-weight:800}.role-badge{background:var(--primary-light);color:var(--primary);border:1px solid #2563eb1a;border-radius:9999px;padding:4px 12px;font-size:13px;font-weight:700;display:inline-block}.user-card-details{flex-direction:column;gap:12px;display:flex}.detail-item{border-radius:0;justify-content:space-between;align-items:center;padding:10px 0;display:flex;background:0 0!important;border:none!important}.detail-value{color:var(--neutral-800);font-size:14px;font-weight:700}.profile-stats-container{grid-template-columns:1fr 1fr;gap:16px;display:grid}.profile-stat-card{background:var(--neutral-50,#f9fafb);border-radius:var(--radius-lg);box-shadow:none;align-items:center;gap:16px;padding:24px;transition:background .2s;display:flex;border:none!important}.profile-stat-card:hover{background:var(--neutral-100,#f3f4f6)}.stat-icon-wrapper{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.stat-meta{flex-direction:column;display:flex}.stat-number{color:var(--neutral-900);font-size:24px;font-weight:800;line-height:1.2}.stat-label{color:var(--neutral-500);font-size:13px;font-weight:600}.form-card h3{margin:0 0 6px;font-size:20px;font-weight:800}.form-subtitle{color:var(--neutral-500);margin:0 0 24px;font-size:14px}.profile-form{flex-direction:column;gap:20px;display:flex}.profile-form label{color:var(--neutral-800);flex-direction:column;gap:8px;font-size:14px;font-weight:700;display:flex}.profile-form input{border:1px solid var(--neutral-300);border-radius:var(--radius-md);background-color:#fff;padding:12px 16px;font-family:inherit;transition:border-color .2s,box-shadow .2s;font-size:16px!important}.profile-form input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 4px #2563eb1a}@media (width<=768px){.profile-grid{grid-template-columns:1fr;gap:24px}}@media (width<=480px){.profile-stats-container{grid-template-columns:1fr}}html.dark{--neutral-50:#0f172a;--neutral-100:#1e293b;--neutral-200:#334155;--neutral-300:#475569;--neutral-400:#64748b;--neutral-600:#cbd5e1;--neutral-700:#e2e8f0;--neutral-800:#f1f5f9;--neutral-900:#f8fafc;--glass-bg:#1e293bcc;--glass-border:#33415580;--primary-light:#1e293b}html.dark body{color:#e2e8f0;background-color:#0f172a}html.dark .app-shell,html.dark .public-shell,html.dark .auth-split-container,html.dark .auth-split-right{background:#0f172a!important}html.dark .auth-status,html.dark .landing-header{background:#0f172acc!important;border-bottom:1px solid #334155!important}html.dark .profile-card,html.dark .word-card,html.dark .saved-word-card,html.dark .launchpad-card,html.dark .daily-study-card,html.dark .profile-stat-card,html.dark .profile-dropdown-menu,html.dark .bell-dropdown-menu,html.dark .mobile-nav-drawer,html.dark .landing-search-card,html.dark .feature-card,html.dark .step-item,html.dark .cta-box{color:var(--neutral-700)!important;background:#1e293b!important;border-color:#334155!important}html.dark .topbar-divider{border-left-color:#334155!important}html.dark h1,html.dark h2,html.dark h3,html.dark h4,html.dark strong,html.dark .topbar-user-name,html.dark .topbar-logo,html.dark .landing-logo{color:#f8fafc!important}html.dark p,html.dark span,html.dark li,html.dark label,html.dark .dictionary-intro,html.dark .detail-label{color:#cbd5e1!important}html.dark input,html.dark select,html.dark textarea{color:#f8fafc!important;background-color:#0f172a!important;border-color:#334155!important}html.dark input:focus{border-color:var(--primary)!important}html.dark .google-auth-btn{color:#f8fafc!important;background:#1e293b!important;border-color:#334155!important}html.dark .google-auth-btn:hover{background:#334155!important;border-color:#475569!important}html.dark .auth-remember-me label.checkbox-label{color:#cbd5e1!important}html.dark .auth-remember-me label.checkbox-label input[type=checkbox]{--lightningcss-light: !important;--lightningcss-dark:initial!important;color-scheme:dark!important;accent-color:#38bdf8!important}.topbar-theme-btn{cursor:pointer;justify-content:center;align-items:center;padding:8px;display:flex;box-shadow:none!important;color:var(--neutral-600)!important;background:0 0!important;border:none!important;outline:none!important}.topbar-theme-btn:hover,.topbar-theme-btn:active,.topbar-theme-btn:focus{box-shadow:none!important;color:var(--neutral-600)!important;background:0 0!important;border:none!important;outline:none!important}html.dark .topbar-theme-btn{color:#fbbf24!important}.topbar-theme-btn:hover .material-symbols-rounded{animation:.6s theme-shake}@keyframes theme-shake{0%{transform:rotate(0)}15%{transform:rotate(15deg)}30%{transform:rotate(-15deg)}45%{transform:rotate(10deg)}60%{transform:rotate(-10deg)}75%{transform:rotate(5deg)}90%{transform:rotate(-5deg)}to{transform:rotate(0)}}.topbar-theme-btn .material-symbols-rounded{transform-origin:50%;font-size:22px}html.dark .floating-search-pill-container.expanded{-webkit-backdrop-filter:none!important;background:#1e293b!important;border-color:#334155!important;box-shadow:0 4px 16px #00000040!important}html.dark .floating-search-pill-container.expanded:focus-within{border-color:#38bdf8!important;box-shadow:0 0 0 3px #38bdf826,0 4px 16px #0000004d!important}html.dark .floating-search-pill-container.collapsed{-webkit-backdrop-filter:none!important;background:#1e293b!important;border-color:#334155!important;box-shadow:0 4px 12px #0003!important}html.dark .floating-search-pill-container.collapsed:hover{background:#334155!important;border-color:#475569!important}html.dark .pill-search-input,html.dark .pill-search-input:focus{color:#f8fafc!important;box-shadow:none!important;background:0 0!important;border:none!important;border-radius:0!important;outline:none!important;padding:0!important}html.dark .pill-search-input::placeholder{color:#64748b!important}html.dark .pill-search-trigger{color:#94a3b8!important}html.dark .pill-search-trigger span.material-symbols-rounded{color:#64748b!important}html.dark .pill-search-hotkey{color:#cbd5e1!important;background:#334155!important}html.dark .pill-collapse-btn{color:#64748b!important}html.dark .pill-collapse-btn:hover{color:#f8fafc!important;background:#ffffff0f!important}html.dark .pill-expand-arrow-btn{color:#94a3b8!important}html.dark .pill-expand-arrow-btn:hover{color:#f8fafc!important;background:0 0!important}html.dark .ai-chat-widget{background:#1e293b!important;border-color:#334155!important;box-shadow:0 12px 40px #0006!important}html.dark .widget-header{color:#f8fafc!important;background:#1e293b!important;border-bottom:1px solid #334155!important}html.dark .widget-close-btn{color:#94a3b8!important}html.dark .widget-close-btn:hover{color:#f8fafc!important;background:#ffffff0f!important}html.dark .widget-body{background:#0f172a!important}html.dark .widget-presets{background:#0f172a!important;border-top-color:#1e293b!important}html.dark .widget-preset-btn{color:#cbd5e1!important;background:#1e293b!important;border-color:#334155!important}html.dark .widget-preset-btn:hover{color:#38bdf8!important;background:#38bdf81a!important;border-color:#38bdf8!important}html.dark .widget-message-wrapper.assistant .widget-message-bubble{color:#cbd5e1!important;background:#1e293b!important;border-color:#334155!important}html.dark .widget-avatar.assistant{color:#cbd5e1!important;background:#334155!important}html.dark .widget-avatar.user{color:#38bdf8!important;background:#38bdf81a!important}html.dark .widget-input-area{background:#1e293b!important;border-top-color:#334155!important}html.dark .widget-input{color:#f8fafc!important;background:#0f172a!important;border-color:#334155!important}html.dark .widget-input:focus{border-color:#38bdf8!important}html.dark .widget-send-btn{color:#38bdf8!important}html.dark .widget-send-btn:disabled{color:#475569!important}.widget-message-bubble.loading-bubble{border:1px solid var(--neutral-200);background:#fff;border-bottom-left-radius:4px}html.dark .widget-message-bubble.loading-bubble{background:#1e293b!important;border-color:#334155!important}html.dark .draggable-ai-bubble.active .bubble-inner{color:#cbd5e1!important;background:#334155!important;box-shadow:0 4px 12px #0000004d!important}
