*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #6366f1;--primary-dark: #4f46e5;--secondary: #8b5cf6;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--text: #1f2937;--text-light: #6b7280;--bg: #ffffff;--bg-light: #f9fafb;--border: #e5e7eb}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--text);line-height:1.6;overflow-x:hidden}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#fffffff2;display:none;flex-direction:column;justify-content:center;align-items:center;z-index:9999;transition:opacity .3s ease}.loading-overlay.show{display:flex;opacity:1}.loading-overlay.hidden{display:none}.spinner{width:60px;height:60px;border:4px solid var(--border);border-top:4px solid var(--primary);border-radius:50%;animation:spin 1s linear infinite}.loading-text{margin-top:20px;font-size:16px;color:var(--text-light);font-weight:500}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.container{max-width:1400px;margin:0 auto;padding:0 40px}header{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6}nav{display:flex;justify-content:space-between;align-items:center;padding:24px 40px!important;min-height:auto}.logo{display:flex;align-items:center;text-decoration:none;transition:transform .3s}.logo:hover{transform:scale(1.05)}.logo-img{height:50px;width:auto;object-fit:contain}.nav-links{display:flex;gap:32px;align-items:center}.nav-links a{text-decoration:none;color:var(--text);font-weight:500;font-size:16px;transition:color .3s}.nav-links a:hover{color:var(--primary)}.btn-profile{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border-radius:12px;font-weight:600;font-size:15px;transition:all .3s;text-decoration:none;box-shadow:0 4px 12px #6366f14d}.btn-profile:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166;color:#fff}.btn-profile svg{flex-shrink:0}.language-selector{position:relative}.language-btn{display:flex;align-items:center;gap:8px;background:var(--bg-light);border:1px solid var(--border);border-radius:8px;padding:10px 16px;cursor:pointer;transition:all .3s;font-size:14px;font-weight:500}.language-btn:hover{background:#fff;border-color:var(--primary)}.language-btn .flag{font-size:18px}.language-btn .lang-text{color:var(--text)}.language-btn .arrow{font-size:10px;color:var(--text-light);transition:transform .3s}.language-btn.active .arrow{transform:rotate(180deg)}.language-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 24px #0000001a;min-width:180px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s;z-index:1000}.language-dropdown.active{opacity:1;visibility:visible;transform:translateY(0)}.language-option{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:all .2s;font-size:15px}.language-option:first-child{border-radius:12px 12px 0 0}.language-option:last-child{border-radius:0 0 12px 12px}.language-option:hover{background:var(--bg-light)}.language-option.selected{background:#6366f11a;color:var(--primary);font-weight:600}.language-option .flag{font-size:20px}.user-section{display:flex;align-items:center;gap:16px}.user-profile{position:relative}.user-info-trigger{display:flex;align-items:center;gap:12px;background:#fff;padding:8px 16px;border-radius:12px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .3s}.user-info-trigger:hover{box-shadow:0 4px 12px #00000026}.user-avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--primary)}.user-name{font-weight:600;color:var(--text);font-size:14px}.dropdown-arrow{font-size:10px;color:var(--text-light);transition:transform .3s}.user-info-trigger.active .dropdown-arrow{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;min-width:200px;padding:8px;display:none;z-index:1000;animation:dropdownSlide .2s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-dropdown.active{display:block}.dropdown-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;text-decoration:none;color:var(--text);font-size:14px;font-weight:500;transition:background .2s;cursor:pointer;border:none;background:none;width:100%;text-align:left}.dropdown-item:hover{background:var(--bg-light)}.dropdown-item svg{flex-shrink:0;color:var(--text-light)}.dropdown-divider{height:1px;background:var(--border);margin:8px 0}.dropdown-signout{color:var(--danger)}.dropdown-signout svg{color:var(--danger)}.btn-signout{background:transparent;border:1px solid var(--border);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-light);transition:all .3s}.btn-signout:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-primary{background:#fff;color:var(--text)!important;padding:10px 20px;border-radius:10px;transition:all .3s;font-size:15px;border:1.5px solid var(--border);cursor:pointer;font-weight:500;display:inline-flex;align-items:center;gap:10px;box-shadow:0 1px 3px #0000000d}.btn-primary svg{flex-shrink:0}.btn-primary:hover{background:var(--bg-light);border-color:var(--primary);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.btn-primary span{color:var(--text)!important}.hero{padding:80px 0 120px;background:linear-gradient(135deg,#f9fafb,#fff);position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:-50%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);border-radius:50%}.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}.hero-content h1{font-size:56px;line-height:1.2;margin-bottom:24px;color:var(--text)}.highlight{background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:20px;color:var(--text-light);margin-bottom:32px;line-height:1.8}.btn-cta{display:inline-block;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;padding:16px 40px;border-radius:12px;text-decoration:none;font-weight:600;font-size:18px;transition:all .3s;box-shadow:0 4px 20px #6366f14d}.btn-cta:hover{transform:translateY(-3px);box-shadow:0 6px 30px #6366f166}.hero-stats{display:flex;gap:48px;margin-top:48px}.stat{text-align:left}.stat-number{font-size:36px;font-weight:700;color:var(--primary);margin-bottom:4px}.stat-label{color:var(--text-light);font-size:14px}.hero-illustration{position:relative;display:flex;justify-content:center;align-items:center}.card-preview{position:relative;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.word-card{background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000001a;min-width:400px}.word{font-size:32px;font-weight:700;color:var(--text);margin-bottom:16px}.meaning{font-size:16px;color:var(--text-light);margin-bottom:32px;line-height:1.6}.actions{display:flex;gap:12px}.actions button{flex:1;padding:12px;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s;font-size:14px}.know{background:#d1fae5;color:#065f46}.know:hover{background:#a7f3d0;transform:translateY(-2px)}.unsure{background:#fef3c7;color:#92400e}.unsure:hover{background:#fde68a;transform:translateY(-2px)}.dont-know{background:#fee2e2;color:#991b1b}.dont-know:hover{background:#fecaca;transform:translateY(-2px)}.features{padding:100px 0;background:#fff}.features h2{text-align:center;font-size:42px;margin-bottom:60px;color:var(--text)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px}.feature{text-align:center;padding:32px;border-radius:16px;transition:all .3s}.feature:hover{transform:translateY(-8px);box-shadow:0 12px 40px #00000014}.feature-icon{font-size:48px;margin-bottom:20px}.feature h3{font-size:24px;margin-bottom:12px;color:var(--text)}.feature p{color:var(--text-light);line-height:1.7}.how-it-works{padding:100px 0;background:var(--bg-light)}.how-it-works h2{text-align:center;font-size:42px;margin-bottom:60px;color:var(--text)}.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px}.step{display:flex;gap:20px}.step-number{width:48px;height:48px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:20px;flex-shrink:0}.step-content h3{font-size:20px;margin-bottom:8px;color:var(--text)}.step-content p{color:var(--text-light);line-height:1.7}.cta-section{padding:100px 0;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;text-align:center}.cta-content h2{font-size:42px;margin-bottom:16px}.cta-content p{font-size:20px;margin-bottom:32px;opacity:.9}.btn-cta-large{background:#fff;color:var(--primary);padding:18px 48px;border:none;border-radius:12px;font-weight:700;font-size:18px;cursor:pointer;transition:all .3s;box-shadow:0 4px 20px #0003;text-decoration:none;display:inline-block}.btn-cta-large:hover{transform:translateY(-3px);box-shadow:0 6px 30px #0000004d}footer{padding:40px 0;background:var(--text);color:#fff}.footer-content{text-align:center}.footer-logo{display:flex;align-items:center;justify-content:center;margin-bottom:12px}.footer-logo-img{height:40px;width:auto;object-fit:contain}.footer-content p{opacity:.7}.footer-made-by{margin-top:6px;font-size:12px;opacity:.45;letter-spacing:.02em}.footer-heart{color:#f43f5e;opacity:1;display:inline-block;animation:heartbeat 1.6s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}14%{transform:scale(1.25)}28%{transform:scale(1)}42%{transform:scale(1.15)}56%{transform:scale(1)}}@media(max-width:768px){.hero .container{grid-template-columns:1fr}.hero-content h1{font-size:36px}.hero-description{font-size:18px}.word-card{min-width:auto;padding:24px}.hero-stats{gap:24px}.nav-links{gap:16px}.features h2,.how-it-works h2,.cta-content h2{font-size:32px}.steps{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);display:flex;justify-content:center;align-items:center;z-index:10000;overflow:hidden}.modal-content{background:#fff;padding:48px;border-radius:28px;max-width:600px;width:90%;position:relative;animation:modalSlideIn .5s ease-out;box-shadow:0 20px 60px #0000004d}.modal-content:before{content:"";position:absolute;width:300px;height:300px;background:radial-gradient(circle,rgba(99,102,241,.15),transparent 70%);top:-100px;right:-100px;border-radius:50%;z-index:-1}.modal-close-overlay{position:absolute;top:40px;left:40px;display:flex;align-items:center;gap:8px;background:#fffffff2;-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid rgba(99,102,241,.2);color:var(--primary);padding:12px 20px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #6366f126;z-index:10001}.modal-close-overlay:hover{background:var(--primary);color:#fff;transform:translate(-4px);box-shadow:0 6px 20px #6366f14d}.modal-close-overlay svg{width:24px;height:24px}.role-modal-slider{overflow:hidden;padding:0;position:relative;min-height:450px}.role-modal-wrapper{position:relative;width:100%;height:100%}.role-step{position:absolute;top:0;left:0;width:100%;padding:48px;transition:transform .6s cubic-bezier(.4,0,.2,1),opacity .6s ease;opacity:0;transform:translate(100%)}.role-step.active{opacity:1;transform:translate(0)}.role-step.slide-out{opacity:0;transform:translate(-100%)}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-title{font-size:32px;font-weight:700;text-align:center;margin-bottom:40px;color:var(--text)}.modal-subtitle{font-size:16px;color:var(--text-secondary);text-align:center;margin-bottom:32px;line-height:1.5}.name-input-container{display:flex;flex-direction:column;gap:16px;max-width:400px;margin:0 auto}.name-input-container input{padding:16px 20px;border:2px solid rgba(99,102,241,.2);border-radius:12px;font-size:18px;transition:all .3s;background:#fff;color:var(--text)}.name-input-container input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.btn-continue{padding:16px 32px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s}.btn-continue:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.btn-continue:disabled{opacity:.5;cursor:not-allowed;transform:none}.modal-subtitle{font-size:24px;font-weight:600;text-align:center;margin-bottom:32px;margin-top:40px;color:var(--text)}.role-selection{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:20px}.role-card{background:var(--bg-light);border:3px solid var(--border);border-radius:16px;padding:32px 24px;cursor:pointer;transition:all .3s;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.role-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 8px 24px #6366f133}.role-card.selected{border-color:var(--primary);background:#6366f10d}.role-icon{font-size:64px;margin-bottom:8px}.role-name{font-size:24px;font-weight:600;color:var(--text)}.role-description{font-size:14px;color:var(--text-light)}.language-selection{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}.language-options{display:grid;grid-template-columns:1fr 1fr;gap:24px}.language-options-three{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}.language-options-three .language-card{width:100%}.language-card{background:var(--bg-light);border:3px solid var(--border);border-radius:16px;padding:32px 24px;cursor:pointer;transition:all .3s;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.language-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 8px 24px #6366f133}.language-card.selected{border-color:var(--primary);background:#6366f10d}.flag-large{font-size:72px}.lang-name{font-size:20px;font-weight:600;color:var(--text)}@media(max-width:768px){.modal-content{padding:32px 24px}.modal-title{font-size:24px;margin-bottom:32px}.role-selection,.language-options,.language-options-three{grid-template-columns:1fr;gap:16px}.language-options-three .language-card{width:100%}.role-card,.language-card{padding:24px}.role-icon{font-size:48px}.flag-large{font-size:56px}}.auth-modal-glass{position:relative;width:500px;max-width:90%;padding:50px 45px;border-radius:28px;background:#fff;border:none;box-shadow:0 20px 60px #0000004d;overflow:hidden;animation:modalFadeIn .6s ease}.modal-close-glass{position:absolute;top:20px;right:20px;background:#f3f4f6;border:1px solid #e5e7eb;width:40px;height:40px;border-radius:50%;font-size:24px;line-height:40px;color:#6b7280;cursor:pointer;text-align:center;transition:all .3s;z-index:10;padding:0;margin:0;font-family:Arial,sans-serif;font-weight:300}.modal-close-glass:hover{background:#e5e7eb;color:#374151;transform:rotate(90deg)}.auth-title{color:#1a1a2e!important;font-size:32px;font-weight:700;margin-bottom:35px;text-align:center;text-shadow:none;position:relative;z-index:1}.auth-form-glass{display:flex;flex-direction:column;position:relative;z-index:1}.input-group-glass{position:relative;margin-bottom:25px}.input-group-glass input{width:100%;padding:16px 14px;background:#f7f8fa!important;border:1px solid #e0e4ea!important;border-radius:14px;outline:none;color:#1a1a2e!important;font-size:15px;transition:.3s}.input-group-glass input::placeholder{color:transparent}.input-group-glass input:focus{border-color:#6366f1;background:#fff;box-shadow:0 0 0 3px #6366f11a}.input-group-glass label{position:absolute;left:14px;top:16px;color:#6b7280!important;font-size:15px;pointer-events:none;transition:.3s}.input-group-glass input:focus+label,.input-group-glass input:not(:placeholder-shown)+label{top:-10px;left:12px;background:#fff;padding:2px 8px;font-size:13px;color:#6366f1;border-radius:6px}.main-btn-glass{width:100%;padding:16px;border-radius:14px;border:none;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-weight:600;font-size:16px;cursor:pointer;transition:.3s;box-shadow:0 0 25px #6366f199;margin-top:5px}.main-btn-glass:hover{transform:translateY(-3px);box-shadow:0 0 40px #6366f1e6}.auth-link-glass{text-align:center;margin-top:12px;margin-bottom:5px}.auth-link-glass a{color:#6b7280;text-decoration:none;font-size:13px;transition:.3s}.auth-link-glass a:hover{color:#6366f1}.divider-glass{margin:25px 0;text-align:center;position:relative;color:#9ca3af;font-size:13px;font-weight:500;text-transform:uppercase;letter-spacing:1px}.divider-glass:before,.divider-glass:after{content:"";position:absolute;top:50%;width:38%;height:1px;background:#e5e7eb}.divider-glass:before{left:0}.divider-glass:after{right:0}.google-btn-glass{width:100%;padding:15px;border-radius:14px;border:1px solid #e5e7eb;background:#fff;color:#374151;font-weight:600;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:.3s}.google-btn-glass:hover{background:#f9fafb;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.google-btn-glass img{width:20px;height:20px}.switch-glass{margin-top:30px;text-align:center;color:#6b7280;font-size:14px}.switch-glass span:last-child{color:#6366f1;cursor:pointer;margin-left:6px;font-weight:700;transition:.3s}.switch-glass span:last-child:hover{color:#818cf8;text-decoration:underline}.modal-content{position:relative}@media(max-width:768px){.auth-modal-glass{width:90%;padding:40px 30px}.auth-title{font-size:26px}}.toast-notification{position:fixed;top:-200px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:20px 28px;border-radius:16px;box-shadow:0 10px 40px #10b98166;display:flex;align-items:center;gap:16px;z-index:20000;transition:top .5s cubic-bezier(.4,0,.2,1);min-width:320px;max-width:90%}.toast-notification.show{top:30px}.toast-icon{width:48px;height:48px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0;animation:toastIconPulse 2s ease-in-out infinite}@keyframes toastIconPulse{0%,to{transform:scale(1);box-shadow:0 0 #fff6}50%{transform:scale(1.05);box-shadow:0 0 0 10px #fff0}}.toast-content{flex:1}.toast-title{font-size:16px;font-weight:700;margin-bottom:4px}.toast-message{font-size:14px;opacity:.95;font-weight:500}@media(max-width:768px){.toast-notification{min-width:280px;padding:16px 20px}.toast-icon{width:40px;height:40px;font-size:24px}.toast-title{font-size:15px}.toast-message{font-size:13px}}.dashboard-container{max-width:1200px;margin:0 auto;padding:40px 24px}.dashboard-header{text-align:center;margin-bottom:48px}.dashboard-header h1{font-size:42px;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px}.dashboard-header p{font-size:18px;color:var(--text-secondary)}.teacher-badge{display:inline-flex;align-items:center;padding:6px 14px;margin:0 12px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-radius:20px;font-size:13px;font-weight:600;height:fit-content;align-self:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:48px}.stat-card{background:var(--bg-light);border:2px solid var(--border);border-radius:16px;padding:24px;display:flex;align-items:center;gap:20px;transition:all .3s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #6366f126;border-color:var(--primary)}.stat-icon{font-size:48px}.stat-info{flex:1}.stat-value{font-size:32px;font-weight:800;color:var(--text-primary);line-height:1}.stat-label{font-size:14px;color:var(--text-secondary);margin-top:8px}.dashboard-section{margin-bottom:48px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.section-header h2{font-size:28px;font-weight:700}.create-class-form{display:flex;gap:16px;margin-bottom:32px;max-width:600px}.create-class-form input{flex:1;padding:14px 20px;border:2px solid var(--border);border-radius:12px;font-size:16px;transition:all .3s}.create-class-form input:focus{outline:none;border-color:var(--primary)}.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.class-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(99,102,241,.15);border-radius:20px;padding:24px;transition:all .3s;box-shadow:0 4px 12px #6366f114;display:flex;flex-direction:column}.class-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #6366f140;border-color:#6366f14d}.class-header{margin-bottom:20px}.class-header h3{font-size:22px;font-weight:700;margin-bottom:12px}.class-code{display:inline-flex;align-items:center;gap:8px;background:var(--primary);color:#fff;padding:6px 12px;border-radius:8px;font-size:14px}.class-code code{font-family:Monaco,Courier New,monospace;font-weight:700;letter-spacing:1px}.class-stats{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;flex:1}.class-stat{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:14px}.class-stat i{color:var(--primary)}.btn-view{width:100%;padding:12px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px;position:relative;overflow:hidden}.btn-view:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.btn-view:hover:before{left:100%}.btn-view:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.empty-state .empty-icon{font-size:72px;margin-bottom:20px}.empty-state p{font-size:18px}.class-modal{width:520px;max-height:80vh;overflow-y:auto;padding:40px;border-radius:28px;background:#fffffff2;-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid rgba(99,102,241,.1);box-shadow:0 0 70px #6366f140;position:relative;animation:modalSlideIn .5s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.class-modal:before{content:"";position:absolute;width:300px;height:300px;background:radial-gradient(circle,rgba(99,102,241,.15),transparent 70%);top:-100px;right:-100px;border-radius:50%;z-index:-1}.class-code-display{display:flex;justify-content:space-between;align-items:center;background:#6366f114;padding:14px 18px;border-radius:14px;margin-top:12px;margin-bottom:25px;border:1px solid rgba(99,102,241,.2)}.class-code-display code{color:var(--primary);font-family:Monaco,Courier New,monospace;font-size:18px;font-weight:700;letter-spacing:3px}.btn-copy{background:#6366f11a;border:none;color:var(--primary);padding:8px 14px;border-radius:10px;cursor:pointer;transition:all .3s;font-weight:600}.btn-copy:hover{background:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:0 0 25px #6366f14d}.students-section h3{font-size:18px;font-weight:700;margin-bottom:16px;color:var(--text)}.students-list{display:flex;flex-direction:column;gap:10px;max-height:220px;overflow-y:auto;margin-bottom:25px}.student-item{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#6366f112;border:none;border-radius:12px;cursor:pointer;transition:all .3s;color:var(--text)}.student-item:hover{background:#6366f126;transform:translateY(-2px)}.student-item img{width:40px;height:40px;border-radius:50%;object-fit:cover}.student-info{flex:1}.student-name{font-weight:600;font-size:16px;color:var(--text-primary)}.student-joined{font-size:13px;color:var(--text-secondary)}.btn-danger{width:100%;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:12px 24px;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 0 25px #ef444499}.student-modal{max-width:600px;max-height:80vh;overflow-y:auto}.student-header{display:flex;align-items:center;gap:20px}.student-avatar-large{width:80px;height:80px;border-radius:50%;object-fit:cover}.student-email{color:var(--text-secondary);font-size:14px}.progress-tiers{display:flex;flex-direction:column;gap:24px}.tier-progress{background:var(--bg-light);border:2px solid var(--border);border-radius:12px;padding:20px}.tier-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.tier-header h4{font-size:18px;font-weight:700;color:var(--primary)}.tier-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}.tier-stat{text-align:center}.tier-stat .label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:4px}.tier-stat .value{display:block;font-size:24px;font-weight:700}.tier-stat.known .value{color:var(--success)}.tier-stat.unsure .value{color:var(--warning)}.tier-stat.unknown .value{color:var(--danger)}.progress-bar-container{width:100%;height:8px;background:var(--border);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--success),var(--primary));border-radius:4px;transition:width .5s ease}.empty-state-small{text-align:center;padding:40px 20px;color:var(--text-secondary);font-style:italic}.toast-success{background:linear-gradient(135deg,#10b981,#059669)}.toast-error{background:linear-gradient(135deg,#ef4444,#dc2626)}.toast-type-success{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 10px 40px #10b98166}.toast-type-info{background:linear-gradient(135deg,#6366f1,#4f46e5);box-shadow:0 10px 40px #6366f166}.my-classes-section{margin-bottom:48px;background:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(99,102,241,.1);border-radius:24px;padding:32px;box-shadow:0 4px 12px #6366f114}.my-classes-section h2{font-size:28px;font-weight:700;margin-bottom:24px;color:var(--text)}.join-class-form{display:flex;gap:12px;margin-bottom:32px;max-width:600px;background:#6366f10d;padding:20px;border-radius:16px;border:1px solid rgba(99,102,241,.1)}.join-class-form input{flex:1;padding:14px 20px;border:2px solid rgba(99,102,241,.2);border-radius:12px;font-size:18px;text-transform:uppercase;font-family:Monaco,Courier New,monospace;font-weight:700;letter-spacing:3px;transition:all .3s;background:#fff;color:var(--primary);text-align:center}.join-class-form input::placeholder{color:#6366f166;letter-spacing:1px;text-transform:none;font-size:14px}.join-class-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.student-classes-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.student-class-card{background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(99,102,241,.15);border-radius:16px;padding:24px;transition:all .3s;box-shadow:0 2px 8px #6366f10f}.student-class-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #6366f133;border-color:#6366f14d}.student-class-card .class-info h3{font-size:20px;font-weight:700;margin-bottom:8px}.student-class-card .teacher-name{color:var(--text-secondary);font-size:14px;margin-bottom:12px}.class-code-badge{display:inline-flex;align-items:center;gap:8px;background:var(--primary);color:#fff;padding:6px 12px;border-radius:8px;font-size:13px}.class-code-badge code{font-family:Monaco,Courier New,monospace;font-weight:700;letter-spacing:1px}.fullscreen-code-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.fullscreen-close{position:fixed;top:40px;right:40px;width:56px;height:56px;min-width:56px;min-height:56px;background:#fffffff2;-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid rgba(99,102,241,.2);border-radius:50%;color:var(--primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;box-shadow:0 4px 12px #6366f126;z-index:10002;padding:0;margin:0}.fullscreen-close svg{width:28px;height:28px;display:block}.fullscreen-close:hover{background:var(--primary);color:#fff;transform:rotate(90deg);box-shadow:0 6px 20px #6366f14d}.fullscreen-code-container{width:100%;max-width:600px;padding:40px;border-radius:28px;background:#fffffff2;-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid rgba(99,102,241,.1);box-shadow:0 0 70px #6366f140;position:relative;animation:modalFadeIn .5s ease;margin:0 20px}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.fullscreen-code-container:before{content:"";position:absolute;width:300px;height:300px;background:radial-gradient(circle,rgba(99,102,241,.15),transparent 70%);top:-100px;right:-100px;border-radius:50%;z-index:-1}.fullscreen-title{color:var(--text);margin-bottom:20px;font-size:26px;font-weight:700;text-align:center}.fullscreen-code{font-family:Monaco,Courier New,monospace;font-size:72px;font-weight:900;letter-spacing:20px;margin:0 0 25px;padding:32px 32px 32px 52px;background:#6366f114;color:var(--primary);border-radius:14px;border:1px solid rgba(99,102,241,.2);text-align:center;width:100%;box-sizing:border-box}.fullscreen-subtitle{font-size:18px;color:var(--text-secondary);text-align:center;font-weight:500}.btn-fullscreen{background:#6366f11a;border:none;color:var(--primary);width:36px;height:36px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;margin-left:8px;font-weight:600}.btn-fullscreen:hover{background:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:0 0 25px #6366f14d}.empty-state-small{text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:15px}.sessions-section{background:#fff;border-radius:16px;padding:28px;margin-bottom:24px;box-shadow:0 2px 12px #0000000f;border:1px solid #f0f0f0}.sessions-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:20px}.sessions-header h2{margin:0;font-size:20px;font-weight:700;color:#1a1a2e}.sessions-total-stats{display:flex!important;gap:16px!important;flex-wrap:wrap;align-items:center}.session-total-item{display:flex;align-items:center;gap:10px;background:#f8f9fa;border-radius:10px;padding:10px 16px}.session-total-icon{font-size:20px}.session-total-value{font-size:18px;font-weight:700;color:#1a1a2e;line-height:1.2}.session-total-label{font-size:11px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.sessions-list{display:flex;flex-direction:column;gap:10px}.sessions-empty{text-align:center;color:#9ca3af;padding:24px;font-size:14px}.session-card{display:flex;align-items:center;justify-content:space-between;background:#f8f9fa;border-radius:12px;padding:14px 18px;gap:16px;border:1px solid #f0f0f0;transition:background .2s}.session-card:hover{background:#f0f4ff}.session-card-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.session-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.dot-complete{background:#22c55e}.dot-partial{background:#f59e0b}.session-info{min-width:0}.session-date{font-size:13px;color:#6b7280}.session-tier{font-size:12px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.session-card-right{display:flex;align-items:center;gap:16px;flex-shrink:0}.session-duration{font-size:14px;font-weight:600;color:#1a1a2e;min-width:48px;text-align:right}.session-stat{display:flex;align-items:center;gap:4px;font-size:13px;color:#6b7280;font-weight:500}.session-stat-icon{font-size:14px}.session-mini-stats{display:flex;gap:6px}.mini-stat,.mini-known,.mini-unsure,.mini-unknown{font-size:12px;font-weight:600;padding:3px 8px;border-radius:20px}.mini-known{background:#dcfce7;color:#16a34a}.mini-unsure{background:#fef9c3;color:#a16207}.mini-unknown{background:#fee2e2;color:#dc2626}.student-session-stats{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap}.student-session-stat{display:flex;align-items:center;gap:10px;background:#f8f9fa;border-radius:10px;padding:12px 16px;flex:1;min-width:100px}.s-stat-icon{font-size:20px}.s-stat-value{font-size:20px;font-weight:700;color:#1a1a2e;line-height:1.2}.s-stat-label{font-size:11px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.student-sessions-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}@media(max-width:768px){.class-modal{width:90%;max-width:400px;padding:30px}.modal-close-overlay{top:20px;left:20px;padding:10px 16px;font-size:14px}.modal-close-overlay svg{width:20px;height:20px}.fullscreen-code-container{width:90%;max-width:400px;padding:30px}.fullscreen-title{font-size:20px;margin-bottom:16px}.fullscreen-code{font-size:48px;letter-spacing:8px;padding:20px 24px}.fullscreen-subtitle{font-size:14px}.fullscreen-close{top:20px;right:20px;width:48px;height:48px;font-size:28px}}.student-modal{max-width:680px!important}.student-section{margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid #f0f0f0}.student-section:last-child{border-bottom:none;margin-bottom:0}.student-section-title{font-size:16px;font-weight:700;color:#1f2937;margin-bottom:16px}.student-section-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:16px}.student-section-header .student-section-title{margin-bottom:0}.student-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.student-stat-card{border-radius:12px;padding:16px 12px;text-align:center}.student-stat-card .s-stat-value{font-size:28px;font-weight:700;line-height:1.1;margin-bottom:4px}.student-stat-card .s-stat-label{font-size:12px;font-weight:500;opacity:.8}.s-known{background:#dcfce7;color:#15803d}.s-learned{background:#ede9fe;color:#5b21b6}.s-unsure{background:#fef9c3;color:#92400e}.s-unknown{background:#fee2e2;color:#991b1b}.student-progress-bar-wrap{margin-top:4px}.student-progress-bar{display:flex;height:12px;border-radius:8px;overflow:hidden;background:#f3f4f6;margin-bottom:10px}.spb-known{background:#10b981;transition:width .5s ease}.spb-unsure{background:#f59e0b;transition:width .5s ease}.spb-unknown{background:#ef4444;transition:width .5s ease}.spb-legend{display:flex;gap:16px;font-size:12px;color:#6b7280}.spb-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:4px;vertical-align:middle}.dot-known{background:#10b981}.dot-unsure{background:#f59e0b}.dot-unknown{background:#ef4444}.student-period-filters{display:flex;gap:6px;flex-wrap:wrap}.s-period-btn{padding:6px 14px;border-radius:20px;border:1.5px solid #e5e7eb;background:#fff;color:#6b7280;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.s-period-btn:hover{border-color:#6c63ff;color:#6c63ff}.s-period-btn.active{background:#6c63ff;border-color:#6c63ff;color:#fff}.student-learned-banner{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border-radius:14px;padding:20px 28px;display:flex;align-items:center;gap:16px}.slb-value{font-size:48px;font-weight:700;line-height:1}.slb-label{font-size:15px;font-weight:500;opacity:.8}.student-word-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.sw-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:20px;border:1.5px solid #e5e7eb;background:#fff;color:#6b7280;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.sw-tab:hover{border-color:#6c63ff;color:#6c63ff}.sw-tab.active{background:#6c63ff;border-color:#6c63ff;color:#fff}.sw-tab-count{background:#0000001f;border-radius:10px;padding:1px 7px;font-size:12px;font-weight:600}.sw-tab.active .sw-tab-count{background:#ffffff40}.sw-words-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;max-height:260px;overflow-y:auto;padding-right:4px}.sw-words-list::-webkit-scrollbar{width:4px}.sw-words-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.sw-word-item{display:flex;flex-direction:column;gap:2px;padding:10px 14px;border-radius:10px;border-left:3px solid transparent}.sw-word-en{font-size:14px;font-weight:600;color:inherit}.sw-word-ru{font-size:12px;opacity:.7}.sw-known{background:#f0fdf4;border-left-color:#10b981;color:#065f46}.sw-learned{background:#f5f3ff;border-left-color:#6c63ff;color:#4c1d95}.sw-unsure{background:#fffbeb;border-left-color:#f59e0b;color:#78350f}.sw-unknown{background:#fef2f2;border-left-color:#ef4444;color:#7f1d1d}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.assignments-list{display:flex;flex-direction:column;gap:12px}.assignment-card{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;padding:16px 20px;gap:16px;transition:box-shadow .2s}.assignment-card:hover{box-shadow:0 4px 16px #00000012}.assignment-card.overdue{border-color:#fca5a5;background:#fff5f5}.asgn-left{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.asgn-icon{font-size:24px;width:44px;height:44px;background:#f3f4f6;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.asgn-info{min-width:0}.asgn-title{font-size:15px;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asgn-meta{font-size:13px;color:#6b7280;margin-top:2px}.asgn-desc{font-size:12px;color:#9ca3af;margin-top:4px}.asgn-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.asgn-due{font-size:13px;font-weight:500;color:#6b7280;white-space:nowrap}.asgn-overdue{color:#ef4444!important}.asgn-delete{background:none;border:none;color:#d1d5db;cursor:pointer;font-size:16px;padding:4px 6px;border-radius:6px;transition:color .2s,background .2s}.asgn-delete:hover{color:#ef4444;background:#fee2e2}.assignment-modal{max-width:520px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}.form-input{width:100%;padding:10px 14px;border:1.5px solid #e5e7eb;border-radius:10px;font-size:14px;color:#1f2937;background:#fff;outline:none;transition:border-color .2s;box-sizing:border-box}.form-input:focus{border-color:#6c63ff}.form-textarea{resize:vertical;min-height:80px;font-family:inherit}.assignment-type-toggle,.assign-to-toggle{display:flex;gap:8px}.type-btn,.assign-btn{flex:1;padding:10px;border:1.5px solid #e5e7eb;border-radius:10px;background:#fff;color:#6b7280;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;text-align:center}.type-btn:hover,.assign-btn:hover{border-color:#6c63ff;color:#6c63ff}.type-btn.active,.assign-btn.active{background:#6c63ff;border-color:#6c63ff;color:#fff}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid #f3f4f6}.btn-secondary{padding:10px 20px;border:1.5px solid #e5e7eb;border-radius:10px;background:#fff;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{border-color:#6b7280;color:#374151}.modal-close-btn{background:none;border:none;font-size:18px;color:#9ca3af;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .2s}.modal-close-btn:hover{color:#374151}
