*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{border:none;cursor:pointer;outline:none}button,input,textarea{font-family:inherit}.sidebar-overlay{display:none}.sidebar{background:#1e3a8a;color:#fff;display:flex;flex-direction:column;height:100vh;left:0;min-width:250px;overflow-y:auto;position:fixed;top:0;transition:transform .3s ease;width:250px;z-index:1000}.sidebar-close-button{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:none;font-size:1.25rem;height:32px;justify-content:center;position:absolute;right:1rem;top:1rem;width:32px;z-index:1002}.sidebar-close-button:hover{background:#ffffff4d}.sidebar-top{border-bottom:1px solid #ffffff1a;padding:2rem 1.5rem;text-align:center}.sidebar-profile{align-items:center;display:flex;flex-direction:column;gap:.75rem}.profile-picture{align-items:center;background:#ffffff26;border:3px solid #84cc16;border-radius:50%;display:flex;height:100px;justify-content:center;overflow:hidden;position:relative;width:100px}.profile-picture-img{height:100%;object-fit:cover;width:100%}.profile-picture-icon{color:#ffffffe6;font-size:2.5rem}.profile-name{color:#fff;font-size:1rem;font-weight:500}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:.5rem;padding:1.5rem 0}.nav-item{align-items:center;border-left:4px solid #0000;color:#fff;display:flex;gap:1rem;padding:1rem 1.5rem;text-decoration:none;transition:all .3s ease}.nav-item:hover{background:#ffffff1a}.nav-item.active{background:#84cc16;border-left-color:#65a30d;color:#1e3a8a;font-weight:600}.nav-icon{align-items:center;display:flex;flex-shrink:0;font-size:1.25rem;justify-content:center;width:24px}.nav-icon-game{color:#f59e0b}.nav-icon-dashboard{color:#3b82f6}.nav-icon-create{color:#10b981}.nav-icon-browse{color:#8b5cf6}.nav-icon-performance{color:#fbbf24}.nav-icon-words{color:#48bb78}.nav-icon-flashcards{color:#9f7aea}.nav-icon-deck-quiz{color:#10b981}.nav-icon-spelling{color:#ec4899;filter:drop-shadow(0 0 2px rgba(236,72,153,.5))}.nav-icon-writing{color:#f59e0b}.nav-item.active .nav-icon{color:#1e3a8a}.nav-text{font-size:1rem}.sidebar-features{border-bottom:1px solid #ffffff1a;border-top:1px solid #ffffff1a;padding:1.5rem}.features-title{color:#fff;font-size:.875rem;font-weight:600;letter-spacing:.5px;margin-bottom:1rem;text-transform:uppercase}.features-list{display:flex;flex-direction:column;gap:.5rem}.feature-placeholder{align-items:center;color:#94a3b8;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem}.feature-icon{color:#94a3b8;flex-shrink:0;font-size:1rem}.sidebar-bottom{border-top:1px solid #ffffff1a;display:flex;flex-direction:column;gap:.5rem;padding:1.5rem}.sidebar-bottom-item{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:1rem;padding:1rem 1.5rem;text-align:left;text-decoration:none;text-transform:uppercase;transition:all .3s ease}.sidebar-bottom-item:hover{background:#ffffff1a}.logout-btn{color:#fff}@media (max-width:768px){.sidebar-overlay{background:#00000080;bottom:0;display:block;left:0;position:fixed;right:0;top:0;z-index:999}.sidebar{transform:translateX(-100%);width:250px}.sidebar.sidebar-open{transform:translateX(0)}.sidebar-close-button{display:flex}.profile-picture{height:80px;width:80px}.nav-text{font-size:.9rem}}@media (min-width:769px){.sidebar-overlay{display:none!important}.sidebar{transform:translateX(0)!important}.sidebar-close-button{display:none!important}}@media (max-width:480px){.sidebar{width:220px}}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;box-shadow:0 2px 10px #0000001a;padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.navbar-container{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 1rem}.navbar-brand{align-items:center;color:#667eea;display:flex;font-size:1.25rem;font-weight:700;gap:.5rem;text-decoration:none;white-space:nowrap}.brand-icon{font-size:1.5rem}.navbar-menu{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-end}.navbar-link{color:#2d3748;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .3s;white-space:nowrap}.navbar-link:hover,.navbar-user{color:#667eea}.navbar-user{font-size:.9rem;font-weight:600;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-sm{padding:8px 16px;white-space:nowrap}@media (max-width:768px){.navbar-container{padding:.75rem 1rem}.navbar-brand{font-size:1.1rem}.brand-icon{font-size:1.25rem}.navbar-menu{gap:.5rem;justify-content:flex-end;width:100%}.navbar-link{font-size:.85rem;padding:.25rem 0}.navbar-user{font-size:.85rem;max-width:100px}.btn-sm{font-size:.8rem;padding:6px 12px}}@media (max-width:480px){.navbar-container{align-items:flex-start;flex-direction:column;gap:.75rem}.navbar-menu{justify-content:space-between;width:100%}.navbar-user{display:none}}.mobile-menu-button{align-items:center;background:#1e3a8a;border:none;border-radius:8px;box-shadow:0 2px 8px #0000004d;color:#fff;cursor:pointer;display:none;font-size:1.5rem;height:48px;justify-content:center;left:1rem;position:fixed;top:1rem;transition:all .3s ease;width:48px;z-index:1001}.mobile-menu-button:active{background:#1e40af;transform:scale(.95)}@media (max-width:768px){.mobile-menu-button{display:flex}}@media (max-width:480px){.mobile-menu-button{font-size:1.25rem;height:40px;left:.75rem;top:.75rem;width:40px}}.home{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);margin:0;max-width:100%;min-height:100vh;padding:0 0 2rem}.home-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;box-shadow:0 2px 10px #0000001a;box-sizing:border-box;justify-content:space-between;left:0;padding:1rem 2rem;position:fixed;right:0;top:0;width:100%;z-index:1000}.home-header,.home-logo{align-items:center;display:flex}.home-logo{color:#667eea;font-size:1.25rem;font-weight:700;gap:.5rem;text-decoration:none}.home-logo .brand-icon{font-size:1.5rem}.home-auth{align-items:center;display:flex;gap:.75rem}.home-login-link{color:#667eea;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .3s}.home-login-link:hover{color:#8258ff}.hero{background:linear-gradient(135deg,#6b73ff,#8258ff 50%,#6a49ff);color:#fff;margin:0 auto 2rem;max-width:100%;padding:4rem 2rem;text-align:center}.home .home-header~.hero{margin-top:80px}.hero-title{color:#fff;font-size:3.5rem;font-weight:800;margin-bottom:1rem;text-shadow:0 2px 8px #00000026}.hero-subtitle{color:#eef2ff;font-size:1.25rem;line-height:1.6;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:800px}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.btn-large{padding:16px 32px}.features{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-left:auto;margin-right:auto;margin-top:4rem;max-width:1200px;padding:0 2rem}.feature-card{background:#fffffffa;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:2rem;text-align:center;transition:transform .3s}.feature-card:hover{transform:translateY(-5px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#2d3748;font-size:1.5rem;margin-bottom:.5rem}.feature-card p{color:#4a5568;line-height:1.6}@media (max-width:768px){.home{padding:1rem}.home-header{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.home-logo{font-size:1.1rem;margin-bottom:.25rem;width:100%}.home-logo .brand-icon{font-size:1.25rem}.home-auth{flex-wrap:wrap;justify-content:flex-end;width:100%}.hero{padding:2rem 1rem}.home .home-header~.hero{margin-top:70px}.hero-title{font-size:2rem}.hero-subtitle{font-size:.95rem}.features{gap:1rem;grid-template-columns:1fr;padding:0 1rem}.feature-card{padding:1.5rem}}@media (max-width:480px){.home{padding:.5rem}.home-header{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.home-logo{font-size:1rem}.home-auth{gap:.5rem}.home-login-link{font-size:.85rem}.hero{padding:1.5rem .5rem}.hero-title{font-size:1.75rem}.hero-subtitle{font-size:.85rem}.feature-card{padding:1rem}.feature-icon{font-size:2rem}}.auth-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:0 2rem 2rem}.auth-container .home-header{left:0;position:fixed;right:0;top:0;width:100%;z-index:1000}.auth-card{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;max-width:400px;padding:3rem;width:100%}.auth-container .home-header~.auth-card{margin-top:80px}@media (max-width:768px){.auth-container .home-header~.auth-card{margin-top:70px}}.auth-title{color:#2d3748;font-size:2rem;font-weight:700;margin-bottom:2rem;text-align:center}.error-message{border-radius:8px;margin-bottom:1rem;padding:12px;text-align:center}.btn-block{margin-top:1rem;width:100%}.auth-footer{color:#4a5568;margin-top:1.5rem;text-align:center}.auth-footer a{color:#667eea;font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.connection-status{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;margin-bottom:1.5rem;padding:12px}.status-item{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.status-item:last-child{margin-bottom:0}.status-label{color:#4a5568;font-weight:500}.status-success{color:#38a169;font-weight:600}.status-error{color:#e53e3e;font-weight:600}.join-quiz-container{align-items:center;background:linear-gradient(135deg,#e0e7ff,#ddd6fe);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding-top:0}.join-quiz-container .home-header{left:0;position:fixed;right:0;top:0;width:100%;z-index:1000}.join-quiz-card{background:#fffffff2;border-radius:12px;box-shadow:0 10px 25px #0003;max-width:400px;padding:3rem;text-align:center;width:100%}.join-quiz-container .home-header~.join-quiz-card{margin-top:80px}@media (max-width:768px){.join-quiz-container .home-header~.join-quiz-card{margin-top:70px}}.join-quiz-card h1{color:#2d3748;font-size:2.5rem;margin-bottom:.5rem}.subtitle{color:#4a5568;margin-bottom:2rem}.pin-input{color:#667eea;font-size:2rem;font-weight:700;letter-spacing:.5rem;text-align:center}.play-quiz{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);max-width:100%;min-height:100vh;overflow-x:hidden;padding:2rem}.play-quiz .home-header{left:0;position:fixed;right:0;top:0;width:100%;z-index:1000}@media (max-width:768px){.play-quiz{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);display:flex;flex-direction:column;max-height:100vh;min-height:100vh;overflow-y:auto;padding:0}}@media (max-width:768px) and (orientation:portrait){.play-quiz{height:100vh;max-height:100vh;overflow:hidden;padding:0}}.play-header{background:#fbbf24;border-radius:8px;margin-bottom:1rem;padding:1.5rem;text-align:center}.play-quiz .home-header~.play-header{margin-top:80px}@media (max-width:768px){.play-header{border-radius:0;flex-shrink:0;margin-bottom:.25rem;padding:.5rem .75rem}.play-quiz .home-header~.play-header{margin-top:70px}}@media (max-width:768px) and (orientation:portrait){.play-header{margin-bottom:.2rem;padding:.4rem .5rem}}.play-header-content{align-items:center;color:#000;display:flex;flex-wrap:wrap;font-weight:600;gap:1rem;justify-content:space-between}.play-header-title{color:#000;flex:1 1;font-size:1.5rem;font-weight:700;text-align:center}.question-counter,.score-display-small{color:#000;font-size:1.1rem}.timer{color:#dc2626;font-size:1.5rem;font-weight:700}@media (max-width:768px){.play-header-title{font-size:1.1rem}.score-display-small{font-size:.85rem}.question-counter{font-size:.8rem}.timer{font-size:1.1rem}}.waiting-screen p{color:#4a5568;margin-bottom:1rem}.quiz-info{background:#f7fafc;border-radius:8px;margin-top:2rem;padding:2rem}.quiz-info h3{color:#2d3748;margin-bottom:.5rem}.quiz-info p{color:#4a5568;margin:.25rem 0}.question-display{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:800px;padding:2rem}@media (max-width:768px){.question-display{border-radius:8px;display:flex;flex:1 1;flex-direction:column;margin-bottom:.25rem;min-height:0;overflow-y:auto;padding:.75rem}}@media (max-width:768px) and (orientation:portrait){.question-display{border-radius:0;margin-bottom:0;overflow-y:auto;padding:.5rem}}.question-text{font-size:1.5rem;line-height:1.3;margin-bottom:1.5rem;padding:0 1rem}@media (max-width:768px){.question-text{font-size:.95rem;line-height:3;margin-bottom:.5rem;padding:0 .25rem}}@media (max-width:768px) and (orientation:portrait){.question-text{font-size:.9rem;margin-bottom:.4rem;padding:0}}.question-image-container{align-items:center;aspect-ratio:700/400;background:#f3f4f6;border-radius:8px;display:flex;justify-content:center;margin:1.5rem auto;max-width:700px;position:relative;width:100%}.question-image-container:empty:before{color:#9ca3af;content:"Image";font-size:1.2rem}.question-image{height:100%;object-position:center}@media (max-width:768px){.question-image-container{margin:.5rem auto;max-width:100%;width:100%}}@media (max-width:768px) and (orientation:portrait){.question-image-container{margin:.3rem auto;max-width:100%;width:100%}}.options-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-bottom:2rem;padding:0 .5rem;position:relative}.known-text-overlay{animation:known-text-animation .3s ease-out forwards;top:0}@media (max-width:768px){.options-grid{flex-shrink:0;gap:.4rem;grid-template-columns:repeat(2,1fr);margin-bottom:.25rem;padding:0}}@media (max-width:768px) and (orientation:portrait){.options-grid{gap:.3rem;margin-bottom:.3rem}}.option-button{box-shadow:0 2px 8px #0000001a;color:#fff;gap:.75rem;min-height:80px;padding:1.25rem}@media (max-width:768px){.option-button{border-radius:6px;font-size:.85rem;gap:.4rem;min-height:55px;padding:.6rem}}@media (max-width:768px) and (orientation:portrait){.option-button{font-size:.8rem;gap:.3rem;min-height:50px;padding:.5rem}}.option-button:hover:not(:disabled){box-shadow:0 4px 12px #0003;transform:scale(1.05)}.option-button:disabled{cursor:not-allowed;opacity:.7}.option-button:first-child{background:#4b5563}.option-button:nth-child(2){background:#ec4899}.option-button:nth-child(3){background:#84cc16}.option-button:nth-child(4){background:#2563eb}.option-button.selected{border:4px solid #fff;box-shadow:0 0 20px #ffffff80}.option-button.correct{background:#48bb78;border:4px solid #2f855a}.option-button.incorrect{background:#f56565;opacity:.7}.option-letter{flex-shrink:0;min-width:40px}@media (max-width:768px){.option-letter{font-size:1.1rem;height:30px;min-width:30px;width:30px}}.answer-feedback{align-items:center;border-radius:12px;display:flex;flex-direction:column;font-size:1.5rem;font-weight:700;gap:1rem;margin-top:2rem;padding:1.5rem}@media (max-width:768px){.answer-feedback{flex-shrink:0;font-size:1rem;gap:.4rem;margin-top:.25rem;padding:.75rem}}@media (max-width:768px) and (orientation:portrait){.answer-feedback{font-size:.9rem;gap:.3rem;margin-top:.2rem;padding:.6rem}.answer-feedback .btn{font-size:.85rem;padding:.5rem 1rem}}.next-question-btn{margin-top:.5rem}@media (max-width:768px){.next-question-btn{font-size:.9rem;margin-top:.3rem;padding:.6rem 1.2rem}}@media (max-width:768px) and (orientation:portrait){.next-question-btn{font-size:.85rem;margin-top:.2rem;padding:.5rem 1rem}}.answer-feedback.correct{background:#c6f6d5;color:#22543d}.answer-feedback.incorrect{background:#fed7d7;color:#991b1b}.points-earned{font-size:1.25rem;margin-top:.5rem}.your-score{background:#f7fafc;border-radius:12px;margin-bottom:2rem;padding:2rem}.your-score h3{color:#2d3748;margin-bottom:1rem}.score-display{color:#667eea;font-size:3rem;font-weight:700}.leaderboard li.you{background:#edf2f7;border-color:#667eea}@media (max-width:480px){.play-quiz{padding:.25rem}.play-header{padding:.5rem}.question-display{padding:.75rem}.question-text{font-size:.9rem;margin-bottom:.5rem}.question-image-container{margin:.5rem auto;max-height:150px;min-height:100px}.question-image{max-height:150px}.options-grid{gap:.4rem;margin-bottom:.25rem}.option-button{font-size:.85rem;min-height:55px;padding:.6rem}.option-letter{font-size:1rem;height:28px;min-width:28px;width:28px}.answer-feedback{font-size:1rem;margin-top:.25rem;padding:.75rem}}.dashboard-container{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);box-sizing:border-box;display:flex;flex-direction:column;margin:0;min-height:100vh;overflow-x:hidden;padding:0;width:100%}.dashboard-header{align-items:center;background:#fff;border-bottom:2px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.5rem 2rem}.dashboard-header h1{color:#2d3748;flex:0 0 auto;font-size:2rem;font-weight:700;margin:0;padding-left:4rem;position:relative;z-index:1}.dashboard-content-wrapper{box-sizing:border-box;display:flex;flex:1 1;overflow:hidden;width:100%}.dashboard-content{box-sizing:border-box;flex:1 1;overflow-x:hidden;overflow-y:auto;padding:2rem}.dashboard-sidebar{background:#fff;border-left:2px solid #e2e8f0;display:flex;flex-direction:column;gap:1rem;overflow-y:auto;padding:1.5rem;width:240px}.dashboard-sidebar h3{color:#2d3748;font-size:1.25rem;font-weight:700;margin:0 0 .5rem}.sidebar-stats{display:flex;flex-direction:column;gap:.75rem}.sidebar-stat-card{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;padding:1rem;text-align:center}.sidebar-stat-label{color:#718096;font-size:.85rem;font-weight:600;margin-bottom:.5rem}.sidebar-stat-value{color:#2d3748;font-size:1.5rem;font-weight:700}.dashboard-error{color:#e53e3e;font-size:1.2rem;padding:2rem;text-align:center}.stats-grid{align-items:stretch;box-sizing:border-box;display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;gap:1.5rem;margin-bottom:2rem;width:100%}.stat-card{background:#fff;box-shadow:0 2px 8px #0000001a;color:#fff;flex:1 1!important;max-width:none;min-width:0;padding:1.5rem}.stat-card-blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-card-green{background:linear-gradient(135deg,#10b981,#059669)}.stat-card-yellow{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-card-teal{background:linear-gradient(135deg,#14b8a6,#0d9488)}.stat-card-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.stat-card-label{font-size:.9rem;opacity:.9}.stat-card-icon{font-size:1.5rem;opacity:.75}.stat-card-value{font-size:2.5rem;font-weight:700}.stat-card-value-small{font-size:1.5rem;font-weight:700}.stat-card-subtext{font-size:.85rem;margin-top:.5rem;opacity:.75}.level-badge-card{background:linear-gradient(135deg,#eef2ff,#f3e8ff);border:2px solid #c7d2fe;border-radius:12px;margin-bottom:2rem;padding:2rem}.level-badge-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1.5rem}.level-badge-title{align-items:center;color:#2d3748;display:flex;font-size:1.75rem;font-weight:700;gap:.75rem;margin:0 0 .5rem}.level-badge-icon{color:#6366f1;font-size:2rem}.level-badge-subtitle{color:#4b5563;margin:0}.level-badge-badge{border-radius:12px;color:#fff;font-size:1.5rem;font-weight:700;padding:.75rem 2rem}.level-badge-a1{background:linear-gradient(135deg,#f97316,#f59e0b)}.level-badge-a2{background:linear-gradient(135deg,#eab308,#84cc16)}.level-badge-b1{background:linear-gradient(135deg,#22c55e,#3b82f6)}.level-badge-b2{background:linear-gradient(135deg,#3b82f6,#6366f1)}.level-badge-c1{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.level-badge-c2{background:linear-gradient(135deg,#8b5cf6,#ec4899)}.level-badge-starter{background:linear-gradient(135deg,#9ca3af,#6b7280)}.level-badge-progress-header{color:#4b5563;display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:.5rem}.level-badge-progress-bar{background:#e5e7eb;border-radius:8px;height:1rem;overflow:hidden;width:100%}.level-badge-progress-fill{border-radius:8px;height:100%;transition:width .5s ease}.level-badge-progress-fill.level-badge-a1{background:linear-gradient(135deg,#f97316,#f59e0b)}.level-badge-progress-fill.level-badge-a2{background:linear-gradient(135deg,#eab308,#84cc16)}.level-badge-progress-fill.level-badge-b1{background:linear-gradient(135deg,#22c55e,#3b82f6)}.level-badge-progress-fill.level-badge-b2{background:linear-gradient(135deg,#3b82f6,#6366f1)}.level-badge-progress-fill.level-badge-c1{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.level-badge-progress-fill.level-badge-c2{background:linear-gradient(135deg,#8b5cf6,#ec4899)}.level-badge-progress-fill.level-badge-starter{background:linear-gradient(135deg,#9ca3af,#6b7280)}.badges-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;padding:2rem}.section-title{color:#2d3748;font-size:1.75rem;font-weight:700;margin:0 0 1.5rem}.badges-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr)}.badge-item{border:2px solid;border-radius:12px;padding:1.5rem;text-align:center}.badge-yellow{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#fbbf24}.badge-green{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#10b981}.badge-purple{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);border-color:#8b5cf6}.badge-blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6}.badge-emoji{font-size:3rem;margin-bottom:.5rem}.badge-label{font-weight:700;margin-bottom:.5rem}.badge-yellow .badge-label{color:#92400e}.badge-green .badge-label{color:#065f46}.badge-purple .badge-label{color:#6b21a8}.badge-blue .badge-label{color:#1e40af}.badge-value{font-size:2rem;font-weight:700;margin-bottom:.25rem}.badge-yellow .badge-value{color:#78350f}.badge-green .badge-value{color:#064e3b}.badge-purple .badge-value{color:#581c87}.badge-blue .badge-value{color:#1e3a8a}.badge-subtext{font-size:.75rem;margin-top:.25rem}.badge-yellow .badge-subtext{color:#92400e}.badge-green .badge-subtext{color:#065f46}.badge-purple .badge-subtext{color:#6b21a8}.module-time-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;padding:2rem}.module-time-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}@media (max-width:992px){.level-charts-grid{grid-template-columns:repeat(3,1fr)}.badges-grid{grid-template-columns:repeat(2,1fr)}}.module-time-item{background:#f0fdf4;border-radius:8px;padding:1rem}.module-time-content{align-items:center;display:flex;gap:.75rem}.module-time-icon{color:#10b981;font-size:2rem}.module-time-label{color:#4b5563;font-size:.9rem;margin:0 0 .25rem}.module-time-value{color:#2d3748;font-size:1.25rem;font-weight:700;margin:0}.level-progress-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;padding:2rem}.level-charts-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(6,1fr)}.level-chart-item{text-align:center}.level-chart-label{color:#2d3748;font-size:1.1rem;font-weight:700;margin-bottom:.5rem}.level-chart-empty{align-items:center;color:#9ca3af;display:flex;font-size:.9rem;height:120px;justify-content:center}.level-chart-stats{color:#4b5563;font-size:.9rem;margin-top:.5rem}.categories-card,.known-total-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:2rem}.known-total-card{margin-bottom:2rem}.known-total-chart-loading{align-items:center;color:#9ca3af;display:flex;height:300px;justify-content:center}@media (max-width:992px){.badges-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:968px){.dashboard-content-wrapper{flex-direction:column}.dashboard-sidebar{-webkit-overflow-scrolling:touch;border-left:none;border-top:2px solid #e2e8f0;flex-direction:row;flex-shrink:0;gap:.75rem;justify-content:space-around;overflow-x:auto;padding:.75rem;width:100%}.dashboard-sidebar h3{display:none}.sidebar-stats{flex-direction:row;gap:.75rem;justify-content:space-around;width:100%}.sidebar-stat-card{flex:1 1;min-width:0;padding:.75rem}.sidebar-stat-label{font-size:.75rem;margin-bottom:.25rem}.sidebar-stat-value{font-size:1.25rem}}@media (max-width:768px){.dashboard-content{padding:.75rem}.dashboard-header{flex-wrap:wrap;gap:.5rem;padding:.75rem .75rem .75rem 4rem;position:relative}.dashboard-header h1{font-size:1.5rem;margin-bottom:.25rem;margin-left:0;padding-left:.75rem;position:relative;width:100%;z-index:1}.stats-grid{-webkit-overflow-scrolling:touch;flex-direction:row!important;flex-wrap:nowrap!important;gap:.5rem;overflow-x:auto;padding-bottom:.5rem}.stat-card{flex:0 0 auto!important;min-width:140px;padding:.75rem}.stat-card .stat-icon{font-size:1.5rem;height:35px;width:35px}.stat-card .stat-value{font-size:1.25rem;margin:.25rem 0}.stat-card .stat-label{font-size:.7rem}.stat-card .stat-sublabel{font-size:.65rem}.badges-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)!important}.level-charts-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)}.module-time-grid{gap:1rem;grid-template-columns:1fr}.level-badge-header{align-items:flex-start;flex-direction:column;gap:1rem}.level-badge-card{padding:1rem}.level-badge-card h3{font-size:1.1rem}.level-badge-button{font-size:1rem;padding:1rem;width:100%}.badges-card,.categories-card,.known-total-card,.level-progress-card,.module-time-card{padding:1rem}.badges-card h3,.categories-card h3,.known-total-card h2,.level-progress-card h3,.module-time-card h3{font-size:1.1rem;margin-bottom:.75rem}.dashboard-sidebar{max-height:none;padding:.75rem}.dashboard-sidebar,.sidebar-stats{flex-direction:column;gap:.75rem}.sidebar-stat-card{width:100%}}@media (max-width:480px){.stats-grid{flex-direction:column!important;overflow-x:visible}.stat-card{min-width:100%;width:100%}.quick-stats-grid{grid-template-columns:1fr}}.create-quiz-container{margin:0 auto;max-width:1400px;padding:2rem}.create-quiz-header{margin-bottom:2rem}.create-quiz-header h1{color:#2d3748;font-size:2rem;margin:0}.import-source-section,.questions-section,.quiz-info-section{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:1.5rem}.import-source-section h2,.questions-section h2,.quiz-info-section h2{color:#2d3748;font-size:1.5rem;margin:0 0 1.5rem}.form-input,.form-select{border-radius:8px;font-size:1rem;padding:.75rem}.processing-section{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:1.5rem;padding:1rem}.progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.progress-status{color:#2d3748;font-weight:600}.processing-details{margin-top:1rem}.processing-logs{background:#fff;border:1px solid #e2e8f0;border-radius:6px;max-height:300px;overflow-y:auto;padding:1rem}.log-entry{color:#4a5568;font-family:monospace;font-size:.875rem;padding:.25rem 0}@media (max-width:768px){.create-quiz-container{padding:1rem}.form-row,.questions-grid{grid-template-columns:1fr}.file-upload-group,.webpage-input-group{flex-direction:column}}.edit-quiz-container{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);min-height:100vh;padding:2rem}.edit-quiz-layout{display:flex;flex-direction:column;gap:2rem;margin:0 auto;max-width:1600px}.edit-quiz-pane,.questions-pane{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:2rem}.edit-quiz-pane h1{color:#2d3748;margin-bottom:2rem}.questions-pane h2{color:#2d3748;margin:0}.questions-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.no-questions-message{background:#f7fafc;border:2px dashed #e2e8f0;border-radius:8px;color:#718096;padding:3rem;text-align:center}.questions-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.question-card{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px}.question-card-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.question-card-header h3{color:#2d3748;font-size:1.1rem;margin:0}.question-card-body{display:flex;flex-direction:column;gap:1rem}@media (max-width:1024px){.edit-quiz-layout{grid-template-columns:1fr}.form-row{grid-template-columns:1fr 1fr}.questions-grid{grid-template-columns:1fr}}@media (max-width:768px){.edit-quiz-container{padding:1rem}.edit-quiz-pane,.questions-pane{padding:1.5rem}.form-row{grid-template-columns:1fr}.questions-header{align-items:flex-start;gap:1rem}.form-actions,.questions-header{flex-direction:column}.form-actions .btn{width:100%}}.host-quiz{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);min-height:100vh;padding:2rem}@media (max-width:768px){.host-quiz{padding:1rem}.host-header{align-items:flex-start;flex-direction:column;gap:1rem;padding:1rem}.host-header h1,.pin-display{font-size:1.5rem}}@media (max-width:480px){.host-quiz{padding:.5rem}.host-header{padding:.75rem}}.host-header{align-items:center;background:#fffffff2;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:2rem;padding:2rem}.host-header h1{color:#2d3748;margin-bottom:.5rem}.host-header p{color:#4a5568;margin:.25rem 0}.pin-display{color:#667eea;font-size:2rem;font-weight:700}.waiting-screen{text-align:center}.waiting-screen h2{color:#2d3748;margin-bottom:1rem}.participants-list{margin-top:2rem;text-align:left}.participants-list h3{color:#2d3748;margin-bottom:1rem}.participants-list ul{list-style:none;padding:0}.participants-list li{background:#f7fafc;border-radius:6px;color:#2d3748;margin-bottom:.5rem;padding:.75rem}.question-header{color:#4a5568;display:flex;font-weight:600;justify-content:space-between;margin-bottom:2rem}.question-text{font-size:2.5rem}.question-image-container{border-radius:12px;margin:1.5rem 0;max-width:100%;overflow:hidden}.question-image{display:block;height:auto;max-height:400px;object-fit:cover;width:100%}.options-display{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr);margin-bottom:2rem}.option-box{align-items:center;border-radius:12px;color:#fff;display:flex;font-size:1.25rem;font-weight:600;gap:1rem;min-height:100px;padding:2rem;text-align:left}.option-1{background:#667eea}.option-2{background:#f093fb}.option-3{background:#4facfe}.option-4{background:#43e97b}.option-letter{font-size:2rem;height:50px;width:50px}.all-questions-display{display:flex;flex-direction:column;gap:1.5rem}.questions-header{padding:1.5rem;text-align:center}.questions-header h2{color:#2d3748;margin-bottom:.5rem}.questions-header p{color:#4a5568;font-size:1.1rem}.questions-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,500px));justify-content:start;max-height:60vh;overflow-y:auto;padding:.5rem}.question-card{border:2px solid #0000;box-sizing:border-box;display:flex;flex-direction:column;max-width:500px;padding:1.5rem;transition:all .5s ease;width:100%}.question-card.active-question{background:#f7fafc;border-color:#667eea;box-shadow:0 4px 12px #667eea33}.question-card .question-number{color:#667eea;flex-shrink:0;font-size:.9rem;font-weight:600;height:24px;letter-spacing:.5px;margin-bottom:1rem;order:1;text-transform:uppercase}.question-card .question-text{word-wrap:break-word;-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#2d3748;display:-webkit-box;flex-shrink:0;font-size:1.2rem;font-weight:600;line-height:1.4;margin-bottom:1rem;max-height:80px;min-height:80px;order:2;overflow:hidden;text-overflow:ellipsis}.question-card .question-image-container{align-items:center;background:#f3f4f6;border-radius:8px;display:flex;flex-shrink:0;height:200px;justify-content:center;margin:0 0 1rem;max-height:200px;min-height:200px;order:3;overflow:hidden;width:100%}.question-card .question-image{display:block;height:100%;max-height:200px;object-fit:contain;width:100%}.question-card .options-display{grid-gap:.75rem;display:grid;flex-shrink:0;gap:.75rem;grid-template-columns:repeat(2,1fr);margin-top:0;order:4}.question-card .option-box{align-items:center;box-sizing:border-box;display:flex;font-size:.9rem;gap:.75rem;height:70px;max-height:70px;min-height:70px;overflow:hidden;padding:1rem;position:relative}.question-card .option-letter{align-items:center;display:flex;font-size:1rem;height:30px;justify-content:center;min-width:30px;width:30px}.question-card .option-text{word-wrap:break-word;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;flex:1 1;line-height:1.3;min-width:0;overflow:hidden;text-overflow:ellipsis}.correct-mark{background:#48bb78;border-radius:4px;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .5rem;position:absolute;right:.5rem;top:.5rem}.question-actions{display:flex;gap:1rem;justify-content:center;padding:1.5rem}.question-actions button:disabled{cursor:not-allowed;opacity:.5}.students-stats{margin-top:1.5rem}.students-stats h3{color:#2d3748;margin-bottom:1rem;text-align:center}.stats-list{display:flex;flex-direction:column;gap:.75rem}.student-stat{align-items:center;background:#f7fafc;border-left:4px solid #667eea;border-radius:8px;display:flex;flex-wrap:wrap;font-size:1rem;gap:.5rem;justify-content:flex-start;padding:1rem}.student-name{color:#2d3748;font-weight:600;min-width:120px}.stat-separator{color:#cbd5e0;margin:0 .5rem}.stat-item{color:#4a5568;font-weight:500;min-width:60px;text-align:center}.stat-correct{color:#48bb78}.stat-correct,.stat-wrong{font-weight:600;min-width:80px;text-align:center}.stat-wrong{color:#f56565}.leaderboard{background:#f7fafc;border-radius:12px;margin:2rem 0;padding:2rem}.leaderboard h3{color:#2d3748;margin-bottom:1.5rem}.leaderboard ol{list-style:none;margin:0 auto;max-width:500px;padding:0}.leaderboard li{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;display:flex;gap:1rem;margin-bottom:.5rem;padding:1rem}.leaderboard li.winner{background:#fffbeb;border-color:#fbbf24}.rank{color:#667eea;font-size:1.5rem;font-weight:700;width:40px}.name{color:#2d3748;flex:1 1;font-weight:600;text-align:left}.score{font-size:1.1rem}.error-screen{padding:3rem;text-align:center}.error-screen h2{color:#f56565;font-size:2rem;margin-bottom:1rem}.error-screen p{color:#4a5568;font-size:1.1rem;margin-bottom:2rem}.error-help{background:#f7fafc;border-radius:8px;margin-top:2rem;padding:2rem;text-align:left}.error-help h3{color:#2d3748;margin-bottom:1rem}.error-help ul{color:#4a5568;margin-bottom:1.5rem;padding-left:1.5rem}.error-help li{margin-bottom:.5rem}.error-help code{background:#e2e8f0;border-radius:4px;color:#2d3748;font-family:monospace;padding:2px 6px}.error-help button{margin:.5rem}@media (max-width:768px){.host-header{align-items:flex-start;flex-direction:column;gap:1rem;padding:1.5rem}.host-header h1{font-size:1.5rem}.options-display{gap:1rem;grid-template-columns:1fr}.question-text{font-size:1.5rem;margin-bottom:1rem}.question-image{max-height:250px}.option-box{font-size:1.1rem;min-height:80px;padding:1.25rem}.option-letter{font-size:1.5rem;height:40px;min-width:40px;width:40px}.questions-list{gap:1rem;grid-template-columns:1fr}.question-card{max-width:100%;padding:1.25rem}.question-card .question-text{font-size:1.1rem;max-height:70px;min-height:70px}.question-card .question-image-container{height:180px;max-height:180px;min-height:180px}.question-card .question-image{max-height:180px}.question-card .options-display{gap:.75rem}.question-card .option-box{font-size:.85rem;height:65px;max-height:65px;min-height:65px;overflow:hidden;padding:.875rem}.question-card .option-text{-webkit-line-clamp:2}.question-card .option-letter{font-size:.9rem;height:28px;min-width:28px;width:28px}.students-stats{margin-top:1rem}.student-stat{flex-wrap:wrap;font-size:.9rem;padding:.75rem}.student-name{font-size:.9rem;min-width:100px}}@media (max-width:480px){.host-header{padding:1rem}.host-header h1{font-size:1.25rem}.pin-display{font-size:1.5rem}.question-text{font-size:1.25rem}.question-image{max-height:200px}.option-box{font-size:1rem;gap:.5rem;min-height:70px;padding:1rem}.option-letter{font-size:1.25rem;height:35px;min-width:35px;width:35px}.questions-list{gap:.75rem;grid-template-columns:1fr}.question-card{max-width:100%;padding:1rem}.question-card .question-text{font-size:1rem;max-height:60px;min-height:60px}.question-card .question-image-container{height:150px;max-height:150px;min-height:150px}.question-card .question-image{max-height:150px}.question-card .option-box{font-size:.8rem;height:60px;max-height:60px;min-height:60px;overflow:hidden;padding:.75rem}.question-card .option-text{-webkit-line-clamp:2}.question-card .option-letter{font-size:.85rem;height:25px;min-width:25px;width:25px}.student-stat{font-size:.85rem;padding:.625rem}.student-name{font-size:.85rem;min-width:80px}}.self-paced-quiz{color:#fff}.quiz-header{background:#fffffff2;border-radius:12px;margin-bottom:2rem;padding:2rem;text-align:center}.quiz-header h1{color:#2d3748;margin-bottom:1rem}.progress-bar{background:#e2e8f0;border-radius:4px;margin-bottom:1rem}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s}.quiz-header p{color:#4a5568;font-weight:600}.question-display{text-align:center}.question-text{color:#2d3748;margin-bottom:2rem}.options-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.option-button{align-items:center;border:none;border-radius:12px;color:#000;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:1rem;padding:1rem;text-align:left;transition:all .3s}.option-button:hover{box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.option-button.selected{border:3px solid #fff;box-shadow:0 0 15px #ffffff80}.option-button:first-child{background:#667eea}.option-button:nth-child(2){background:#f093fb}.option-button:nth-child(3){background:#4facfe}.option-button:nth-child(4){background:#43e97b}.option-letter{align-items:center;background:#ffffff4d;border-radius:50%;display:flex;font-size:1.5rem;font-weight:700;height:40px;justify-content:center;width:40px}.option-text{flex:1 1}.question-actions{margin-top:2rem}.results-screen{text-align:center}.results-screen h2{color:#2d3748;font-size:2.5rem;margin-bottom:2rem}.results-summary{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:2rem}.stat{background:#f7fafc;border-radius:12px;padding:1.5rem}.stat-value{color:#667eea;font-size:2.5rem;margin-bottom:.5rem}.stat-label{color:#4a5568}.performance-container{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);box-sizing:border-box;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;width:100%}.performance-header{align-items:center;background:#fff;border-bottom:2px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.5rem 2rem}.performance-header h1{color:#2d3748;flex:0 0 auto;font-size:2rem;font-weight:700;margin:0;padding-left:2.5rem;position:relative;z-index:1}.performance-content-wrapper{box-sizing:border-box;display:flex;flex:1 1;overflow:hidden;width:100%}.performance-content{box-sizing:border-box;flex:1 1;overflow-x:hidden;overflow-y:auto;padding:2rem}.performance-sidebar{background:#fff;border-left:2px solid #e2e8f0;display:flex;flex-direction:column;gap:1rem;overflow-y:auto;padding:1.5rem;width:240px}.performance-sidebar h3{color:#2d3748;font-size:1.25rem;font-weight:700;margin:0 0 .5rem}.sidebar-filters{display:flex;flex-direction:column;gap:.75rem}.sidebar-filter-item{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;padding:.75rem}.sidebar-filter-label{color:#718096;display:block;font-size:.75rem;font-weight:600;margin-bottom:.25rem;text-transform:uppercase}.sidebar-filter-value{color:#2d3748;display:block;font-size:.9rem;font-weight:500}.summary-cards-simple{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.summary-card-simple{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;gap:1rem;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.summary-card-simple:hover{box-shadow:0 6px 20px #00000026;transform:translateY(-2px)}.summary-card-icon{flex-shrink:0;font-size:2.5rem}.summary-card-content{flex:1 1}.summary-card-value{color:#1e293b;font-size:2rem;font-weight:700;margin-bottom:.25rem}.summary-card-label{color:#64748b;font-size:.875rem;font-weight:500}@media (max-width:768px){.summary-cards-simple{gap:.75rem;grid-template-columns:repeat(2,minmax(0,1fr))}.summary-card-simple{box-sizing:border-box;min-width:0;width:100%}.filters-row{flex-direction:column}.filter-group-simple{width:100%}.filter-actions-simple{justify-content:stretch;width:100%}.filter-actions-simple .btn{flex:1 1}}.summary-cards{grid-gap:1.5rem;align-items:start;display:grid;gap:1.5rem;grid-template-columns:1fr 3fr;margin-bottom:2rem}.summary-card-large{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;min-height:-webkit-fit-content;min-height:fit-content}.summary-cards-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,auto);position:relative}.summary-card-row-1,.summary-card-row-2{position:relative}.summary-card-row-2:before{background:linear-gradient(90deg,#0000,#3b82f680 10%,#3b82f680 90%,#0000);box-shadow:0 2px 4px #3b82f64d;content:"";height:3px;left:-1rem;position:absolute;right:-1rem;top:-.5rem;z-index:1}.summary-card-row-3{position:relative}.summary-card-row-3:before{background:linear-gradient(90deg,#0000,#10b98180 10%,#10b98180 90%,#0000);box-shadow:0 2px 4px #10b9814d;content:"";height:3px;left:-1rem;position:absolute;right:-1rem;top:-.5rem;z-index:1}@media (max-width:1400px){.summary-cards{grid-template-columns:1fr 3fr}}@media (max-width:1200px){.summary-cards{grid-template-columns:1fr}.summary-card-large{grid-row:span 1}.summary-cards-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:auto}}@media (max-width:768px){.summary-cards-grid{grid-template-columns:1fr}}.summary-card{border-radius:16px;box-shadow:0 8px 16px #00000026;color:#fff;overflow:hidden;padding:1.5rem;position:relative;text-align:center}.summary-card-yellow{background:linear-gradient(135deg,#f59e0b,#d97706)}.summary-card-quiz{background:linear-gradient(135deg,#3b82f6,#2563eb)}.summary-card-game{background:linear-gradient(135deg,#10b981,#059669)}.summary-card-pronunciation{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.summary-card:hover{box-shadow:0 12px 24px #0003}.summary-emoji{opacity:.9}.summary-emoji,.summary-value{font-size:2.5rem;margin-bottom:.5rem}.summary-value{color:#fff;font-weight:700}.summary-label{color:#ffffffe6;font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.filters-panel-simple{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:2rem;padding:1.25rem 1.5rem}.filters-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:1rem}.filter-group-simple{display:flex;flex:1 1;flex-direction:column;gap:.5rem;min-width:150px}.filter-group-simple label{color:#475569;font-size:.875rem;font-weight:600}.filter-group-simple input{border:1px solid #cbd5e1;border-radius:8px;font-size:.875rem;padding:.625rem .875rem;transition:border-color .2s ease,box-shadow .2s ease}.filter-group-simple input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.filter-actions-simple{display:flex;flex-shrink:0;gap:.5rem}.btn-small{font-size:.875rem;padding:.625rem 1.25rem}.filters-panel{background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid #667eea33;border-radius:16px;box-shadow:0 10px 25px #667eea26,0 4px 10px #0000000d;margin-bottom:2rem;overflow:hidden;padding:1.5rem 2rem;position:relative}.filters-panel:before{background:linear-gradient(90deg,#667eea,#764ba2 50%,#f093fb);box-shadow:0 2px 8px #667eea4d;content:"";height:5px;left:0;position:absolute;right:0;top:0}.filters-panel h2{align-items:center;color:#1e293b;display:flex;font-size:1.5rem;font-weight:700;gap:.75rem;margin-bottom:1.25rem}.filters-panel h2:before{content:"🔍";font-size:1.5rem}.filters-grid{align-items:flex-end;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-start;margin-bottom:1.5rem}.filter-group{flex:0 0 auto;flex-direction:column;position:relative;width:160px}@media (max-width:1400px){.filter-group{width:180px}}@media (max-width:768px){.filters-grid{align-items:stretch;flex-direction:column}.filter-group{max-width:100%;min-width:100%}}.filter-group label{align-items:center;color:#475569;display:flex;font-size:.85rem;font-weight:600;gap:.3rem;letter-spacing:.2px;margin-bottom:.4rem}.filter-group input,.filter-group select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #00000005;box-sizing:border-box;color:#1e293b;font-family:inherit;font-size:.72rem;height:30px;padding:.4rem .6rem;width:100%}.filter-group input:hover,.filter-group select:hover{background:linear-gradient(135deg,#fff,#faf5ff);border-color:#a78bfa;box-shadow:0 4px 12px #8b5cf633}.filter-group input:focus,.filter-group select:focus{background:linear-gradient(135deg,#fff,#f0f9ff);border-color:#667eea;box-shadow:0 0 0 3px #667eea33,0 4px 16px #667eea40;outline:none}.filter-group input::placeholder{color:#94a3b8;opacity:.7}.filter-actions-inline{align-items:flex-end;display:flex;flex:0 0 auto;gap:.5rem}.filter-actions-inline .btn{font-size:.72rem;height:30px;padding:.4rem 1rem;white-space:nowrap}.performance-table-container{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #e2e8f0cc;border-radius:16px;box-shadow:0 10px 25px #0000001a,0 4px 10px #0000000d;padding:2rem}.performance-table-container h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.table-wrapper{overflow-x:auto}.performance-table{border-collapse:collapse;font-size:.95rem;width:100%}.performance-table thead{background:linear-gradient(135deg,#667eea,#764ba2)}.performance-table th{border-bottom:2px solid #fff3;color:#fff;font-weight:600;padding:1rem;text-align:left;text-shadow:0 1px 2px #0000001a}.performance-table th:has(div){white-space:normal}.performance-table th:not(:has(div)){white-space:nowrap}.performance-table th div{line-height:1.3;white-space:normal}.performance-table th div:first-child{margin-bottom:.25rem}.performance-table td{border-bottom:1px solid #e2e8f0;color:#4a5568;padding:1rem}.performance-table tbody tr:hover{background:linear-gradient(90deg,#667eea0d,#764ba20d);box-shadow:0 2px 8px #667eea1a}.performance-table tbody tr.expanded{background:linear-gradient(90deg,#667eea1a,#764ba21a)}.student-name{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);font-size:1.05rem}.correct,.student-name{-webkit-background-clip:text;background-clip:text;font-weight:700}.correct{color:#000}.wrong{background:linear-gradient(135deg,#ef4444,#dc2626);-webkit-background-clip:text;background-clip:text;color:#ef4444}.score,.wrong{-webkit-text-fill-color:#0000;font-weight:700}.score{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#667eea}.accuracy{border-radius:8px;display:inline-block;font-size:.9rem;font-weight:700;padding:.35rem .75rem}.accuracy-low{background:linear-gradient(135deg,#fee2e2,#fecaca);box-shadow:0 2px 6px #dc262633;color:#dc2626}.accuracy-medium{background:linear-gradient(135deg,#fef3c7,#fde68a);box-shadow:0 2px 6px #d9770633;color:#d97706}.accuracy-high{background:linear-gradient(135deg,#d1fae5,#a7f3d0);box-shadow:0 2px 6px #05966933;color:#059669}.detail-row{background:#f7fafc}.detail-row td{border:none;padding:0}.session-details{padding:1.5rem}.session-details h3{color:#2d3748;font-size:1.2rem;font-weight:700;margin-bottom:1rem}.session-card{background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid #667eea33;border-radius:12px;box-shadow:0 4px 12px #667eea1a;padding:1.5rem}.session-card:hover{border-color:#667eea66;box-shadow:0 8px 20px #667eea33}.session-header{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.session-header h4{color:#2d3748;flex:1 1;font-size:1.1rem;font-weight:600;margin:0;min-width:200px}.session-badges{display:flex;flex-wrap:wrap;gap:.5rem}.session-meta{flex-wrap:wrap;margin-bottom:1rem}.session-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.session-stats .stat{background:linear-gradient(135deg,#f7fafc,#f1f5f9);border-left:3px solid #667eea;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem}.session-stats .stat:hover{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.session-stats .stat-label{color:#718096;font-weight:500}.session-stats .stat-value{color:#1e293b;font-weight:700}.session-stats .stat-value.correct{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#10b981,#059669);-webkit-background-clip:text;background-clip:text}.session-stats .stat-value.wrong{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#ef4444,#dc2626);-webkit-background-clip:text;background-clip:text}.badge-level{box-shadow:0 2px 4px #3b82f633;color:#1e40af;font-weight:600}.badge-skill{background:linear-gradient(135deg,#d1fae5,#a7f3d0);box-shadow:0 2px 4px #10b98133;color:#047857;font-weight:600}.badge-task{background:linear-gradient(135deg,#ede9fe,#ddd6fe);box-shadow:0 2px 4px #8b5cf633;color:#7c3aed;font-weight:600}.btn-primary{border:none;font-weight:600;letter-spacing:.5px}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#5568d3,#6a3f8f);box-shadow:0 6px 16px #667eea66}.btn-primary:active:not(:disabled){box-shadow:0 2px 8px #667eea4d}.btn-secondary{background:linear-gradient(135deg,#fff,#f1f5f9);border:2px solid #cbd5e1;box-shadow:0 2px 6px #00000014;color:#475569;font-weight:600;letter-spacing:.5px}.btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-color:#94a3b8;box-shadow:0 4px 12px #0000001f;color:#334155}.btn-secondary:active:not(:disabled){box-shadow:0 2px 4px #0000000d}.btn-small{font-size:.85rem;padding:.4rem .8rem}.empty-state{background:#fffffff2;box-shadow:0 4px 6px #0000001a}.empty-state p{color:#4a5568;font-size:1.1rem;margin-bottom:1.5rem}.quiz-performance-container{border-image:linear-gradient(90deg,#3b82f6,#8b5cf6 50%,#ec4899) 1;border-top:3px solid;margin-top:3rem;padding-top:2rem}.quiz-performance-container h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.game-stats-container{border-image:linear-gradient(90deg,#667eea,#764ba2 50%,#f093fb) 1;border-top:3px solid;margin-top:3rem;padding-top:2rem}.game-stats-container h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.pronunciation-stats-container{border-image:linear-gradient(90deg,#f093fb,#f5576c 50%,#4facfe) 1;border-top:3px solid;margin-top:3rem;padding-top:2rem}.pronunciation-stats-container h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#f093fb,#f5576c);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.pronunciation-type-section{background:linear-gradient(135deg,#f093fb1a,#f5576c1a);border:1px solid #f093fb4d;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.pronunciation-type-section h4{color:#7c3aed;font-size:1.1rem;font-weight:600;margin-bottom:1rem}.pronunciation-summary{background:#fffc;border-radius:8px;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1rem}.word-analysis{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.5rem}.word-status{border-radius:6px;cursor:help;font-size:.9rem;font-weight:600;padding:.3rem .6rem}.word-matched{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981;color:#047857}.word-missing{background:linear-gradient(135deg,#fee2e2,#fecaca);border:2px solid #ef4444;color:#991b1b}.word-wrong{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;color:#92400e}.pronunciation-scores{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.pronunciation-scores span{cursor:help}.score-overall{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700}.score-pronunciation{color:#7c3aed;font-size:1rem;font-weight:600}.score-fluency{color:#f59e0b}.score-content,.score-fluency{font-size:1rem;font-weight:600}.score-content{color:#3b82f6}.pronunciation-date-spacer{margin-left:2rem;min-width:2rem}.pronunciation-date{color:#6b7280;font-size:.85rem;margin-left:auto}.pronunciation-item-card{background:#fff;border:1px solid #f093fb4d;border-radius:12px;box-shadow:0 4px 6px #0000001a;margin-bottom:1rem;padding:1.5rem}.pronunciation-item-header{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;gap:1.5rem;justify-content:space-between}@media (max-width:768px){.pronunciation-item-header{align-items:flex-start;flex-direction:column}}.pronunciation-items-list{display:flex;flex-direction:column;gap:1rem}@media (max-width:768px){.performance-container{padding:.5rem}.performance-header{align-items:flex-start;flex-direction:column;gap:.5rem;padding:.75rem .75rem .75rem 2.5rem;position:relative}.performance-header h1{font-size:1.5rem;margin-left:0;padding-left:.75rem;position:relative;width:100%;z-index:1}.performance-content-wrapper{flex-direction:column}.performance-sidebar{border-left:none;border-top:2px solid #e2e8f0;padding:1rem;width:100%}.summary-cards-simple{gap:.75rem;grid-template-columns:repeat(2,1fr);margin-bottom:1rem}.summary-card-simple{padding:1rem .75rem}.summary-card-simple .card-icon{font-size:1.5rem;height:40px;width:40px}.summary-card-simple .card-value{font-size:1.25rem}.summary-card-simple .card-label{font-size:.7rem}.filters-panel{margin-bottom:1rem;padding:1rem}.filters-panel h2{font-size:1.1rem;margin-bottom:.75rem}.filters-grid{gap:.75rem;grid-template-columns:1fr}.filter-group{margin-bottom:0}.filter-group label{font-size:.85rem;margin-bottom:.25rem}.filter-group input,.filter-group select{font-size:.9rem;padding:.6rem}.performance-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto;padding:.5rem}.performance-table{font-size:.75rem;min-width:600px}.performance-table td.group-separator,.performance-table th.group-separator{border-left:2px solid #667eea4d;padding-left:1rem}.performance-table td,.performance-table th{padding:.5rem .35rem}.stacked-cell{padding:.5rem .75rem}.stacked-top{font-size:.9rem;margin-bottom:.15rem}.stacked-bottom{font-size:.8rem}.session-header{align-items:flex-start;flex-direction:column;gap:.5rem}.session-header h4{font-size:1rem;min-width:auto}.session-stats{gap:.75rem;grid-template-columns:1fr}.session-stats .stat{padding:.6rem}.game-stats-container,.pronunciation-stats-container,.quiz-performance-container{margin-top:2rem;padding-top:1.5rem}.game-stats-container h2,.pronunciation-stats-container h2,.quiz-performance-container h2{font-size:1.25rem;margin-bottom:1rem}.game-stats-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.game-stats-table{font-size:.75rem;min-width:500px}.pronunciation-type-section{padding:1rem}.pronunciation-summary{flex-direction:column;gap:.75rem;padding:.75rem}}@media (max-width:480px){.summary-cards-simple{gap:.5rem;grid-template-columns:repeat(2,minmax(0,1fr))}.summary-card-simple{box-sizing:border-box;min-width:0;width:100%}.performance-table{font-size:.7rem}.performance-table td,.performance-table th{padding:.4rem .25rem}}@-webkit-keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size:12px;--rc-drag-handle-mobile-size:24px;--rc-drag-handle-bg-colour:#0003;--rc-drag-bar-size:6px;--rc-border-color:#ffffffb3;--rc-focus-color:#08f}.ReactCrop{cursor:crosshair;display:inline-block;max-width:100%;position:relative}.ReactCrop *,.ReactCrop :after,.ReactCrop :before{-webkit-box-sizing:border-box;box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{max-height:inherit;overflow:hidden}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-height:inherit;max-width:100%}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{-ms-touch-action:none;touch-action:none}.ReactCrop__crop-mask{bottom:0;height:calc(100% + .5px);left:0;pointer-events:none;position:absolute;right:0;top:0;width:calc(100% + .5px)}.ReactCrop__crop-selection{cursor:move;left:0;position:absolute;top:0;-webkit-transform:translateZ(0);transform:translateZ(0)}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{border:1px solid #ffffffb3;border:1px solid var(--rc-border-color);bottom:-1px;content:"";left:-1px;opacity:.3;pointer-events:none;position:absolute;right:-1px;top:-1px}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed #fff}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){-webkit-animation:marching-ants 1s;animation:marching-ants 1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-play-state:running;animation-play-state:running;-webkit-animation-timing-function:linear;animation-timing-function:linear;background-image:-webkit-gradient(linear,left top,right top,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,right top,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,left bottom,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,left bottom,color-stop(50%,#fff),color-stop(50%,#444));background-image:linear-gradient(90deg,#fff 50%,#444 0),linear-gradient(90deg,#fff 50%,#444 0),linear-gradient(180deg,#fff 50%,#444 0),linear-gradient(180deg,#fff 50%,#444 0);background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;background-size:10px 1px,10px 1px,1px 10px,1px 10px;color:#fff}.ReactCrop__crop-selection:focus{outline:2px solid #08f;outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-hz:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-vt:before{background-color:#fff6;content:"";display:block;position:absolute}.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-vt:before{height:100%;width:1px}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:after,.ReactCrop__rule-of-thirds-hz:before{height:1px;width:100%}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{background-color:#0003;background-color:var(--rc-drag-handle-bg-colour);border:1px solid #ffffffb3;border:1px solid var(--rc-border-color);height:12px;height:var(--rc-drag-handle-size);position:absolute;width:12px;width:var(--rc-drag-handle-size)}.ReactCrop__drag-handle:focus{background:#08f;background:var(--rc-focus-color)}.ReactCrop .ord-nw{cursor:nw-resize;left:0}.ReactCrop .ord-n,.ReactCrop .ord-nw{top:0;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}.ReactCrop .ord-n{cursor:n-resize;left:50%}.ReactCrop .ord-ne{cursor:ne-resize;top:0}.ReactCrop .ord-e,.ReactCrop .ord-ne{right:0;-webkit-transform:translate(50%,-50%);transform:translate(50%,-50%)}.ReactCrop .ord-e{cursor:e-resize;top:50%}.ReactCrop .ord-se{bottom:0;cursor:se-resize;right:0;-webkit-transform:translate(50%,50%);transform:translate(50%,50%)}.ReactCrop .ord-s{cursor:s-resize;left:50%}.ReactCrop .ord-s,.ReactCrop .ord-sw{bottom:0;-webkit-transform:translate(-50%,50%);transform:translate(-50%,50%)}.ReactCrop .ord-sw{cursor:sw-resize;left:0}.ReactCrop .ord-w{cursor:w-resize;left:0;top:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{height:6px;height:var(--rc-drag-bar-size);left:0;top:0;-webkit-transform:translateY(-50%);transform:translateY(-50%);width:100%}.ReactCrop__drag-bar.ord-e{height:100%;right:0;top:0;-webkit-transform:translate(50%);transform:translate(50%);width:6px;width:var(--rc-drag-bar-size)}.ReactCrop__drag-bar.ord-s{bottom:0;height:6px;height:var(--rc-drag-bar-size);left:0;-webkit-transform:translateY(50%);transform:translateY(50%);width:100%}.ReactCrop__drag-bar.ord-w{height:100%;left:0;top:0;-webkit-transform:translate(-50%);transform:translate(-50%);width:6px;width:var(--rc-drag-bar-size)}.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w,.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle{display:none}@media (pointer:coarse){.ReactCrop .ord-e,.ReactCrop .ord-n,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{height:24px;height:var(--rc-drag-handle-mobile-size);width:24px;width:var(--rc-drag-handle-mobile-size)}}.profile-page{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);box-sizing:border-box;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;width:100%}.profile-header{align-items:center;background:#fff;border-bottom:2px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.5rem 2rem}.profile-header h1{color:#2d3748;flex:0 0 auto;font-size:2rem;font-weight:700;margin:0;padding-left:0}.profile-content{flex:1 1;margin:0 auto;max-width:800px;overflow-x:hidden;overflow-y:auto;padding:2rem;width:100%}.message{border-radius:8px;font-weight:500;margin-bottom:1.5rem;padding:1rem}.message.success{background:#c6f6d5;border:1px solid #9ae6b4;color:#22543d}.message.error{background:#fed7d7;border:1px solid #fc8181;color:#991b1b}.profile-content{display:flex;flex-direction:column;gap:2rem}.profile-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:2rem}.profile-section h2{border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.5rem}.profile-picture-section{align-items:center;display:flex;flex-direction:column;gap:1.5rem}.profile-picture-container{height:150px;position:relative;width:150px}.profile-picture-large{object-fit:cover}.profile-picture-large,.profile-picture-placeholder{border:4px solid #84cc16;border-radius:50%;height:150px;width:150px}.profile-picture-placeholder{align-items:center;background:#ffffff26;background-color:#e2e8f0;display:flex;justify-content:center}.placeholder-icon{color:#94a3b8;font-size:4rem}.upload-button{align-items:center;background:#667eea;border:3px solid #fff;border-radius:50%;bottom:0;cursor:pointer;display:flex;height:45px;justify-content:center;position:absolute;right:0;transition:all .3s ease;width:45px}.upload-button:hover{background:#5568d3;transform:scale(1.1)}.camera-icon{color:#fff;font-size:1.25rem}.picture-actions{display:flex;gap:1rem}.profile-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{color:#2d3748;font-size:.9rem}.btn-secondary{background:#f7fafc}.btn-secondary:hover:not(:disabled){background:#edf2f7}.crop-modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10000}.crop-modal{background:#fff;border-radius:12px;max-height:90vh;max-width:600px;overflow-y:auto;padding:2rem;width:100%}.crop-modal h3{color:#2d3748;font-size:1.5rem;margin:0 0 1.5rem}.crop-container{display:flex;justify-content:center;margin-bottom:1.5rem;overflow:hidden;width:100%}.crop-container img{height:auto;max-width:100%}.crop-actions{display:flex;gap:1rem;justify-content:flex-end}@media (max-width:768px){.profile-page{padding:1rem}.profile-page h1{font-size:1.5rem}.profile-section{padding:1.5rem}.profile-section h2{font-size:1.25rem}.profile-picture-container,.profile-picture-large,.profile-picture-placeholder{height:120px;width:120px}.placeholder-icon{font-size:3rem}.crop-modal{max-width:95%;padding:1.5rem}}@media (max-width:480px){.profile-page{padding:.75rem}.profile-page h1{font-size:1.25rem}.profile-section{padding:1rem}.profile-section h2{font-size:1.1rem}.profile-picture-container,.profile-picture-large,.profile-picture-placeholder{height:100px;width:100px}.crop-modal{border-radius:0;max-height:100vh;max-width:100%;padding:1rem}}.word-database{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);box-sizing:border-box;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;width:100%}.word-database-header{align-items:center;background:#fff;border-bottom:2px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.5rem 2rem}.word-database-header h1{color:#2d3748;flex:0 0 auto;font-size:3rem;font-weight:700;margin:0;padding-left:2.5rem;position:relative;z-index:1}.word-database-content{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:2rem}.header-actions{align-items:center;display:flex;gap:1rem}.import-export-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.word-database-stats{margin-bottom:2rem}.word-stats{display:flex;flex-wrap:wrap;gap:1.5rem}.stat-item{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;padding:.75rem 1rem}.stat-label{font-size:.75rem;margin-bottom:.25rem;text-transform:uppercase}.stat-value{color:#2d3748}.stat-value.known{color:#38a169}.stat-value.unknown{color:#e53e3e}.filter-group{align-items:center;display:flex;gap:.5rem}.filter-input{flex:0 0 auto;max-width:120px;min-width:120px;width:120px}.filter-select{max-width:195px;min-width:195px;width:195px}.words-table,.words-table-container{min-height:500px}.words-table th{font-size:.85rem;padding:.5rem .75rem}.words-table th:first-child{width:40px}.words-table td{font-size:.9rem;padding:.5rem .75rem}.words-table-body{display:table-row-group}.empty-table-cell{background-color:#f7fafc;color:#718096;height:450px;padding:0;position:relative;text-align:center;vertical-align:middle}.empty-table-cell p{font-size:1rem;margin:0}.word-type-badge{margin-top:.25rem}.word-action-cell{min-width:50px;text-align:center}.word-action-cell .btn-icon{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem;transition:transform .2s}.word-action-cell .btn-icon:hover{transform:scale(1.2)}.editable-field{border-radius:4px;cursor:pointer;display:inline-block;padding:.25rem;transition:background-color .2s}.editable-field:hover{background-color:#f0f0f0}.editable-input,.editable-select{border:2px solid #667eea;border-radius:4px;font-family:inherit;font-size:.9rem;padding:.25rem .5rem;width:100%}.editable-input:focus,.editable-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.word-sample-cell{max-width:300px;min-width:200px}.word-status-cell{min-width:100px;text-align:center}.context-menu-item:hover{background-color:#f7fafc!important}.btn-success{background-color:#10b981}.btn-warning{background-color:#f59e0b;color:#fff}.btn-danger{background-color:#dc3545}.btn-sm{font-size:.8rem;padding:.25rem .5rem}.pagination{gap:.5rem;margin-bottom:1rem;padding:.5rem 0}.page-info{align-items:center;display:flex;font-size:.8rem;font-weight:500;gap:.25rem}.page-input{background:#fff;border:1px solid #cbd5e1;border-radius:4px;color:#4a5568;font-size:.8rem;font-weight:600;padding:.25rem .35rem;text-align:center;transition:border-color .2s ease,box-shadow .2s ease;width:50px}.page-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.page-input::-webkit-inner-spin-button,.page-input::-webkit-outer-spin-button{cursor:pointer;opacity:1}@media (max-width:968px){.words-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.words-table{font-size:.9rem}.words-table td,.words-table th{padding:.75rem .5rem}}@media (max-width:768px){.word-database{padding:.5rem}.word-database-header{align-items:flex-start;flex-direction:column;gap:.75rem;padding:1rem}.word-database-header h1{font-size:1.5rem;width:100%}.header-actions{flex-direction:column;gap:.5rem;width:100%}.import-export-buttons{flex-direction:row;flex-wrap:wrap;gap:.5rem;width:100%}.import-export-buttons .btn{flex-basis:calc(33.333% - 0.5rem);flex-grow:1;flex-shrink:1;font-size:.85rem;justify-content:center;max-width:100%;min-width:0;overflow:hidden;padding:.5rem .75rem;text-overflow:ellipsis;white-space:nowrap}.word-database-content{padding:1rem .5rem}.word-database-stats{margin-bottom:1.5rem}.word-stats{flex-wrap:nowrap;gap:.5rem;justify-content:space-between;width:100%}.stat-item{flex-basis:calc(25% - 0.375rem);flex-grow:1;flex-shrink:1;min-width:0;padding:.75rem .5rem}.stat-label{font-size:.65rem}.stat-value{font-size:1.1rem}.manual-creation-section{margin-bottom:1.5rem;padding:1rem}.manual-creation-section h2{font-size:1.1rem;margin-bottom:.75rem}.word-list-section{padding:1rem}.word-list-section h2{font-size:1.1rem;margin-bottom:.75rem}.word-list-controls{flex-direction:column;gap:.75rem}.word-filters{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;gap:.5rem;width:100%}.filter-input{flex:0 0 100px;max-width:100px;min-width:100px}.filter-input,.filter-select{font-size:.8rem;padding:.5rem}.filter-select{flex-basis:calc(18% - 0.3rem);flex-grow:0;flex-shrink:0;min-width:80px}.word-filters>.btn-primary{min-width:100px;padding:.5rem .75rem}.filter-checkbox,.word-filters>.btn-primary{flex:0 0 auto;font-size:.8rem;white-space:nowrap}.words-table-container{-webkit-overflow-scrolling:touch;margin-top:1rem;overflow-x:auto}.words-table{font-size:.75rem;min-width:700px}.words-table td,.words-table th{padding:.5rem .35rem}.word-action-cell{white-space:nowrap}.word-action-cell .btn{font-size:.7rem;min-width:auto;padding:.35rem .5rem}.pagination{align-items:stretch;flex-direction:column;gap:.75rem}.pagination-info{font-size:.85rem;text-align:center}.pagination-controls{flex-wrap:wrap;justify-content:center}.pagination-btn{font-size:.85rem;padding:.5rem .75rem}}@media (max-width:480px){.word-database-header h1{font-size:1.25rem}.stat-item{flex-basis:calc(25% - 0.375rem);flex-grow:1;flex-shrink:1;min-width:0}.stat-label{font-size:.6rem}.stat-value{font-size:1rem}.words-table{font-size:.7rem;min-width:600px}.words-table td,.words-table th{padding:.4rem .25rem}}.filterable-header{cursor:default;position:relative}.header-content{gap:.5rem;justify-content:space-between}.filter-icon,.header-content{align-items:center;display:flex}.filter-icon{background:none;border:none;border-radius:3px;color:#4a5568;cursor:pointer;font-size:.7rem;height:22px;justify-content:center;line-height:1;opacity:.5;padding:.2rem .3rem;transition:opacity .2s,background-color .2s;width:22px}.filter-icon:hover{background-color:#e2e8f0;opacity:1}.filter-icon.active{background-color:#667eea;color:#fff;font-weight:700;opacity:1}.column-filter-dropdown{background:#fff;border:1px solid #cbd5e1;border-radius:6px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;left:0;margin-top:4px;max-height:400px;max-width:300px;min-width:250px;position:absolute;top:100%;z-index:1000}.filter-dropdown-header{align-items:center;background-color:#f7fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:.75rem 1rem}.filter-dropdown-title{color:#2d3748;font-size:.9rem;font-weight:600}.filter-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;display:flex;font-size:1.5rem;height:24px;justify-content:center;padding:0;transition:background-color .2s;width:24px}.filter-close-btn:hover{background-color:#e2e8f0;color:#2d3748}.filter-dropdown-search{border-bottom:1px solid #e2e8f0;padding:.5rem}.filter-search-input{border:1px solid #cbd5e1;border-radius:4px;font-size:.85rem;padding:.5rem;width:100%}.filter-search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.filter-dropdown-actions{border-bottom:1px solid #e2e8f0;display:flex;gap:.5rem;padding:.5rem}.filter-action-btn{background-color:#f7fafc;border:1px solid #cbd5e1;border-radius:4px;color:#4a5568;cursor:pointer;flex:1 1;font-size:.8rem;padding:.4rem .75rem;transition:background-color .2s,border-color .2s}.filter-action-btn:hover{background-color:#edf2f7;border-color:#a0aec0}.filter-dropdown-list{max-height:250px;overflow-y:auto;padding:.25rem 0}.filter-checkbox-item{align-items:center;cursor:pointer;display:flex;gap:.5rem;padding:.4rem 1rem;transition:background-color .2s}.filter-checkbox-item:hover{background-color:#f7fafc}.filter-checkbox-item input[type=checkbox]{cursor:pointer;flex-shrink:0;height:16px;width:16px}.filter-checkbox-item label{color:#4a5568;cursor:pointer;flex:1 1;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-empty-message{color:#718096;font-size:.85rem;padding:1rem;text-align:center}.filter-dropdown-list::-webkit-scrollbar{width:8px}.filter-dropdown-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.filter-dropdown-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.filter-dropdown-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}.study-timer{align-items:center;background:#fff;border:2px solid #667eea;border-radius:8px;box-shadow:0 2px 4px #0000001a;box-sizing:border-box;display:flex;flex-shrink:0;gap:.5rem;height:40px;padding:.5rem 1rem}.study-timer-icon{color:#667eea;font-size:1.1rem}.study-timer-time{color:#2d3748;font-size:1rem;font-weight:700;min-width:60px;text-align:center}@media (max-width:768px){.study-timer{gap:.4rem;padding:.4rem .6rem}.study-timer-icon{font-size:.9rem}.study-timer-time{font-size:.85rem;min-width:50px}.study-timer-toggle{padding:.2rem}.study-timer-pause-icon,.study-timer-play-icon{font-size:.8rem}}.study-timer-toggle{align-items:center;background:#0000;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:.25rem;transition:background-color .2s}.study-timer-toggle:hover{background-color:#f3f4f6}.study-timer-pause-icon{color:#f59e0b;font-size:.9rem}.study-timer-play-icon{color:#10b981;font-size:.9rem}.flashcards-container{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);box-sizing:border-box;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;width:100%}.flashcards-header{align-items:center;background:#fff;border-bottom:2px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.5rem 2rem}.flashcards-header h1{color:#2d3748;flex:0 0 auto;font-size:2rem;font-weight:700;margin:0;padding-left:0}.flashcards-header .study-timer{flex-shrink:0;width:120px}.flashcards-content{overflow:hidden}.flashcard-area,.flashcards-content{box-sizing:border-box;display:flex;flex:1 1;overflow-x:hidden;width:100%}.flashcard-area{align-items:center;background:linear-gradient(135deg,#e0e7ff,#ddd6fe);flex-direction:column;gap:.5rem;justify-content:flex-start;min-height:calc(100vh - 200px);overflow-y:auto;padding:1rem 3rem}.progress-info{color:#fff}.progress-fill{transition:width .2s ease}.card-stack-container{align-items:center;display:flex;flex-shrink:0;height:200px;justify-content:center;margin-bottom:.75rem;margin-left:auto;margin-right:auto;max-height:200px;max-width:480px;min-height:200px;min-width:480px;position:relative;touch-action:pan-y pan-x;width:480px}.card-stack-wrapper{align-items:center;display:flex;flex-direction:column;justify-content:center;overflow:hidden}.card-stack-item,.card-stack-wrapper{box-sizing:border-box;height:100%;left:0;position:absolute;top:0;width:100%}.flashcard-image-container{align-items:center;display:flex;flex-shrink:0;height:300px;justify-content:center;margin-bottom:.75rem;margin-left:auto;margin-right:auto;max-height:300px;max-width:480px;min-height:300px;min-width:480px;perspective:1000px;position:relative;transform-style:preserve-3d;width:480px}.flashcard-image{border-radius:0;box-sizing:border-box;display:block;height:100%;object-fit:cover;transition:all .2s ease;width:100%}.known-text-overlay{animation:known-text-animation .2s ease-out forwards}.unknown-text-overlay{animation:unknown-text-animation .2s ease-out forwards}.animate-image-known{animation:image-pulse-known .4s ease-out}.animate-image-unknown{animation:image-pulse-unknown .4s ease-out}.image-pane-placeholder .generate-image-btn{transition:all .3s}.flashcard{max-height:200px;min-height:200px;min-width:480px;touch-action:pan-y pan-x;transition:transform .2s ease-out,opacity .2s ease-out}.flashcard.card-stack-item{box-sizing:border-box;height:100%!important;max-height:100%!important;max-width:100%!important;min-height:0!important;min-width:0!important;width:100%!important}.flashcard.card-stack-top{touch-action:pan-y pan-x}.flashcard-inner{transition:transform .4s}.card-sentence-container{flex-direction:column;gap:.5rem}.card-sentence{width:100%}.card-sentence-controls{align-items:center;display:flex;justify-content:center;width:100%}.audio-btn-inline{line-height:1;padding:0;transition:all .3s;width:40px}.audio-btn-inline:after{transition:width .5s,height .5s,opacity .5s}.audio-btn-inline:active{animation:sound-wave .3s ease-out}.card-navigation{margin-left:auto;margin-right:auto}.nav-btn{transition:all .3s}.animate-press,.nav-btn:active:not(:disabled){animation:button-press .2s ease-out}.animate-pulse-status{animation:pulse-known .4s ease-out}.status-unknown.animate-pulse-status{animation:pulse-unknown .4s ease-out}.animate-sound-wave{animation:sound-wave .3s ease-out}.flashcard-sidebar{background:#fff;border-left:2px solid #e2e8f0;display:flex;flex-direction:column;gap:.75rem;padding:1rem;width:180px}.flashcard-sidebar h3{color:#2d3748;font-size:1.25rem;font-weight:700;margin:0}.progress-section{border-bottom:2px solid #e2e8f0;margin-bottom:.5rem;padding-bottom:.5rem}.progress-section h3{margin-bottom:0}.mark-as-section{border-bottom:none;margin-bottom:0;padding-bottom:0}.stats-grid{gap:.5rem}@media (min-width:969px){.flashcard-sidebar .stats-grid{flex-direction:column!important}}.stat-card{padding:.5rem}.stat-label{margin:0 0 .25rem}.stat-value{font-size:1.5rem}.status-btn{transition:all .3s}.status-btn:before{transition:width .4s,height .4s}.status-btn.status-unknown:active{animation:pulse-unknown .4s ease-out}.status-btn.status-known:active{animation:pulse-known .4s ease-out}.deck-statistics-panel{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;margin-top:1.5rem;padding:1rem}.deck-statistics-title{color:#2d3748;font-size:.9rem;font-weight:700;margin-bottom:.75rem;text-align:center}.deck-statistics-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(3,1fr)}.deck-stat-item{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:.75rem;text-align:center}.deck-stat-label{color:#718096;font-size:.75rem;margin:0 0 .25rem}.deck-stat-value{font-size:1.25rem;font-weight:700;margin:0}.deck-type-badge{color:#667eea;font-size:.75rem;font-style:italic;margin:.5rem 0 0;text-align:center}@media (max-width:768px){.flashcards-header{align-items:center;flex-direction:row;flex-wrap:wrap;gap:.5rem;justify-content:space-between;padding:.75rem .75rem .75rem 2.5rem;position:relative}.header-title-section{align-items:center;display:flex;gap:.5rem;margin-bottom:.25rem;margin-left:.75rem;width:100%}.flashcards-header h1{flex-shrink:0;font-size:1.25rem;margin:0;padding:0;white-space:nowrap}.flashcards-header .study-timer{align-items:center;box-sizing:border-box;display:flex;flex-shrink:0;height:40px;padding:.5rem .75rem;width:100px}.header-controls{align-items:center;display:flex;flex-direction:row;flex-shrink:0;flex-wrap:nowrap;gap:.5rem;justify-content:flex-end;width:100%}.deck-select,.header-controls>*{box-sizing:border-box;flex-shrink:0;height:40px}.deck-select{align-items:center;display:flex;font-size:.85rem;max-width:162px;min-width:130px;padding:.5rem .75rem;width:130px}.header-buttons{display:flex;flex-direction:row;flex-shrink:0;gap:.4rem}.header-buttons .btn{align-items:center;display:flex;font-size:.85rem;height:40px;justify-content:center;line-height:1;padding:.5rem .75rem;text-align:center;white-space:nowrap}.flashcard-area{gap:.25rem;justify-content:flex-start;min-height:auto;overflow-y:auto;padding:.5rem 1.5rem}.progress-container{margin-bottom:0;padding:.5rem}.progress-info{font-size:.8rem}.progress-bar{height:6px}.card-stack-container{margin:0 auto .5rem}.card-stack-container,.flashcard-image-container{aspect-ratio:480/300;flex-shrink:0;height:auto;max-height:40vh;max-width:100%;min-width:0;width:100%}.flashcard-image-container{margin:0 auto .75rem}.flashcard-image{height:100%;object-fit:cover;width:100%}.known-text-overlay,.unknown-text-overlay{font-size:2rem}.image-pane-placeholder .placeholder-icon{font-size:2.5rem}.image-pane-placeholder .placeholder-text{font-size:.85rem;margin-bottom:.5rem}.image-pane-placeholder .generate-image-btn{font-size:.85rem;padding:.5rem 1rem}.replace-image-btn{font-size:1rem;height:35px;padding:.5rem;right:.5rem;top:.5rem;width:35px}.flashcard{aspect-ratio:480/300!important;flex-shrink:0;height:auto!important;margin-bottom:.75rem;margin-left:auto!important;margin-right:auto!important;max-height:50vh!important;max-width:100%!important;min-width:0!important;width:100%!important}.card-word{font-size:1.75rem}.card-type{font-size:1rem;margin-bottom:.5rem}.card-translation{font-size:1.25rem;margin-bottom:.5rem}.card-sentence{font-size:.95rem}.card-hint{font-size:.75rem;margin-top:.75rem}.card-navigation{align-items:center;display:flex;flex-direction:row;flex-shrink:0;flex-wrap:nowrap;gap:.5rem;justify-content:center;margin:.5rem auto 0;max-width:100%;padding:0 .5rem;width:100%}.nav-btn,.nav-btn-emoji{flex:1 1;font-size:2.31rem;height:40px;min-width:0}.nav-btn-emoji{padding:0}}@media (max-width:968px){.flashcards-content{flex-direction:column}.card-stack-container{aspect-ratio:480/300!important;height:auto!important;margin:0 auto!important;max-height:40vh!important;max-width:100%!important;min-width:0!important;width:100%!important}.flashcard-image-container{aspect-ratio:480/300;flex-shrink:0;height:auto;margin:0 auto .75rem;max-height:40vh;max-width:100%;min-width:0;width:100%}.flashcard-image{height:100%;object-fit:cover;width:100%}.known-text-overlay,.unknown-text-overlay{font-size:2rem}.flashcard{margin-left:auto!important;margin-right:auto!important}.card-navigation{margin:0 auto!important;max-width:100%!important;width:100%!important}.flashcard-sidebar{border-left:none;border-top:2px solid #e2e8f0;flex-direction:row;flex-shrink:0;gap:.75rem;justify-content:space-around;overflow-x:auto;padding:.75rem;width:100%}.mark-as-section{border-bottom:none;border-right:2px solid #e2e8f0;flex:1 1;margin-bottom:0;margin-right:.75rem;min-width:0;order:1;padding-bottom:0;padding-right:.75rem}.mark-as-title{font-size:1rem;margin-bottom:.5rem}.status-buttons{flex-direction:column;gap:.5rem}.status-btn{font-size:.85rem;padding:.75rem}.progress-section{border-bottom:none;flex:1 1;min-width:0;order:2}.progress-section h3{font-size:1rem;margin-bottom:.5rem}.stats-grid{flex-direction:row;gap:.5rem;overflow-x:auto}.stat-card{flex:1 1;min-width:80px;padding:.75rem .5rem}.stat-label{font-size:.7rem;margin-bottom:.25rem}.stat-value{font-size:1.25rem}.flashcard{aspect-ratio:480/300!important;height:auto!important;max-height:50vh!important;max-width:100%!important;min-width:0!important;width:100%!important}.card-word{font-size:2rem}}@media (max-width:768px){.flashcard-sidebar{flex-direction:column;gap:.5rem;max-height:none;padding:.75rem}.progress-section{border-bottom:2px solid #e2e8f0;margin-bottom:0;order:1;padding-bottom:0}.mark-as-section{border-bottom:none;border-right:none;margin-bottom:0;margin-right:0;order:2;padding-bottom:0;padding-right:0;width:100%}.status-buttons{flex-direction:row;gap:.5rem}.status-btn{flex:1 1;font-size:.85rem;padding:.75rem}.progress-section{width:100%}.stats-grid{display:flex!important;flex-direction:row!important;gap:.5rem}.stat-card{flex:1 1!important;min-width:0;padding:.75rem .5rem;width:auto!important}.stat-label{font-size:.7rem;margin-bottom:.25rem}.stat-value{font-size:1.25rem}.card-image{height:100px;width:100px}.deck-statistics-panel{margin-top:1rem;padding:.75rem}.deck-statistics-grid{gap:.5rem;grid-template-columns:repeat(3,1fr)}.deck-stat-item{padding:.5rem}.deck-stat-label{font-size:.7rem}.deck-stat-value{font-size:1.1rem}}.audio-controls-group{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.mic-btn-inline{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.2rem;height:40px;justify-content:center;line-height:1;padding:0;transition:all .3s;user-select:none;-webkit-user-select:none;width:40px}.mic-btn-inline:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}.mic-btn-inline:active:not(:disabled){transform:scale(.95)}.mic-btn-inline:disabled{cursor:not-allowed;opacity:.5}.mic-btn-inline.recording{animation:pulse-recording 1.5s ease-in-out infinite;background:#f5576ccc;border-color:#f5576c}@keyframes pulse-recording{0%,to{box-shadow:0 0 0 0 #f5576cb3}50%{box-shadow:0 0 0 10px #f5576c00}}.recording-pulse{animation:blink 1s ease-in-out infinite;background:#fff;border-radius:50%;display:inline-block;height:12px;width:12px}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.evaluate-btn-inline,.play-btn-inline,.record-again-btn-inline{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.2rem;height:40px;justify-content:center;line-height:1;padding:0;transition:all .3s;width:40px}.evaluate-btn-inline:hover:not(:disabled),.play-btn-inline:hover:not(:disabled),.record-again-btn-inline:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}.evaluate-btn-inline:active:not(:disabled),.play-btn-inline:active:not(:disabled),.record-again-btn-inline:active:not(:disabled){transform:scale(.95)}.evaluate-btn-inline:disabled,.play-btn-inline:disabled,.record-again-btn-inline:disabled{cursor:not-allowed;opacity:.5}.evaluate-btn-inline{background:#11998e99;border-color:#11998ecc}.evaluate-btn-inline:hover:not(:disabled){background:#11998ecc;border-color:#11998e}.spinner-small{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:16px;width:16px}@keyframes spin{to{transform:rotate(1turn)}}.speech-evaluation-results{animation:fadeIn .3s ease-in;background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000001a;margin:1.5rem auto;max-width:480px;padding:1.5rem;width:100%}.speech-evaluation-results .results-header{margin-bottom:1.5rem}.speech-evaluation-results .results-header h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin:0}.speech-evaluation-results .ai-label{color:#ff9800;font-size:.9em;font-weight:400}.results-content{display:flex;flex-direction:column;gap:1.5rem}.recognized-text-box{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;font-size:1.1em;line-height:2;min-height:60px;padding:15px}.recognized-text-box .word{border-radius:3px;cursor:default;padding:4px 2px;transition:all .2s}.recognized-text-box .word-correct{background-color:#c8e6c9;color:#2e7d32}.recognized-text-box .word-missing{background-color:#ffcdd2;color:#c62828;text-decoration:line-through}.recognized-text-box .word-wrong{background-color:#fff9c4;color:#f57f17}.recognized-text-box .word:hover{box-shadow:0 2px 5px #0000001a;transform:scale(1.05)}.legend{border-top:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:20px;padding-top:15px}.legend-item{align-items:center;color:#666;display:flex;font-size:.9em;gap:8px}.legend-color{border-radius:12px;display:inline-block;height:20px;width:30px}.legend-color.correct{background-color:#c8e6c9;border:1px solid #81c784}.legend-color.missing{background-color:#ffcdd2;border:1px solid #e57373}.legend-color.wrong{background-color:#fff9c4;border:1px solid #fff176}.audio-player-container{margin-top:15px}.audio-player-container audio{border-radius:20px;height:40px;outline:none;width:100%}.score-card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px}.score-header{align-items:center;background:linear-gradient(135deg,#1e88e5,#1565c0);border-radius:8px;color:#fff;display:flex;font-weight:600;justify-content:space-between;margin:-20px -20px 20px;padding:15px 20px}.score-value{font-size:1.2em}.score-metrics{gap:20px}.metric,.score-metrics{display:flex;flex-direction:column}.metric{gap:8px}.metric-header{align-items:center;display:flex;font-size:.95em;justify-content:space-between}.metric-header span:first-child{color:#333;font-weight:500}.metric-score{color:#666;font-size:.9em}.metric-bar{background:#e0e0e0;border-radius:6px;height:12px;overflow:hidden;width:100%}.metric-fill{border-radius:6px;height:100%;transition:width .3s ease}@media (max-width:768px){.audio-controls-group{gap:.4rem}.evaluate-btn-inline,.mic-btn-inline,.play-btn-inline,.record-again-btn-inline{font-size:1rem;height:40px;min-width:40px;padding:.4rem}.speech-evaluation-results{margin:1rem auto;max-width:100%;padding:1rem}.recognized-text-box{font-size:1em;padding:12px}.legend{flex-direction:column;gap:10px}.score-header{flex-direction:column;gap:5px;text-align:center}}.spelling-container{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);box-sizing:border-box;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;width:100%}.spelling-header{align-items:center;background:#fff;border-bottom:2px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.5rem 2rem}.spelling-header h1{color:#2d3748;flex:0 0 auto;font-size:2rem;font-weight:700;margin:0;padding-left:0}.spelling-header .study-timer{flex-shrink:0;width:120px}.header-controls{flex-wrap:nowrap}.header-buttons{align-items:center;display:flex;gap:.75rem}.header-buttons .btn{justify-content:center;line-height:1}.deck-select,.header-buttons .btn{align-items:center;box-sizing:border-box;display:flex;height:40px;padding:.5rem 1rem}.deck-select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;flex-shrink:0;font-size:1rem;min-width:180px;width:180px}.deck-select:focus{border-color:#667eea;outline:none}.flashcards-setup{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;margin:2rem;padding:2rem}.flashcards-setup h1{color:#2d3748;font-size:2rem;margin-bottom:1.5rem}.setup-filters{display:flex;flex-wrap:wrap;gap:1rem}.filter-select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:.5rem 1rem}.spelling-content{overflow:hidden}.spelling-area,.spelling-content{box-sizing:border-box;display:flex;flex:1 1;overflow-x:hidden;width:100%}.spelling-area{align-items:center;background:linear-gradient(135deg,#e0e7ff,#ddd6fe);flex-direction:column;gap:.5rem;justify-content:flex-start;margin:0 auto;max-width:1200px;min-height:calc(100vh - 200px);overflow-y:auto;padding:1rem 3rem}.progress-container{flex-shrink:0;max-width:100%;padding:0 .5rem;width:100%}.progress-info{color:#000;display:flex;font-size:.9rem;font-weight:600;justify-content:space-between;margin-bottom:.5rem}.progress-bar{background:#ffffff4d;border-radius:10px;height:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#f093fb,#f5576c);border-radius:10px;height:100%;transition:width .15s ease}.card-counter{color:#fff;font-size:1.1rem;font-weight:600;text-shadow:0 2px 4px #0003}.writing-pane-container{flex-shrink:0;height:auto;margin-bottom:.75rem;max-width:480px;min-width:480px;position:relative;touch-action:pan-x;width:480px}.writing-pane,.writing-pane-container{align-items:center;display:flex;justify-content:center;min-height:200px}.writing-pane{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 10px 30px #0000004d;box-sizing:border-box;color:#fff;padding:1.5rem;transform-origin:center;transition:opacity .15s ease-in-out,transform .15s ease-out,scale .15s ease-out}.writing-pane,.writing-question{flex-direction:column;width:100%}.writing-question{align-items:center;display:flex;gap:.5rem;margin-bottom:1rem}.question-label{font-size:.9rem;font-weight:600;letter-spacing:1px;opacity:.9;text-transform:uppercase}.question-text-container{align-items:center;display:flex;gap:.75rem;justify-content:center;width:100%}.question-text{color:#252525;font-size:2rem;font-weight:700;margin:0;text-align:center;text-shadow:0 2px 4px #0003}.writing-answer-section{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem;width:100%}.answer-label{font-size:.9rem;font-weight:600;opacity:.9}.answer-input,.answer-label-centered{text-align:center}.answer-input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:3px solid #ffffff4d;border-radius:12px;box-sizing:border-box;color:#fff;font-size:1.25rem;font-weight:600;padding:.75rem 1rem;transition:all .1s ease;width:100%}.answer-input::placeholder{color:#fff9}.answer-input:focus{background:#ffffff26;border-color:#fff9;box-shadow:0 0 0 4px #fff3;outline:none}.answer-input:disabled{cursor:not-allowed;opacity:.7}.answer-input.answer-correct{background:#60f0a633;border-color:#60f0a6}.answer-input.answer-incorrect{background:#f8717133;border-color:#f87171}.answer-feedback{animation:fadeIn .1s ease-out;border-radius:8px;font-size:1rem;font-weight:600;padding:.75rem 1rem;text-align:center}.feedback-correct{background:#60f0a64d;border:2px solid #60f0a680;color:#d1fae5}.feedback-incorrect{background:#f871714d;border:2px solid #f8717180;color:#fee2e2}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.writing-sentence{flex-direction:column;margin:1rem 0}.sentence-text-container,.writing-sentence{align-items:center;display:flex;gap:.75rem;width:100%}.sentence-text-container{flex-wrap:wrap;justify-content:center}.sentence-label{font-size:.85rem;font-weight:600;letter-spacing:.5px;margin:0;opacity:.9;text-transform:uppercase}.sentence-text{font-size:.95rem;font-style:italic;line-height:1.4;margin:0;opacity:.95;padding:0 1rem;text-align:center}.writing-hint{font-size:.75rem;margin-top:.5rem;opacity:.8;text-align:center}.spelling-image-container{align-items:center;display:flex;flex-shrink:0;height:300px;justify-content:center;margin-bottom:.75rem;max-height:300px;max-width:480px;min-height:300px;min-width:480px;perspective:1000px;position:relative;transform-style:preserve-3d;width:480px}.spelling-image{border-radius:0;box-sizing:border-box;display:block;height:100%;object-fit:cover;transition:all .15s ease;width:100%}.known-text-overlay{animation:known-text-animation .15s ease-out forwards;color:#60f0a6;font-size:3rem;font-weight:700;left:50%;pointer-events:none;position:absolute;text-shadow:0 2px 8px #00000080;top:10%;transform:translate(-50%);z-index:100}.writing-pane{position:relative}@keyframes known-text-animation{0%{opacity:1;transform:translate(-50%) scale(1)}20%{opacity:.8;transform:translate(-50%) scale(1)}to{opacity:.5;transform:translate(-50%,-100px) scale(1.5)}}.unknown-text-overlay{animation:unknown-text-animation .15s ease-out forwards;color:#60a6f0;font-size:3rem;font-weight:700;left:50%;pointer-events:none;position:absolute;text-shadow:0 2px 8px #00000080;top:70%;transform:translate(-50%);z-index:100}@keyframes unknown-text-animation{0%{opacity:1;transform:translate(-50%) scale(1)}20%{opacity:.8;transform:translate(-50%) scale(1)}to{opacity:.5;transform:translate(-50%,100px) scale(1.5)}}.animate-image-known{animation:image-pulse-known .2s ease-out}.animate-image-unknown{animation:image-pulse-unknown .2s ease-out}@keyframes image-pulse-known{0%{box-shadow:0 0 0 0 #055f46b3;filter:brightness(1);transform:scale(1)}50%{box-shadow:0 0 0 15px #055f4600;filter:brightness(1.1);transform:scale(1.02)}to{box-shadow:0 0 0 0 #055f4600;filter:brightness(1);transform:scale(1)}}@keyframes image-pulse-unknown{0%{box-shadow:0 0 0 0 #1e40afb3;filter:brightness(1);transform:scale(1)}50%{box-shadow:0 0 0 15px #1e40af00;filter:brightness(1.1);transform:scale(1.02)}to{box-shadow:0 0 0 0 #1e40af00;filter:brightness(1);transform:scale(1)}}.image-pane-placeholder{align-items:center;background:linear-gradient(135deg,#f7fafc,#edf2f7);display:flex;flex-direction:column;height:100%;justify-content:center;padding:2rem;width:100%}.image-pane-placeholder .placeholder-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.image-pane-placeholder .placeholder-text{color:#718096;font-size:1rem;margin-bottom:1rem}.image-pane-placeholder .generate-image-btn{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .15s}.image-pane-placeholder .generate-image-btn:hover:not(:disabled){background:#5568d3;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.image-pane-placeholder .generate-image-btn:disabled{cursor:not-allowed;opacity:.6}.flashcard{box-sizing:border-box;cursor:pointer;flex-shrink:0;height:200px;margin-bottom:.75rem;max-width:480px;perspective:1000px;position:relative;touch-action:pan-x;transition:transform .3s ease-out,opacity .3s ease-out;width:480px}.flashcard.card-stack-item{left:0;margin-bottom:0;position:absolute;top:0}.flashcard.card-stack-top{cursor:pointer;touch-action:pan-x}.flashcard-inner{height:100%;position:relative;transform-style:preserve-3d;transition:transform .6s;width:100%}.flashcard.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard-back,.flashcard-front{align-items:center;-webkit-backface-visibility:hidden;backface-visibility:hidden;border-radius:20px;box-shadow:0 10px 30px #0000004d;box-sizing:border-box;display:flex;flex-direction:column;height:100%;justify-content:center;padding:1.5rem;position:absolute;width:100%}.flashcard-front{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.flashcard-back{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;transform:rotateY(180deg)}.card-word-container{align-items:center;display:flex;gap:.75rem;justify-content:center;margin:.5rem 0}.card-word{font-size:2.5rem;font-weight:700;margin:0;text-align:center;text-shadow:0 2px 4px #0003}.card-type{font-size:1rem;text-transform:capitalize}.card-translation,.card-type{margin-bottom:.5rem;opacity:.9}.card-translation{font-size:1.25rem}.card-sentence-container{align-items:center;display:flex;gap:.75rem;justify-content:center;margin:1rem 0;max-width:90%}.card-sentence{flex:1 1;font-size:.95rem;font-style:italic;line-height:1.4;margin:0;opacity:.95;text-align:center}.audio-btn-inline{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.2rem;height:40px;justify-content:center;min-width:40px;overflow:visible;padding:.5rem;position:relative;transition:all .15s}.audio-btn-inline:after{background:#fff6;border-radius:50%;content:"";height:0;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .3s,height .3s,opacity .3s;width:0}.audio-btn-inline:active:after{height:60px;opacity:0;width:60px}.audio-btn-inline:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}.audio-btn-inline:active{animation:sound-wave .2s ease-out}@keyframes sound-wave{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.card-hint{font-size:.75rem;margin-top:.5rem;opacity:.8;text-align:center}.card-navigation{align-items:center;display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;gap:.75rem;justify-content:center;max-width:480px;width:480px}.card-navigation>*{display:inline-block!important;flex-shrink:0}.nav-btn{align-items:center;background:#0000!important;border:none!important;border-radius:12px;box-sizing:border-box;color:#667eea;cursor:pointer;display:flex!important;flex:1 1;font-size:3.5rem;height:45px;justify-content:center;margin:0!important;min-width:0;padding:0!important;transition:all .15s;width:auto!important}.nav-btn:hover:not(:disabled){background:#fff3!important;transform:translateY(-2px)}.nav-btn:active:not(:disabled){animation:button-press .15s ease-out}@keyframes button-press{0%{transform:scale(1)}50%{transform:scale(.9)}to{transform:scale(1)}}.animate-press{animation:button-press .15s ease-out}.animate-pulse-status{animation:pulse-known .2s ease-out}.status-unknown.animate-pulse-status{animation:pulse-unknown .2s ease-out}.animate-sound-wave{animation:sound-wave .2s ease-out}.nav-btn:disabled{cursor:not-allowed;opacity:.6}.nav-btn-emoji{font-size:2.45rem}.spelling-sidebar{background:#fff;border-left:2px solid #e2e8f0;display:flex;flex-direction:column;gap:.75rem;padding:1rem;width:180px}.spelling-sidebar h3{color:#2d3748;font-size:1.25rem;font-weight:700;margin:0}.mark-as-section{border-bottom:2px solid #e2e8f0;margin-bottom:1rem;padding-bottom:1rem}.mark-as-title{color:#2d3748;font-size:1rem;font-weight:700;margin:0 0 .75rem}.status-buttons{gap:.75rem}.stats-grid,.status-buttons{display:flex;flex-direction:column}.stats-grid{gap:1rem}@media (min-width:969px){.spelling-sidebar .stats-grid{flex-direction:column!important}}.stat-card{border-radius:12px;padding:1rem;text-align:center}.stat-correct{background:#f0fdf4;border:2px solid #86efac}.stat-incorrect{background:#fef2f2;border:2px solid #fca5a5}.stat-remaining{background:#eff6ff;border:2px solid #93c5fd}.stat-label{color:#718096;font-size:.9rem;font-weight:600;margin:0 0 .5rem}.stat-value{font-size:2rem;font-weight:700;margin:0}.stat-correct .stat-value{color:#16a34a}.stat-incorrect .stat-value{color:#dc2626}.stat-remaining .stat-value{color:#2563eb}.status-btn{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;overflow:hidden;padding:1rem;position:relative;text-align:left;transition:all .15s}.status-btn:before{background:#ffffff80;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .3s,height .3s;width:0}.status-btn:active:before{height:300px;width:300px}.status-btn.status-unknown{background:#dbeafe;color:#1e40af}.status-btn.status-unknown:hover{background:#bfdbfe;box-shadow:0 4px 12px #1e40af4d;transform:translateY(-2px)}.status-btn.status-unknown:active{animation:pulse-unknown .2s ease-out}.status-btn.status-known{background:#d1fae5;color:#065f46}.status-btn.status-known:hover{background:#a7f3d0;box-shadow:0 4px 12px #055f464d;transform:translateY(-2px)}.status-btn.status-known:active{animation:pulse-known .2s ease-out}@keyframes pulse-known{0%{box-shadow:0 0 0 0 #055f46b3;transform:scale(1)}50%{box-shadow:0 0 0 10px #055f4600;transform:scale(1.05)}to{box-shadow:0 0 0 0 #055f4600;transform:scale(1)}}@keyframes pulse-unknown{0%{box-shadow:0 0 0 0 #1e40afb3;transform:scale(1)}50%{box-shadow:0 0 0 10px #1e40af00;transform:scale(1.05)}to{box-shadow:0 0 0 0 #1e40af00;transform:scale(1)}}.deck-info{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;margin-top:auto;padding:1rem}.deck-info-title{color:#718096;font-size:.75rem;font-weight:600;margin:0 0 .5rem;text-transform:uppercase}.deck-info-name{color:#2d3748;font-size:1rem;font-weight:600;margin:0 0 .5rem}.deck-info-stats{color:#4a5568;font-size:.85rem;margin:0}.modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-width:500px;padding:2rem;width:90%}.modal-content h2{color:#2d3748;font-size:1.75rem;font-weight:700;margin:0 0 1.5rem}.modal-input-group{margin-bottom:1rem}.modal-input-group label{color:#4a5568;display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.modal-input-group input{border:2px solid #e2e8f0;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:.75rem;width:100%}.modal-input-group input:focus{border-color:#667eea;outline:none}.modal-info{color:#718096;font-size:.9rem;margin-bottom:1.5rem}.modal-actions{display:flex;gap:1rem}.modal-actions .btn{flex:1 1}.add-card-modal{display:flex;flex-direction:column;max-height:80vh;max-width:600px}.available-words-list{border:2px solid #e2e8f0;border-radius:8px;margin:1rem 0;max-height:400px;overflow-y:auto;padding:.5rem}.words-list{gap:.5rem}.word-item{align-items:center;background:#f7fafc;border:2px solid #0000;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:.75rem;transition:all .2s}.word-item:hover{background:#edf2f7;border-color:#667eea;transform:translateX(4px)}.word-item-content{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.word-item-content strong{color:#2d3748;font-size:1.1rem}.word-type{color:#718096;font-size:.85rem;text-transform:capitalize}.word-meaning{color:#4a5568;font-size:.9rem}.word-item .btn{margin-left:1rem;padding:.5rem 1rem}@media (max-width:768px){.spelling-header{align-items:center;flex-direction:row;flex-wrap:wrap;gap:.5rem;justify-content:space-between;padding:.75rem .75rem .75rem 2.5rem;position:relative}.header-title-section{align-items:center;display:flex;gap:.5rem;margin-bottom:.25rem;margin-left:.75rem;width:100%}.spelling-header h1{flex-shrink:0;font-size:1.25rem;margin:0;padding:0;white-space:nowrap}.spelling-header .study-timer{flex-shrink:0;width:100px}.header-controls{align-items:center;display:flex;flex-direction:row;flex-shrink:0;flex-wrap:nowrap;gap:.5rem;justify-content:flex-end;width:100%}.header-controls>*,.study-timer{box-sizing:border-box;flex-shrink:0;height:40px}.study-timer{width:100px}.deck-select,.study-timer{align-items:center;display:flex;padding:.5rem .75rem}.deck-select{box-sizing:border-box;flex-shrink:0;font-size:.85rem;height:40px;max-width:162px;min-width:130px;width:130px}.header-buttons{display:flex;flex-direction:row;flex-shrink:0;gap:.4rem}.header-buttons .btn{align-items:center;display:flex;font-size:.85rem;height:40px;justify-content:center;line-height:1;padding:.5rem .75rem;text-align:center;white-space:nowrap}.spelling-area{gap:.25rem;justify-content:flex-start;min-height:auto;overflow-y:auto;padding:.5rem}.progress-container{margin-bottom:0;padding:.5rem}.progress-info{font-size:.8rem}.progress-bar{height:6px}.writing-pane-container{flex-shrink:0;margin-bottom:.5rem;max-width:100%;min-width:0;width:100%}.writing-pane{min-height:180px;padding:1.5rem;width:100%}.question-text-container{flex-wrap:wrap;gap:.5rem}.question-text{font-size:1.75rem}.answer-input{font-size:1.25rem;padding:.75rem 1rem}.sentence-text{font-size:.85rem}.spelling-image-container{aspect-ratio:480/300;flex-shrink:0;height:auto;margin-bottom:.75rem;max-height:40vh;max-width:100%;min-width:0;width:100%}.spelling-image{height:100%;object-fit:cover;width:100%}.known-text-overlay,.unknown-text-overlay{font-size:2rem}.image-pane-placeholder .placeholder-icon{font-size:2.5rem}.image-pane-placeholder .placeholder-text{font-size:.85rem;margin-bottom:.5rem}.image-pane-placeholder .generate-image-btn{font-size:.85rem;padding:.5rem 1rem}.replace-image-btn{font-size:1rem;height:35px;padding:.5rem;right:.5rem;top:.5rem;width:35px}.flashcard{aspect-ratio:480/300;flex-shrink:0;height:auto;margin-bottom:.75rem;max-height:50vh;max-width:100%;min-width:0;width:100%}.card-word{font-size:1.75rem}.card-type{font-size:1rem;margin-bottom:.5rem}.card-translation{font-size:1.25rem;margin-bottom:.5rem}.card-sentence{font-size:.95rem}.card-hint{font-size:.75rem;margin-top:.75rem}.card-navigation{align-items:center;display:flex;flex-direction:row;flex-shrink:0;flex-wrap:nowrap;gap:.5rem;justify-content:center;margin-bottom:0;margin-top:.5rem;max-width:100%;padding:0 .5rem;width:100%}.nav-btn,.nav-btn-emoji{flex:1 1;font-size:2.31rem;height:40px;min-width:0}.nav-btn-emoji{padding:0}}.empty-state{padding:4rem 2rem}.results-page{align-items:center;display:flex;justify-content:center;min-height:400px;padding:2rem;width:100%}.results-container{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;max-width:600px;padding:3rem;text-align:center;width:100%}.results-title{color:#667eea;font-size:2.5rem;font-weight:700;margin-bottom:2rem}.results-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr);margin-bottom:2.5rem}.result-stat-card{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px;padding:1.5rem;transition:transform .2s ease}.result-stat-card:hover{transform:translateY(-4px)}.result-stat-known{background:linear-gradient(135deg,#a8edea,#fed6e3)}.result-stat-unknown{background:linear-gradient(135deg,#ffecd2,#fcb69f)}.result-stat-time{background:linear-gradient(135deg,#d299c2,#fef9d7)}.result-stat-label{color:#4a5568;font-size:.9rem;font-weight:600;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.result-stat-value{color:#2d3748;font-size:2.5rem;font-weight:700;margin:0}.results-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.results-actions .btn{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .2s ease}.results-actions .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.results-actions .btn-primary:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.results-actions .btn-secondary{background:#e2e8f0;color:#4a5568}.results-actions .btn-secondary:hover{background:#cbd5e0;transform:translateY(-2px)}@media (max-width:768px){.results-container{padding:2rem 1.5rem}.results-title{font-size:2rem;margin-bottom:1.5rem}.results-stats{gap:1rem;grid-template-columns:1fr;margin-bottom:2rem}.result-stat-value{font-size:2rem}.results-actions{flex-direction:column}.results-actions .btn{width:100%}}@media (max-width:968px){.spelling-content{flex-direction:column}.writing-pane-container{max-width:100%!important;min-width:0!important;width:100%!important}.writing-pane{min-height:180px;padding:1.5rem;width:100%}.spelling-image-container{aspect-ratio:480/300;flex-shrink:0;height:auto;margin-bottom:.75rem;max-height:40vh;max-width:100%;min-width:0;width:100%}.spelling-image{height:100%;object-fit:cover;width:100%}.known-text-overlay,.unknown-text-overlay{font-size:2rem}.flashcard{aspect-ratio:480/200!important;max-height:35vh!important}.card-navigation{max-width:100%!important;width:100%!important}.spelling-sidebar{border-left:none;border-top:2px solid #e2e8f0;flex-direction:row;flex-shrink:0;gap:.75rem;justify-content:space-around;overflow-x:auto;padding:.75rem;width:100%}.mark-as-section{border-bottom:none;border-right:2px solid #e2e8f0;flex:1 1;margin-bottom:0;margin-right:.75rem;min-width:0;padding-bottom:0;padding-right:.75rem}.mark-as-title{font-size:1rem;margin-bottom:.5rem}.status-buttons{flex-direction:column;gap:.5rem}.status-btn{font-size:.85rem;padding:.75rem}.progress-section{flex:1 1;min-width:0}.progress-section h3{font-size:1rem;margin-bottom:.5rem}.stats-grid{flex-direction:row;gap:.5rem;overflow-x:auto}.stat-card{flex:1 1;min-width:80px;padding:.75rem .5rem}.stat-label{font-size:.7rem;margin-bottom:.25rem}.stat-value{font-size:1.25rem}.flashcard{aspect-ratio:480/300!important;height:auto!important;max-height:50vh!important;max-width:100%!important;min-width:0!important;width:100%!important}.card-word{font-size:2rem}}@media (max-width:768px){.spelling-sidebar{flex-direction:column;gap:.75rem;max-height:none;padding:.75rem}.mark-as-section{border-bottom:2px solid #e2e8f0;border-right:none;margin-bottom:.75rem;margin-right:0;padding-bottom:.75rem;padding-right:0;width:100%}.status-buttons{flex-direction:row;gap:.5rem}.status-btn{flex:1 1;font-size:.85rem;padding:.75rem}.progress-section{width:100%}.stats-grid{display:flex!important;flex-direction:row!important;gap:.5rem}.stat-card{flex:1 1!important;min-width:0;padding:.75rem .5rem;width:auto!important}.stat-label{font-size:.7rem;margin-bottom:.25rem}.stat-value{font-size:1.25rem}.card-image{height:100px;width:100px}}.create-deck-container{margin:0 auto;max-width:1400px;padding:2rem}.create-deck-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.create-deck-header h1{color:#2d3748;font-size:2rem;margin:0}.create-deck-form{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:1.5rem}.deck-name-input{margin-bottom:1rem}.deck-name-input label{color:#2d3748;display:block;font-weight:600;margin-bottom:.5rem}.form-input{padding:.75rem;transition:border-color .2s}.form-group{margin-bottom:1rem}.form-label{font-size:.9rem}.form-select{padding:.75rem;transition:border-color .2s}.form-select:focus{border-color:#667eea;outline:none}.form-row{grid-template-columns:repeat(4,1fr);margin-bottom:1rem}.input-with-icon,.textarea-with-icon{align-items:center;display:flex;position:relative}.input-with-icon .form-input,.textarea-with-icon .form-input{padding-right:45px}.textarea-with-icon textarea{resize:vertical}.icon-button{align-items:center;background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;position:absolute;right:8px;transition:all .2s;width:32px}.icon-button:hover:not(:disabled){background:#5568d3;transform:scale(1.1)}.icon-button:disabled{cursor:not-allowed;opacity:.5}.textarea-with-icon .icon-button{bottom:auto;top:8px}.enhanced-ai-section,.manual-creation-section{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:1.5rem}.manual-creation-section h2{color:#2d3748;font-size:1.25rem;margin:0 0 1rem}.selected-count{color:#667eea;font-size:.9rem;font-weight:600}.category-filters-section{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.category-filters-section h2{color:#2d3748;font-size:1.25rem;margin:0 0 1rem}.category-filters-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.category-filter-group{display:flex;flex-direction:column;gap:.5rem}.category-filter-group label{color:#4a5568;font-size:.9rem;font-weight:600}.category-select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:.9rem;padding:.75rem;transition:border-color .2s}.category-select:focus{border-color:#667eea;outline:none}.word-filters{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.filter-input,.filter-select{border:2px solid #e2e8f0;border-radius:8px;font-size:.9rem;padding:.5rem 1rem;transition:border-color .2s}.filter-input{flex:1 1;min-width:100px}.filter-select{min-width:150px}.filter-input:focus,.filter-select:focus{border-color:#667eea;outline:none}.filter-checkbox{align-items:center;color:#4a5568;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem}.filter-checkbox input[type=checkbox]{cursor:pointer}.words-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;overflow-x:auto}.words-table{border-collapse:collapse;min-width:1000px;width:100%}.words-table thead{background:#f7fafc;border-bottom:2px solid #e2e8f0}.words-table th{color:#2d3748;font-size:.9rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.words-table th:first-child{text-align:center;width:50px}.words-table td{border-bottom:1px solid #e2e8f0;color:#4a5568;padding:1rem}.words-table td:first-child{text-align:center}.words-table tbody tr{transition:background-color .2s}.words-table tbody tr:hover{background-color:#f7fafc}.words-table tbody tr.selected{background-color:#e6f3ff}.words-table tbody tr.known{background-color:#f0fff4}.words-table tbody tr.unknown{background-color:#fff5f5}.word-english-cell{color:#2d3748;font-weight:600}.word-english-cell strong{display:block;font-size:1rem}.word-meaning-cell{color:#4a5568}.word-category-cell{min-width:200px}.category-badges{display:flex;flex-direction:column;gap:.25rem}.category-badge{background:#e6fffa;border-radius:4px;color:#234e52;display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .75rem;width:-webkit-fit-content;width:fit-content}.category-badge.category-2{background:#fed7d7;color:#742a2a}.category-badge.category-3{background:#feebc8;color:#7c2d12}.word-level-cell{min-width:60px}.word-level-badge{background:#bee3f8;border-radius:4px;color:#2c5282;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.word-type-cell{min-width:100px}.word-type-badge{background:#edf2f7;border-radius:4px;color:#4a5568;display:inline-block;font-size:.7rem;padding:.2rem .5rem;text-transform:capitalize}.word-status-cell{min-width:120px}.status-badge{border-radius:4px;display:inline-block;font-size:.8rem;font-weight:600;padding:.35rem .75rem}.status-badge.status-known{background:#c6f6d5;color:#22543d}.status-badge.status-unknown{background:#fed7d7;color:#742a2a}.status-badge.status-untracked{background:#e2e8f0;color:#4a5568}.pagination{align-items:center;display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.page-info{color:#4a5568;font-size:1rem;font-weight:600}.empty-state{background:#fff;border-radius:12px;color:#718096;padding:3rem}.loading{color:#718096;font-size:1.1rem}.create-deck-actions{display:flex;justify-content:center;margin-top:2rem}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{border:2px solid #667eea}.btn-secondary:hover{background:#f7fafc}.source-input-group{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.file-upload-group,.webpage-input-group{align-items:center;display:flex;gap:.5rem}.file-upload-label{flex:1 1}.file-upload-button{background:#f7fafc;border:2px dashed #cbd5e0;border-radius:8px;cursor:pointer;display:inline-block;padding:.75rem 1rem;text-align:center;transition:all .2s;width:100%}.file-upload-button:hover{background:#edf2f7;border-color:#667eea}@media (max-width:968px){.words-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.words-table{font-size:.9rem;min-width:900px}.words-table td,.words-table th{padding:.75rem .5rem}.form-row{grid-template-columns:1fr 1fr}}@media (max-width:768px){.create-deck-container{padding:1rem}.create-deck-header{align-items:flex-start;flex-direction:column;gap:1rem}.create-deck-header h1{font-size:1.75rem}.word-filters{flex-direction:row}.filter-input,.filter-select{width:100%}.form-row{grid-template-columns:1fr}.file-upload-group,.webpage-input-group{flex-direction:column}}.edit-deck-container{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);min-height:100vh;padding:2rem}.edit-deck-layout{display:flex;flex-direction:column;gap:2rem;margin:0 auto;max-width:1600px}.edit-deck-form,.edit-deck-pane,.words-pane{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:2rem}.edit-deck-form{margin:0 auto;max-width:1200px}.edit-deck-form h1,.edit-deck-pane h1{color:#2d3748;margin-bottom:2rem}.words-pane h2{color:#2d3748;margin:0}.form-group{margin-bottom:.75rem}.form-label{color:#4a5568;font-size:.75rem;margin-bottom:.25rem}.form-input,.form-select{border:1px solid #e2e8f0;border-radius:4px;font-size:.875rem;transition:border-color .2s;width:100%}.form-input-small{border:1px solid #e2e8f0;border-radius:4px;font-size:.8rem;padding:.4rem .5rem}.form-input-small:focus,.form-input:focus,.form-select:focus{border-color:#667eea;outline:none}.form-input[readonly]{background-color:#f7fafc;cursor:not-allowed}.form-row{grid-gap:1rem;gap:1rem;grid-template-columns:1fr 1fr 1fr}.words-section{margin-top:2rem}.words-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.words-header h2{color:#2d3748}.words-header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.image-service-selector{align-items:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;gap:.75rem;margin-right:.5rem;padding:.5rem .75rem}.image-service-label{color:#4a5568;font-size:.875rem;font-weight:600;margin:0;white-space:nowrap}.radio-group{gap:1rem}.radio-group,.radio-label{align-items:center;display:flex}.radio-label{color:#4a5568;cursor:pointer;font-size:.875rem;gap:.5rem;-webkit-user-select:none;user-select:none}.radio-label input[type=radio]{accent-color:#667eea;cursor:pointer;height:18px;width:18px}.radio-label span{font-weight:500}.no-words-message{background:#f7fafc;border:2px dashed #e2e8f0;border-radius:8px;color:#718096;padding:3rem;text-align:center}.words-list{display:flex;flex-direction:column;gap:1.5rem}.word-card{background:#e6eff5;border:2px solid #e2e8f0;border-radius:8px;padding:1rem}.word-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem}.word-header h3{color:#2d3748;margin:0}.word-header-actions{align-items:center;display:flex;gap:.5rem}.word-content{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:2fr 1fr}.word-main-info{gap:.5rem}.word-image-section,.word-main-info{display:flex;flex-direction:column}.image-controls{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.keywords-input{flex:1 1;min-width:150px}.image-generate-btn{align-items:center;display:flex;font-size:1.2rem;justify-content:center;min-width:40px;padding:.4rem .6rem}.search-query-log{background:#f0f4f8;border-radius:4px;color:#4a5568;font-size:.75rem;margin-bottom:.25rem;margin-top:.5rem;padding:.25rem .5rem}.search-query-log strong{color:#2d3748}.image-error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#dc3545;font-size:.75rem;margin-bottom:.5rem;margin-top:.25rem;padding:.25rem .5rem;word-break:break-word}.word-image-preview{border:2px solid #e2e8f0;border-radius:8px;margin-top:1rem;max-width:100%;overflow:hidden}.word-image-preview img{display:block;height:auto;max-height:300px;object-fit:cover;width:100%}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn{padding:.75rem 1.5rem}.btn-primary{background:#667eea}.btn-primary:hover:not(:disabled){background:#5568d3}.btn-secondary{color:#4a5568}.btn-secondary:hover:not(:disabled){background:#cbd5e0}.btn-danger:hover:not(:disabled){background:#e53e3e}.btn-sm{font-size:.9rem;padding:.5rem 1rem}.btn-large{font-size:1.1rem;padding:1rem 2rem}.btn:disabled{opacity:.5}.loading{color:#4a5568;font-size:1.2rem;padding:3rem;text-align:center}.error-message{background:#fed7d7;border:1px solid #fc8181;border-radius:6px;color:#c53030;margin-bottom:1.5rem;padding:1rem}@media (max-width:1024px){.edit-deck-layout{grid-template-columns:1fr}.edit-deck-pane{position:relative;top:0}.word-content{grid-template-columns:1fr}.form-row{grid-template-columns:1fr 1fr}.form-row .form-group:last-child{grid-column:1/-1}}@media (max-width:768px){.edit-deck-container{padding:1rem}.edit-deck-form,.edit-deck-pane,.words-pane{padding:1.5rem}.form-row{grid-template-columns:1fr}.words-header{align-items:flex-start;flex-direction:column;gap:1rem}.words-header-actions{flex-wrap:wrap;width:100%}.word-header{align-items:flex-start;gap:.5rem}.form-actions,.word-header{flex-direction:column}.form-actions .btn{width:100%}}.decks-container{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);margin:0 auto;max-width:1400px;min-height:100vh;padding:2rem}.decks-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.decks-header h1{color:#2d3748;font-size:2rem;font-weight:700;margin:0}.decks-header-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.deck-card,.decks-empty{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a}.deck-card{transition:transform .2s,box-shadow .2s}.deck-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.deck-badge{background:#e6fffa;border-radius:4px;color:#234e52;font-weight:500;padding:.25rem .75rem}.deck-actions{flex-wrap:wrap}.deck-actions .btn{flex:1 1;min-width:80px}.btn-sm{padding:.4rem .8rem}.btn-danger{border:none}.deck-edit-form{gap:1rem}.deck-edit-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#4a5568;font-size:.85rem;font-weight:600}.form-input,.form-select{border:2px solid #e2e8f0;border-radius:6px;font-family:inherit;font-size:.9rem;padding:.5rem}.form-input:focus,.form-select:focus{border-color:#667eea;outline:none}.form-row{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(3,1fr)}.deck-edit-actions{display:flex;gap:.5rem;margin-top:.5rem}.deck-edit-actions .btn{flex:1 1}@media (max-width:768px){.decks-container{padding:1rem}.decks-header{align-items:stretch;flex-direction:column}.decks-header-controls{flex-direction:column;width:100%}.decks-grid,.form-row{grid-template-columns:1fr}.deck-actions{flex-direction:column}.deck-actions .btn{width:100%}}.deck-quiz-container{background:linear-gradient(135deg,#e0e7ff,#ddd6fe);box-sizing:border-box;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;width:100%}.deck-quiz-header{background:#fff;border-bottom:2px solid #e2e8f0;flex-wrap:wrap;justify-content:space-between;padding:1.5rem 2rem}.deck-quiz-header,.header-title-section{align-items:center;display:flex;gap:1rem}.header-title-section{flex:0 0 auto}.deck-quiz-header h1{color:#2d3748;flex:0 0 auto;font-size:2rem;font-weight:700;margin:0;padding-left:0}.header-controls{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-end}.deck-quiz-content{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:2rem}.deck-quiz-tabs{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:12px;box-shadow:0 4px 12px #00000026;display:flex;gap:.5rem;padding:.25rem}.tab-button{align-items:center;background:#0000;border:none;border-radius:6px;color:#4a5568;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.tab-button:hover{background:#f7fafc}.tab-button.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea66;color:#fff}.tab-button svg{font-size:1rem}.filters{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.filter-select{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #ffffff4d;border-radius:10px;box-shadow:0 2px 8px #0000001a;box-sizing:border-box;color:#2d3748;cursor:pointer;flex:1 1 auto;font-size:.9rem;font-weight:500;max-width:180px;min-width:120px;padding:10px 16px;transition:all .3s;width:auto}.filter-select:hover{background:#fff;border-color:#667eea80;box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.filter-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea33,0 4px 12px #00000026;outline:none}.show-hidden-toggle{align-items:center;background:#0000;border:none;color:#4a5568;cursor:pointer;display:flex;flex-shrink:0;font-size:.9rem;gap:.5rem;padding:0;transition:all .2s;white-space:nowrap}.show-hidden-toggle:hover{color:#667eea}.show-hidden-toggle input[type=checkbox]{accent-color:#667eea;cursor:pointer;flex-shrink:0;height:16px;margin:0;width:16px}.decks-empty{background:linear-gradient(135deg,#ffffffe6,#f0f5ffe6);border:1px solid #ffffff4d;border-radius:16px;box-shadow:0 4px 16px #0000001a;padding:4rem 2rem;text-align:center}.decks-empty p{color:#4a5568;font-size:1.1rem;margin-bottom:1.5rem}.decks-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.deck-card{background:linear-gradient(135deg,#fffffff2,#fafcfff2);border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 16px #0000001a;display:flex;flex-direction:column;gap:1rem;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.deck-card:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.deck-card:hover{border-color:#667eea4d;box-shadow:0 8px 24px #667eea33;transform:translateY(-4px)}.deck-card:hover:before{opacity:1}.deck-card.deck-hidden{border:2px dashed #cbd5e0;opacity:.7}.deck-card-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between}.deck-card-header h3{color:#2d3748;flex:1 1;font-size:1.25rem;font-weight:600;margin:0}.deck-hidden-badge{background:#fed7d7;border-radius:4px;color:#c53030;font-size:.75rem;font-weight:600;padding:.25rem .75rem;white-space:nowrap}.deck-description{color:#4a5568;font-size:.9rem;line-height:1.5;margin:0}.deck-meta{display:flex;flex-wrap:wrap;gap:.5rem}.deck-badge{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border:1px solid #6366f133;border-radius:8px;box-shadow:0 2px 4px #0000000d;color:#3730a3;font-size:.75rem;font-weight:600;padding:.35rem .85rem}.deck-stats{border-top:1px solid #e2e8f0;display:flex;flex-direction:column;gap:.5rem;padding-top:.5rem}.deck-stat{align-items:center;display:flex;justify-content:space-between}.deck-stat-label{color:#4a5568;font-size:.85rem;font-weight:500}.deck-stat-value{color:#2d3748;font-size:.9rem;font-weight:600}.deck-actions{align-items:center;border-top:1px solid #e2e8f0;display:flex;flex-wrap:nowrap;gap:.5rem;padding-top:.5rem}.deck-actions .btn{align-items:center;display:inline-flex;flex:0 0 auto;justify-content:center;min-width:36px;white-space:nowrap}.deck-actions .btn svg{font-size:1rem}.quiz-grid-layout{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr}@media (min-width:1200px){.quiz-grid-layout{grid-template-columns:2fr 1fr}}.quiz-section{background:linear-gradient(135deg,#fffffff2,#fafcfff2);border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 16px #0000001a;padding:2rem}.quiz-section h2{color:#2d3748;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.sessions-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:1.5rem}.session-filters,.sessions-header{align-items:center;display:flex;gap:1rem}.session-filters label{align-items:center;color:#4a5568;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem}.session-filters input[type=radio]{accent-color:#667eea;cursor:pointer}.empty-state{color:#4a5568;padding:2rem;text-align:center}.quiz-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.quiz-card{background:linear-gradient(135deg,#fffffff2,#fafcfff2);border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 16px #0000001a;display:flex;flex-direction:column;gap:1rem;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.quiz-card:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.quiz-card:hover{border-color:#667eea4d;box-shadow:0 8px 24px #667eea33;transform:translateY(-5px)}.quiz-card:hover:before{opacity:1}.quiz-card-header{align-items:start;display:flex;gap:1rem;justify-content:space-between}.quiz-card-header h3{color:#2d3748;flex:1 1;font-size:1.25rem;margin:0}.header-badges{align-items:center;display:flex;gap:.5rem}.quiz-description{color:#4a5568;font-size:.95rem;line-height:1.5;margin:0}.quiz-meta{color:#718096;display:flex;flex-direction:column;font-size:.9rem;gap:.5rem}.quiz-actions{display:flex;flex-direction:row;flex-wrap:nowrap;gap:.5rem;margin-top:auto}.quiz-actions .btn{align-items:center;display:inline-flex;flex:0 0 auto;justify-content:center;min-width:36px}.quiz-actions .btn svg{font-size:1rem}.badge{border-radius:12px;font-size:.85rem;font-weight:600;padding:.25rem .75rem;text-transform:capitalize}.badge-level{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid #3b82f633;box-shadow:0 2px 4px #0000000d;color:#1e3a8a}.sessions-list{display:flex;flex-direction:column;gap:1rem}.session-item{align-items:center;background:linear-gradient(135deg,#f7fafce6,#edf2f7e6);border:1px solid #667eea26;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;gap:1rem;justify-content:space-between;padding:1rem;transition:all .2s}.session-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateX(4px)}.session-item-content{flex:1 1}.session-item strong{color:#2d3748;display:block;margin-bottom:.5rem}.session-meta{color:#718096;display:flex;font-size:.9rem;gap:1rem}.status{border-radius:4px;font-size:.75rem;font-weight:600;padding:2px 8px;text-transform:capitalize}.status-waiting{background:#fed7aa;color:#7c2d12}.status-active{background:#c6f6d5;color:#22543d}.status-completed{background:#cbd5e0;color:#2d3748}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.new-deck-btn{align-items:center;box-sizing:border-box;display:flex;justify-content:center;padding:.5rem;text-align:center;width:50px}.btn-primary{box-shadow:0 4px 12px #667eea4d}.btn-primary:hover{background:linear-gradient(135deg,#5568d3,#6b3fa0);box-shadow:0 6px 16px #667eea66;transform:translateY(-1px)}.btn-secondary{background:#e2e8f0;color:#2d3748}.btn-secondary:hover{background:#cbd5e0}.btn-danger{background:#fc8181}.btn-danger:hover{background:#f56565}.btn-sm{font-size:.85rem;padding:.4rem .72rem}.btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.deck-quiz-container{padding:.5rem}.deck-quiz-header{align-items:stretch;flex-direction:column;flex-wrap:wrap;gap:.5rem;padding:.5rem .5rem .75rem 2.5rem;position:relative}.header-title-section{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.25rem;margin-left:.75rem;width:100%}.deck-quiz-header h1{flex-shrink:0;font-size:1.25rem;margin:0;padding:0;white-space:nowrap}.new-deck-btn{align-items:center;box-sizing:border-box;display:flex;flex:0 0 auto;font-size:.85rem;justify-content:center;min-width:50px;padding:.5rem;text-align:center;white-space:nowrap;width:50px}.deck-quiz-tabs{flex:0 0 auto;order:0}.header-controls{align-items:stretch;flex-direction:column;gap:.75rem;width:100%}.tab-button{flex:1 1;font-size:.9rem;justify-content:center;padding:.6rem 1rem}.filters{flex-direction:row;flex-wrap:wrap;gap:.5rem;order:2;width:100%}.filter-select{box-sizing:border-box;flex:0 0 25%!important;font-size:.9rem;max-width:100%!important;min-width:0!important;padding:.2rem;width:35%!important}.show-hidden-toggle{flex-shrink:0;justify-content:flex-start;padding:0;width:auto}.show-hidden-toggle input[type=checkbox]{flex-shrink:0;height:16px;width:16px}.deck-quiz-content{padding:1rem .5rem}.decks-grid{gap:1rem;grid-template-columns:1fr}.deck-card{padding:1rem}.deck-card-header h3{font-size:1.1rem}.deck-description{font-size:.85rem}.deck-meta{gap:.4rem}.deck-badge{font-size:.7rem;padding:.25rem .6rem}.deck-stats{gap:.4rem}.deck-stat-label,.deck-stat-value{font-size:.8rem}.deck-actions{-webkit-overflow-scrolling:touch;flex-direction:row;flex-wrap:nowrap;gap:.4rem;overflow-x:auto;padding-top:.75rem}.deck-actions .btn{flex-shrink:0;min-width:36px;padding:.5rem;width:auto}.quiz-grid{gap:1rem;grid-template-columns:1fr}.quiz-grid-layout{gap:1.5rem;grid-template-columns:1fr}.quiz-section{padding:1rem}.quiz-section h2{font-size:1.25rem;margin-bottom:1rem}.quiz-card{padding:1rem}.quiz-card-header h3{font-size:1.1rem}.quiz-description{font-size:.85rem}.quiz-meta{font-size:.8rem;gap:.4rem}.quiz-actions{-webkit-overflow-scrolling:touch;flex-direction:row;flex-wrap:nowrap;gap:.4rem;overflow-x:auto}.quiz-actions .btn{flex:0 0 auto;font-size:.8rem;min-width:36px;padding:10px}.sessions-header{align-items:flex-start;flex-direction:column;gap:.75rem}.sessions-header h2{font-size:1.25rem}.session-filters{flex-wrap:wrap;gap:.5rem}.session-filters label{font-size:.85rem}.session-item{align-items:flex-start;flex-direction:column;padding:.75rem}.session-item .btn{margin-top:.5rem;width:100%}.empty-state{padding:2rem 1rem}.empty-state p{font-size:.95rem}}@media (max-width:480px){.deck-quiz-header h1{font-size:1.25rem}.tab-button{font-size:.85rem;padding:.5rem}.tab-button svg{font-size:.9rem}.deck-actions .btn{min-width:64px;padding:.4rem}.quiz-actions .btn{min-width:32px;padding:.4rem .6rem}}.App{display:flex;flex-direction:row}.App,.main-content{background:#f3f4f6;min-height:100vh}.main-content{box-sizing:border-box;flex:1 1;margin:0;padding:0;width:100%}.main-content.with-sidebar{margin-left:250px;width:calc(100% - 250px)}.main-content.public-page{margin-left:0;padding:0;width:100%}@media (max-width:768px){.main-content.with-sidebar{margin-left:0;padding:0;width:100%}}.loading{align-items:center;background:#f3f4f6;color:#2d3748;display:flex;font-size:1.5rem;justify-content:center;min-height:50vh;padding:2rem}.btn{border-radius:8px;display:inline-block;font-size:1rem;font-weight:600;padding:12px 18px;text-align:center;text-decoration:none;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-secondary{background:#fff;color:#667eea}.btn-secondary:hover{background:#f0f0f0}.btn-success{background:#48bb78;color:#fff}.btn-success:hover{background:#38a169}.btn-danger{background:#f56565;color:#fff}.btn-danger:hover{background:#e53e3e}.card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;margin-bottom:1.5rem;padding:2rem}.card-title{color:#2d3748;font-size:1.5rem;font-weight:700;margin-bottom:1rem}.form-group{margin-bottom:1.5rem}.form-label{color:#2d3748;display:block;font-weight:600;margin-bottom:.5rem}.form-input{border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:12px;transition:border-color .3s;width:100%}.form-input:focus{border-color:#667eea;outline:none}.form-select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:12px;width:100%}.quiz-color-1{background:#667eea}.quiz-color-2{background:#f093fb}.quiz-color-3{background:#4facfe}.quiz-color-4{background:#43e97b}
/*# sourceMappingURL=main.bb92a9ad.css.map*/