header{z-index:200;background-color:#fff;padding:.75rem 0;position:sticky;top:0;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}header .container{justify-content:space-between;align-items:center;max-width:1280px;margin:0 auto;padding:0 1rem;display:flex}@media (width>=1024px){header .container{padding:0 2rem}}.logo{color:#111827;align-items:center;gap:.5rem;text-decoration:none;display:flex}.logo:visited{color:#111827}.logo img{width:auto;height:32px}@media (width>=768px){.logo img{height:40px}}.logo span{color:#4f46e5;font-size:1.125rem;font-weight:700}@media (width>=768px){.logo span{font-size:1.25rem}}nav{align-items:center;display:flex}.nav-links{align-items:center;gap:.25rem;list-style:none;display:none}@media (width>=768px){.nav-links,.nav-links.active{display:flex}}.nav-links li{display:flex}.nav-links a{color:#4b5563;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-links a:hover{color:#111827;background-color:#f3f4f6}.nav-links a:visited{color:#4b5563}.nav-links .icon-text-link{align-items:center;gap:.5rem;display:flex}@media (width>=1024px){.nav-links .icon-text-link span{display:inline}}.nav-links svg{flex-shrink:0;width:22px;height:22px}.mobile-menu-toggle{cursor:pointer;background:0 0;border:none;border-radius:.5rem;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:.5rem;display:flex}@media (width>=768px){.mobile-menu-toggle{display:none}}.mobile-menu-toggle:hover{background-color:#f3f4f6}.mobile-menu-toggle span{background-color:#111827;border-radius:1px;width:100%;height:2px;display:block}@media (width<=767px){.nav-links{z-index:400;background-color:#fff;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:none;position:fixed;inset:0}.nav-links.active{display:flex}.nav-links li{width:100%;max-width:280px}.nav-links a{border-radius:.75rem;justify-content:center;padding:1rem;font-size:1.125rem}.nav-links a:hover{background-color:#f3f4f6}.nav-links svg{width:24px;height:24px}}.footer{text-align:center;color:#4b5563;background-color:#fff;border-top:1px solid #e5e7eb;padding:2rem 1rem;font-size:.875rem}@media (width>=1024px){.footer{padding:3rem 1rem;font-size:1rem}}.footer p{margin:0}.footer i{color:#9ca3af;font-style:italic}.footer small{color:#9ca3af}.footer a{color:#4b5563;text-decoration:none}.footer a:hover{color:#111827}.home{min-height:80vh}.hero{color:#fff;text-align:center;background:linear-gradient(135deg,#4f46e5 0%,#3730a3 100%);padding:4rem 0}@media (width>=768px){.hero{padding:5rem 0}}.hero .container{max-width:1024px;margin:0 auto;padding:0 1rem}.hero h1{color:#fff;margin-bottom:1rem;font-size:1.5rem;font-weight:700}@media (width>=768px){.hero h1{font-size:2.25rem}}.hero p{opacity:.9;color:#fff;max-width:600px;margin-bottom:2rem;margin-left:auto;margin-right:auto;font-size:1.125rem}@media (width>=768px){.hero p{font-size:1.25rem}}.hero .cta-buttons{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.button{cursor:pointer;border:none;border-radius:.75rem;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.button.primary{color:#4338ca;background-color:#fff}.button.primary:hover{background-color:#f3f4f6;transform:translateY(-2px);box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}.button.primary:visited{color:#4338ca}.button.secondary{color:#fff;background-color:transparent;border:2px solid rgba(255,255,255,.3)}.button.secondary:hover{background-color:rgba(255,255,255,.1);border-color:rgba(255,255,255,.5)}.button.secondary:visited{color:#fff}.features{background-color:#fff;padding:4rem 0}.features .container{max-width:1280px;margin:0 auto;padding:0 1rem}@media (width>=1024px){.features .container{padding:0 2rem}}.features h2{text-align:center;color:#111827;margin-bottom:3rem;font-size:1.5rem}@media (width>=768px){.features h2{font-size:1.875rem}}.feature-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (width>=640px){.feature-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.feature-grid{grid-template-columns:repeat(3,1fr)}}.feature-card a{color:inherit;background-color:#f9fafb;border-radius:1rem;padding:1.5rem;text-decoration:none;transition:all .15s;display:block}.feature-card a:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}.feature-card a:visited{color:inherit}.feature-card .icon{color:#4f46e5;width:48px;height:48px;margin-bottom:1rem}.feature-card h3{color:#111827;margin-bottom:.5rem;font-size:1.125rem;font-weight:600}.feature-card p{color:#4b5563;margin:0;font-size:.875rem;line-height:1.75}.demo{background-color:#f9fafb;padding:4rem 0}.demo .container{max-width:768px;margin:0 auto;padding:0 1rem}.demo h2{text-align:center;color:#111827;margin-bottom:2rem;font-size:1.5rem}@media (width>=768px){.demo h2{font-size:1.875rem}}.demo-video{color:#fff;text-align:center;background:linear-gradient(135deg,#6366f1 0%,#4338ca 100%);border-radius:1rem;flex-direction:column;justify-content:center;align-items:center;padding:3rem 2rem;display:flex}.demo-video .button.secondary{border-color:rgba(255,255,255,.5);padding:1rem 2rem;font-size:1.125rem}.demo-video .button.secondary:hover{background-color:rgba(255,255,255,.15)}.collection-grid{grid-template-columns:1fr;gap:1.5rem;max-width:1280px;margin:0 auto;padding:2rem 1rem;display:grid}@media (width>=640px){.collection-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.collection-grid{grid-template-columns:repeat(3,1fr);padding:2rem}}.collection-card{background-color:#fff;border-radius:1rem;transition:all .15s;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.collection-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}.collection-card a{color:inherit;text-decoration:none;display:block}.collection-card a:visited{color:inherit}.collection-cover{aspect-ratio:16/9;background:linear-gradient(135deg,#e0e7ff 0%,#c7d2fe 100%);width:100%;position:relative;overflow:hidden}.collection-cover img{object-fit:cover;width:100%;height:100%}.level-badge{color:#fff;text-transform:uppercase;background-color:#4f46e5;border-radius:9999px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;position:absolute;top:.75rem;right:.75rem}.new-badge{color:#fff;background-color:#22c55e;border-radius:9999px;padding:.25rem .75rem;font-size:.75rem;font-weight:700;animation:2s infinite pulse;position:absolute;top:.75rem;left:.75rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.collection-info{padding:1rem}.collection-info h2{color:#111827;margin-bottom:.5rem;font-size:1.125rem;font-weight:600}.collection-info .description{color:#4b5563;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.75rem;font-size:.875rem;display:-webkit-box;overflow:hidden}.collection-info .meta{color:#9ca3af;align-items:center;gap:1rem;font-size:.75rem;display:flex}.collection-info .episode-count{color:#4b5563;background-color:#f3f4f6;border-radius:9999px;align-items:center;padding:.25rem .5rem;font-weight:500;display:inline-flex}.collection-info .last-update{color:#9ca3af}.collection-detail-container{max-width:1280px;margin:0 auto;padding:2rem 1rem}@media (width>=1024px){.collection-detail-container{padding:2rem}}.collection-detail .collection-card{margin-bottom:1.5rem}.collection-detail .collection-card .collection-cover{aspect-ratio:21/9;max-height:300px}.episode-list h2{color:#111827;margin-bottom:1rem;font-size:1.25rem;font-weight:600}.episode-cards{flex-direction:column;gap:.75rem;display:flex}.episode-card{color:inherit;background-color:#fff;border-radius:.75rem;padding:1rem;text-decoration:none;transition:all .15s;display:block;box-shadow:0 1px 2px rgba(0,0,0,.05)}.episode-card:hover{transform:translate(4px);box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)}.episode-card:visited{color:inherit}.episode-card h3{color:#111827;margin-bottom:.5rem;font-size:1rem;font-weight:500}.episode-meta{color:#9ca3af;align-items:center;gap:1rem;font-size:.75rem;display:flex}.episode-meta .duration{background-color:#f3f4f6;border-radius:.375rem;align-items:center;gap:.25rem;padding:.25rem .5rem;display:flex}.episode-meta .update-time{color:#9ca3af}.episode-page{flex-direction:column;min-height:80vh;display:flex}.episode-header{background-color:#fff;border-bottom:1px solid #e5e7eb;padding:1.5rem 0}.episode-header-content{justify-content:space-between;align-items:center;max-width:1280px;margin:0 auto;padding:0 1rem;display:flex}@media (width>=1024px){.episode-header-content{padding:0 2rem}}.episode-header-content .back-link{color:#4b5563;align-items:center;gap:.5rem;font-size:.875rem;text-decoration:none;display:flex}.episode-header-content .back-link:hover{color:#4f46e5}.episode-header-content .back-link svg{width:18px;height:18px}.episode-header-content .episode-nav{align-items:center;gap:.5rem;display:flex}.episode-header-content .episode-nav .nav-btn{color:#4b5563;cursor:pointer;background-color:#f3f4f6;border:none;border-radius:.5rem;justify-content:center;align-items:center;width:36px;height:36px;transition:all .15s;display:flex}.episode-header-content .episode-nav .nav-btn:hover:not(:disabled){color:#111827;background-color:#e5e7eb}.episode-header-content .episode-nav .nav-btn:disabled{opacity:.3;cursor:not-allowed}.episode-header-content .episode-nav .nav-btn svg{width:18px;height:18px}.episode-title{text-align:center;padding:1rem 0}.episode-title h1{color:#111827;max-width:768px;margin:0 auto;padding:0 1rem;font-size:1.25rem;font-weight:600}@media (width>=768px){.episode-title h1{font-size:1.5rem}}@media (width>=768px){.subtitle-container{padding:1.5rem 1rem}}.subtitle-content{background-color:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}@media (width>=768px){.subtitle-content{padding:2rem}}.subtitle-paragraph.highlight{background-color:#eef2ff;border-left:3px solid #6366f1;border-radius:0 .5rem .5rem 0;padding:.75rem 1rem}.word-popup-overlay{z-index:300;background-color:rgba(0,0,0,.5);justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}@media (width>=768px){.word-popup-overlay{padding:2rem}}.word-popup{background-color:#fff;border-radius:1rem;flex-direction:column;width:100%;max-width:500px;max-height:80vh;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}.word-popup-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.word-popup-header h3{color:#111827;font-size:1.25rem;font-weight:600}.word-popup-header .close-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:.5rem;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.word-popup-header .close-btn:hover{color:#111827;background-color:#f3f4f6}.word-popup-content{flex:1;padding:1.5rem;overflow-y:auto}.word-phonetic{color:#9ca3af;margin-bottom:1rem;font-size:.875rem}.word-definition{border-bottom:1px solid #e5e7eb;margin-bottom:1rem;padding-bottom:1rem}.word-definition:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.word-definition .pos{color:#4338ca;background-color:#e0e7ff;border-radius:.375rem;margin-bottom:.5rem;padding:.25rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.word-definition .meaning{color:#111827;font-size:1rem;line-height:1.75}.word-menu button{color:#111827;cursor:pointer;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;flex:1;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .15s}.word-menu button:hover{background-color:#f9fafb;border-color:#d1d5db}.word-menu button.primary{color:#fff;background-color:#4f46e5;border-color:#4f46e5}.word-menu button.primary:hover{background-color:#4338ca}.flashcard-container{perspective:1000px;justify-content:center;align-items:center;padding:2rem 1rem;display:flex}.flashcard{width:100%;max-width:320px;height:220px;transform-style:preserve-3d;transition:transform .6s;position:relative}.flashcard.flipped{transform:rotateY(180deg)}.flashcard-face{backface-visibility:hidden;text-align:center;border-radius:1rem;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:1.5rem;display:flex;position:absolute}.flashcard-face.front{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#4338ca 100%)}.flashcard-face.front h2{color:#fff;margin-bottom:.5rem;font-size:1.875rem}.flashcard-face.front p{opacity:.8;font-size:.875rem}.flashcard-face.back{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%);transform:rotateY(180deg)}.flashcard-face.back h3{color:#fff;margin-bottom:.75rem;font-size:1.25rem}.flashcard-face.back p{opacity:.9;font-size:1rem}.flashcard-controls{justify-content:center;gap:1rem;margin-top:1.5rem;display:flex}.main{flex-direction:column;min-height:80vh;display:flex}.subtitle-container{flex:1;width:100%;max-width:768px;margin:0 auto;padding:1rem;overflow-y:auto}@media (width>=768px){.subtitle-container{padding:1.5rem 1rem}}.subtitle-text{background-color:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}@media (width>=768px){.subtitle-text{padding:2rem}}.subtitle-paragraph{color:#111827;margin-bottom:1rem;font-size:1.125rem;line-height:1.75}.subtitle-paragraph:last-child{margin-bottom:0}.subtitle-paragraph.last{background-color:#eef2ff;border-left:3px solid #6366f1;border-radius:.75rem;padding:1rem;font-size:1.25rem;font-weight:500}.highlight{color:#4338ca;cursor:pointer;background-color:#e0e7ff;border-radius:.375rem;padding:.25rem .5rem;font-weight:500;transition:all .15s}.highlight:hover{background-color:#c7d2fe}.audio-player{max-width:768px;margin:1rem auto;padding:1rem}@media (width>=768px){.audio-player{padding:1.5rem}}.audio-player audio{width:100%;display:none}.main-panel{align-items:center;gap:1rem;margin-bottom:.75rem;display:flex}.left-panel{flex:1;min-width:0}.progress-container{cursor:pointer;background-color:#e5e7eb;border-radius:.5rem;width:100%;height:36px;position:relative;overflow:hidden}@media (width<=767px){.progress-container{height:28px}}.progress-bar{background:linear-gradient(90deg,#6366f1 0%,#4f46e5 100%);border-radius:.5rem;align-items:center;height:100%;transition:width .1s linear;display:flex;position:relative;overflow:hidden}.progress-bar-animated{background:repeating-linear-gradient(-45deg,transparent,transparent 8px,rgba(255,255,255,.15) 8px 16px) 0 0/32px 32px;position:absolute;inset:0}.progress-bar-animated .episode-title{z-index:1;white-space:nowrap;padding:0 .75rem;position:relative}.progress-bar-animated .episode-title h3{color:#fff;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.875rem;font-weight:500;overflow:hidden}@keyframes moveStripes{0%{background-position:0 0}to{background-position:32px 0}}.album-icon{cursor:pointer;background:0 0;border:none;border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;padding:0;display:flex;position:relative}.album-icon:hover{transform:scale(1.05)}.album-icon .album{width:64px;height:64px}.album-icon .album.spinning{animation:8s linear infinite spin}.album-icon .album.paused{animation-play-state:paused}.album-icon .pause{opacity:0;fill:#111827;width:24px;height:24px;transition:opacity .15s;position:absolute}.album-icon:hover .pause{opacity:.7}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.time-display{color:#4b5563;font-variant-numeric:tabular-nums;justify-content:space-between;margin-bottom:.75rem;font-size:12px;display:flex}.controls-container{align-items:center;display:flex}.audio-controls{align-items:center;gap:.5rem;width:100%;display:flex}.audio-controls.hidden{visibility:hidden}.control-btn{color:#4b5563;cursor:pointer;background:0 0;border:none;border-radius:.5rem;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:all .15s;display:flex}.control-btn:hover{color:#111827;background-color:#f3f4f6}.control-btn svg{width:20px;height:20px}.speed-menu{position:relative}.speed-options{z-index:100;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;margin:0 0 .5rem;padding:0;list-style:none;display:none;position:absolute;bottom:100%;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}.speed-options.show{display:block}.speed-options button{text-align:left;cursor:pointer;white-space:nowrap;background:0 0;border:none;width:100%;padding:.5rem 1rem;font-size:.875rem;transition:background-color .15s;display:block}.speed-options button:hover{background-color:#f9fafb}.speed-options button.active{color:#4338ca;background-color:#eef2ff;font-weight:500}.volume-container{align-items:center;gap:.5rem;margin-left:auto;display:flex}.volume-container span{color:#9ca3af;min-width:30px;font-size:.75rem}.volume-slider{appearance:none;cursor:pointer;background-color:#e5e7eb;border-radius:9999px;outline:none;width:80px;height:4px}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background-color:#4f46e5;border-radius:9999px;width:14px;height:14px;transition:transform .15s}.volume-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.volume-slider::-moz-range-thumb{cursor:pointer;background-color:#4f46e5;border:none;border-radius:9999px;width:14px;height:14px}@media (width>=768px){.volume-slider{width:100px}}.form-container{background-color:#f9fafb;justify-content:center;align-items:center;min-height:80vh;padding:2rem 1rem;display:flex}.auth-form{background-color:#fff;border-radius:1rem;width:100%;max-width:400px;padding:2rem;box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}.auth-form h1{text-align:center;color:#111827;margin-bottom:1.5rem;font-size:1.5rem;font-weight:700}.input-group{margin-bottom:1.25rem;position:relative}.input-group input{box-sizing:border-box;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.75rem 1rem .75rem 2.5rem;font-size:1rem;transition:all .15s}.input-group input:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}.input-group input::placeholder{color:#9ca3af}.input-group label{color:#9ca3af;pointer-events:none;background-color:#fff;padding:0 .25rem;font-size:1rem;transition:all .15s;position:absolute;top:50%;left:2.5rem;transform:translateY(-50%)}.input-group input:focus+label{color:#4f46e5;background-color:#fff;font-size:.75rem;top:0;left:.75rem}.input-group input:not(:placeholder-shown)+label{color:#4f46e5;background-color:#fff;font-size:.75rem;top:0;left:.75rem}.input-group svg{color:#9ca3af;pointer-events:none;width:20px;height:20px;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.input-group input:focus~label{left:2.5rem}.input-group input:not(:placeholder-shown)~label{left:2.5rem}button[type=submit]{color:#fff;cursor:pointer;background-color:#4f46e5;border:none;border-radius:.5rem;width:100%;margin-top:1rem;padding:.75rem 1rem;font-size:1rem;font-weight:600;transition:all .15s}button[type=submit]:hover{background-color:#4338ca}button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.switch-auth{text-align:center;color:#4b5563;border-top:1px solid #e5e7eb;margin-top:1.5rem;padding-top:1.5rem;font-size:.875rem}.switch-auth a{color:#4f46e5;font-weight:600}.switch-auth a:hover{color:#4338ca}.error-message{color:#dc2626;background-color:#fef2f2;border-radius:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.success-message{color:#16a34a;background-color:#f0fdf4;border-radius:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.dashboard{min-height:90vh;display:flex}.sidebar{color:#fff;background-color:#111827;flex-shrink:0;width:260px;transition:width .3s;overflow-x:hidden}.sidebar.folded{width:60px}.sidebar.folded .menu-text{display:none}.sidebar.folded a:hover .menu-text{white-space:nowrap;z-index:100;background-color:#1f2937;border-radius:.5rem;margin-left:.5rem;padding:.5rem .75rem;display:block;position:absolute;left:100%}@media (width>=1024px){.sidebar{width:280px}}.nav-menu{padding:1rem 0}.nav-menu ul{list-style:none}.nav-menu li{margin-bottom:.25rem}.nav-menu a{color:#9ca3af;border-radius:0 .5rem .5rem 0;align-items:center;gap:.75rem;margin-right:1rem;padding:.75rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex;position:relative}.nav-menu a:hover{color:#fff;background-color:rgba(255,255,255,.1)}.nav-menu a:visited{color:#9ca3af}.nav-menu a.active{color:#fff;background-color:#4f46e5}.nav-menu a svg{flex-shrink:0;width:20px;height:20px}.nav-menu .menu-text{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.admin-main-panel{background-color:#f9fafb;flex:1;overflow-y:auto}@media (width>=1024px){.dashboard-content{padding:2rem}}@media (width>=768px){.dashboard-title{font-size:1.875rem}}@media (width>=640px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.stats-grid{grid-template-columns:repeat(4,1fr)}}@media (width>=768px){.stat-value{font-size:1.875rem}}.container{padding:0 1rem}@media (width>=1024px){.container{padding:0 2rem}}.collections-table{border-collapse:collapse;background-color:#fff;border-radius:1rem;width:100%;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.action-icons .icon{cursor:pointer;opacity:.6;width:20px;height:20px;transition:transform .15s,opacity .15s}.modal{z-index:300;background-color:rgba(0,0,0,.5);justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background-color:#fff;border-radius:1rem;flex-direction:column;width:100%;max-width:500px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}.modal-content h2{color:#111827;border-bottom:1px solid #e5e7eb;padding:1rem 1.5rem;font-size:1.25rem;font-weight:600}.form-group label{color:#4b5563;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:flex}.form-group label svg{width:18px;height:18px}.form-group input,.form-group select,.form-group textarea{box-sizing:border-box;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.75rem 1rem;font-size:1rem;transition:all .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}.collection-select{appearance:none;background-color:#fff;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.75rem 2.5rem .75rem 1rem;font-size:1rem}.collection-select:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}.form-actions{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.btn{cursor:pointer;border:1px solid transparent;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn.btn-primary{color:#fff;background-color:#4f46e5}.btn.btn-primary:hover{background-color:#4338ca}.btn:not(.btn-primary){color:#111827;background-color:#fff;border-color:#e5e7eb}.btn:not(.btn-primary):hover{background-color:#f9fafb;border-color:#d1d5db}.pagination .preBtn{align-items:center;gap:.5rem;display:inline-flex}@media (width<=768px){.sidebar{z-index:400;transition:transform .3s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar:not(.folded){transform:translate(0)}.admin-main-panel{width:100%}}.admin-collections-page{padding:1.5rem}@media (width>=1024px){.admin-collections-page{padding:2rem}}.admin-collections-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.admin-collections-header h1{color:#111827;font-size:1.5rem;font-weight:700}.collections-table-container{background-color:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.collections-table{border-collapse:collapse;width:100%}.collections-table th{text-align:left;color:#4b5563;text-transform:uppercase;letter-spacing:.05em;background-color:#f9fafb;border-bottom:2px solid #e5e7eb;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.collections-table td{color:#111827;border-bottom:1px solid #e5e7eb;padding:.75rem 1rem;font-size:.875rem}.collections-table tbody tr{transition:background-color .15s}.collections-table tbody tr:hover{background-color:#f9fafb}.level-badge{text-transform:uppercase;border-radius:9999px;align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.level-badge.elementary{color:#16a34a;background-color:#f0fdf4}.level-badge.intermediate{color:#4338ca;background-color:#e0e7ff}.level-badge.advanced{color:#d97706;background-color:#fffbeb}.level-badge.hard{color:#dc2626;background-color:#fef2f2}.episode-count{color:#4b5563;background-color:#f3f4f6;border-radius:9999px;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.uuid-display{color:#9ca3af;text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:.75rem;overflow:hidden}.collection-actions{align-items:center;gap:.5rem;display:flex}.collection-actions .action-btn{color:#4b5563;cursor:pointer;background:0 0;border:1px solid #e5e7eb;border-radius:.5rem;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.collection-actions .action-btn:hover{color:#111827;background-color:#f9fafb;border-color:#d1d5db}.collection-actions .action-btn.delete:hover{color:#dc2626;background-color:#fef2f2;border-color:#ef4444}.collection-actions .action-btn svg{width:16px;height:16px}.admin-collection-form{padding:1.5rem}@media (width>=1024px){.admin-collection-form{padding:2rem}}.form-card{background-color:#fff;border-radius:1rem;max-width:600px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.form-card-header{border-bottom:1px solid #e5e7eb;padding:1rem 1.5rem}.form-card-header h2{color:#111827;font-size:1.25rem;font-weight:600}.form-card-body{padding:1.5rem}.form-group:last-child{margin-bottom:0}.form-group textarea,.form-group select{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.75rem 1rem;font-size:1rem;transition:all .15s}.form-group input[type=text]{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.75rem 1rem;font-size:1rem;transition:all .15s}.form-group input[type=number]{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.75rem 1rem;font-size:1rem;transition:all .15s}.form-group textarea:focus,.form-group select:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}.form-group input[type=text]:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}.form-group input[type=number]:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}.form-group input[type=text]::placeholder{color:#9ca3af}.form-group input[type=number]::placeholder{color:#9ca3af}.form-group textarea::placeholder{color:#9ca3af}.form-group select::placeholder{color:#9ca3af}.form-group textarea:disabled,.form-group select:disabled{cursor:not-allowed;background-color:#f3f4f6}.form-group input[type=text]:disabled{cursor:not-allowed;background-color:#f3f4f6}.form-group input[type=number]:disabled{cursor:not-allowed;background-color:#f3f4f6}.form-group textarea{resize:vertical;min-height:120px}.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}.form-hint{color:#9ca3af;margin-top:.25rem;font-size:.75rem}.form-error{color:#dc2626;margin-top:.25rem;font-size:.75rem}.form-actions{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.tasks-page{padding:1.5rem}@media (width>=1024px){.tasks-page{padding:2rem}}.tasks-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.tasks-header h1{color:#111827;font-size:1.5rem;font-weight:700}.tasks-table-container{background-color:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.tasks-table{border-collapse:collapse;width:100%}.tasks-table th{text-align:left;color:#4b5563;text-transform:uppercase;letter-spacing:.05em;background-color:#f9fafb;border-bottom:2px solid #e5e7eb;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.tasks-table th:first-child{padding-left:1.5rem}.tasks-table th:last-child{padding-right:1.5rem}.tasks-table td{color:#111827;border-bottom:1px solid #e5e7eb;padding:.75rem 1rem;font-size:.875rem}.tasks-table td:first-child{padding-left:1.5rem}.tasks-table td:last-child{padding-right:1.5rem}.tasks-table tbody tr{transition:background-color .15s}.tasks-table tbody tr:hover{background-color:#f9fafb}.status-badge{border-radius:9999px;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.status-badge.pending{color:#d97706;background-color:#fffbeb}.status-badge.running{color:#0284c7;background-color:#e0f2fe}.status-badge.done{color:#16a34a;background-color:#f0fdf4}.status-badge.error{color:#dc2626;background-color:#fef2f2}.status-badge.unknown{color:#4b5563;background-color:#f3f4f6}.filter-controls{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.filter-controls .filter-select{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;min-width:150px;padding:.5rem .75rem;font-size:.875rem}.filter-controls .filter-select:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}.task-actions{align-items:center;gap:.5rem;display:flex}.task-actions .action-btn{color:#4b5563;cursor:pointer;background:0 0;border:1px solid #e5e7eb;border-radius:.5rem;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.task-actions .action-btn:hover{color:#111827;background-color:#f9fafb;border-color:#d1d5db}.task-actions .action-btn.reset:hover{color:#d97706;background-color:#fffbeb;border-color:#f59e0b}.task-actions .action-btn.delete:hover{color:#dc2626;background-color:#fef2f2;border-color:#ef4444}.task-actions .action-btn svg{width:16px;height:16px}.worker-popup{z-index:300;background-color:rgba(0,0,0,.5);justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.worker-popup-content{text-align:center;background-color:#fff;border-radius:1rem;width:100%;max-width:480px;padding:2rem;box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}.worker-popup-content .success-icon{color:#16a34a;background-color:#f0fdf4;border-radius:9999px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 1rem;display:flex}.worker-popup-content .success-icon svg{width:32px;height:32px}.worker-popup-content h2{color:#111827;margin-bottom:.5rem;font-size:1.25rem;font-weight:700}.worker-popup-content p{color:#4b5563;margin-bottom:1rem;font-size:.875rem}.worker-popup-content .token-display{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.worker-popup-content .token-display textarea{color:#111827;resize:none;cursor:pointer;background:0 0;border:none;width:100%;min-height:80px;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:.875rem}.worker-popup-content .token-display textarea:focus{outline:none}.worker-popup-content .copy-hint{color:#9ca3af;margin-bottom:1rem;font-size:.75rem}.worker-popup-content .warning-text{color:#d97706;background-color:#fffbeb;border-radius:.5rem;margin-bottom:1.5rem;padding:.75rem;font-size:.75rem}.worker-form .form-group{margin-bottom:1rem}.worker-form .form-group label{color:#4b5563;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:flex}.worker-form .form-group label svg{width:18px;height:18px}.edit-task-form .form-group{margin-bottom:1rem}.edit-task-form .form-group label{color:#4b5563;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:flex}.edit-task-form .form-group label svg{width:18px;height:18px}.dashboard-content{padding:1.5rem}@media (width>=1024px){.dashboard-content{padding:2rem}}.dashboard-title{color:#111827;margin-bottom:1.5rem;font-size:1.5rem;font-weight:700}@media (width>=768px){.dashboard-title{font-size:1.875rem}}.dashboard-subtitle{color:#4b5563;margin-top:-1rem;margin-bottom:2rem;font-size:1rem}.stats-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media (width>=640px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:1rem;align-items:center;gap:1rem;padding:1.25rem;transition:all .15s;display:flex;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)}.stat-icon{border-radius:.75rem;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.stat-icon.users-icon{color:#4f46e5;background-color:#e0e7ff}.stat-icon.admins-icon{color:#9333ea;background-color:#f3e8ff}.stat-icon.collections-icon{color:#16a34a;background-color:#f0fdf4}.stat-icon.episodes-icon{color:#d97706;background-color:#fffbeb}.stat-icon.tasks-icon{color:#0284c7;background-color:#e0f2fe}.stat-icon.pending-icon{color:#d97706;background-color:#fef3c7}.stat-icon.done-icon{color:#16a34a;background-color:#f0fdf4}.stat-icon.error-icon{color:#dc2626;background-color:#fef2f2}.stat-icon svg{width:28px;height:28px}.stat-info{flex-direction:column;min-width:0;display:flex}.stat-value{color:#111827;font-size:1.5rem;font-weight:700;line-height:1}@media (width>=768px){.stat-value{font-size:1.875rem}}.stat-label{color:#4b5563;margin-top:.25rem;font-size:.875rem}.quick-actions{margin-top:2rem}.quick-actions h2{color:#111827;margin-bottom:1rem;font-size:1.25rem;font-weight:600}.actions-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media (width>=640px){.actions-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.actions-grid{grid-template-columns:repeat(4,1fr)}}.action-card{color:#111827;background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;align-items:center;gap:.75rem;padding:1rem;text-decoration:none;transition:all .15s;display:flex;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.action-card:hover{border-color:#c7d2fe;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)}.action-card:visited{color:#111827}.action-card .action-icon{color:#4f46e5;background-color:#e0e7ff;border-radius:.5rem;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.action-card .action-icon svg{width:22px;height:22px}.action-card .action-info{min-width:0}.action-card .action-info h3{margin-bottom:.25rem;font-size:.875rem;font-weight:600}.action-card .action-info p{color:#4b5563;font-size:.75rem}.recent-activity{margin-top:2rem}.recent-activity h2{color:#111827;margin-bottom:1rem;font-size:1.25rem;font-weight:600}.activity-list{background-color:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.activity-item{border-bottom:1px solid #e5e7eb;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.activity-item:last-child{border-bottom:none}.activity-item .activity-icon{border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.activity-item .activity-icon.success{color:#16a34a;background-color:#f0fdf4}.activity-item .activity-icon.warning{color:#d97706;background-color:#fffbeb}.activity-item .activity-icon.error{color:#dc2626;background-color:#fef2f2}.activity-item .activity-content{flex:1;min-width:0}.activity-item .activity-content p{color:#111827;font-size:.875rem}.activity-item .activity-content .activity-time{color:#9ca3af;font-size:.75rem}.loading{color:#4b5563;justify-content:center;align-items:center;padding:3rem;font-size:.875rem;display:flex}.admin-users-page{padding:1.5rem}@media (width>=1024px){.admin-users-page{padding:2rem}}.admin-users-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.admin-users-header h1{color:#111827;font-size:1.5rem;font-weight:700}.section-title{color:#111827;border-bottom:2px solid #6366f1;margin-bottom:1rem;padding-bottom:.75rem;font-size:1.25rem;font-weight:600}.section-title:not(:first-child){margin-top:2rem}.users-table-container{background-color:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.users-table{border-collapse:collapse;width:100%}.users-table th{text-align:left;color:#4b5563;text-transform:uppercase;letter-spacing:.05em;background-color:#f9fafb;border-bottom:2px solid #e5e7eb;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.users-table td{color:#111827;border-bottom:1px solid #e5e7eb;padding:.75rem 1rem;font-size:.875rem}.users-table tbody tr{transition:background-color .15s}.users-table tbody tr:hover{background-color:#f9fafb}.user-info{align-items:center;gap:.75rem;display:flex}.user-avatar{color:#4338ca;background-color:#e0e7ff;border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.875rem;font-weight:600;display:flex}.user-details{min-width:0}.user-details .user-name{color:#111827;font-weight:500}.user-details .user-email{color:#9ca3af;font-size:.75rem}.admin-level-badge{border-radius:9999px;align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.admin-level-badge.super-admin{color:#d97706;background-color:#fef3c7}.admin-level-badge.admin{color:#4338ca;background-color:#e0e7ff}.admin-level-badge.moderator{color:#16a34a;background-color:#f0fdf4}.user-actions{align-items:center;gap:.5rem;display:flex}.user-actions .action-btn{color:#4b5563;cursor:pointer;background:0 0;border:1px solid #e5e7eb;border-radius:.5rem;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.user-actions .action-btn:hover{color:#111827;background-color:#f9fafb;border-color:#d1d5db}.user-actions .action-btn.delete:hover{color:#dc2626;background-color:#fef2f2;border-color:#ef4444}.user-actions .action-btn svg{width:16px;height:16px}.profile-container{max-width:768px;margin:0 auto;padding:1.5rem 1rem}@media (width>=1024px){.profile-container{padding:2rem}}.user-info{background-color:#fff;border-radius:1rem;margin-bottom:1.5rem;padding:1.5rem;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.user-info p{color:#111827;margin-bottom:.5rem;font-size:1rem}.user-info p:last-of-type{margin-bottom:1rem}.user-info p span{color:#4b5563;font-size:.875rem}.user-info .btn{cursor:pointer;border:none;border-radius:.5rem;align-items:center;gap:.5rem;margin-right:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.user-info .btn.btn-edit{color:#fff;background-color:#4f46e5}.user-info .btn.btn-edit:hover{background-color:#4338ca}.user-info .btn.btn-logout{color:#fff;background-color:#ef4444}.user-info .btn.btn-logout:hover{background-color:#dc2626}.tabs{background-color:#fff;border-bottom:1px solid #e5e7eb;border-radius:.75rem .75rem 0 0;margin-bottom:1rem;display:flex;overflow:hidden}.tabs .tab{color:#4b5563;cursor:pointer;background:0 0;border:none;border-bottom:2px solid transparent;flex:1;padding:.75rem 1rem;font-size:.875rem;font-weight:500;transition:all .15s}.tabs .tab:hover{color:#111827;background-color:#f9fafb}.tabs .tab.active{color:#4f46e5;background-color:#fff;border-bottom-color:#4f46e5}.tab-content{background-color:#fff;border-radius:1rem;padding:1rem;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}@media (width>=1024px){.tab-content{padding:1.5rem}}.edit-form{max-width:400px}.edit-form .form-group{margin-bottom:1rem}.edit-form .form-group label{color:#4b5563;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.edit-form .form-group input{box-sizing:border-box;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.75rem 1rem;font-size:1rem;transition:all .15s}.edit-form .form-group input:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}.edit-form .btn{cursor:pointer;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .15s;display:inline-flex}.edit-form .btn.btn-save{color:#fff;background-color:#4f46e5}.edit-form .btn.btn-save:hover{background-color:#4338ca}.more-link{color:#4f46e5;border-radius:.5rem;margin-top:1rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:inline-block}.more-link:hover{color:#4338ca;background-color:#eef2ff}.more-link:visited{color:#4f46e5}.list{flex-direction:column;gap:1rem;padding:0;list-style:none;display:flex}.list li{margin:0}.flashcard-container{perspective:1000px;justify-content:center;align-items:center;display:flex}.flashcard{width:100%;max-width:300px;height:200px;transform-style:preserve-3d;cursor:pointer;background:0 0;border:none;padding:0;transition:transform .6s;position:relative}.flashcard.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s;position:relative}.flashcard-front,.flashcard-back{backface-visibility:hidden;text-align:center;border-radius:1rem;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:1.5rem;display:flex;position:absolute;box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}.flashcard-front{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#4338ca 100%)}.flashcard-front small{opacity:.8;margin-bottom:.75rem;font-size:.75rem}.flashcard-front h2{color:#fff;margin-bottom:.75rem;font-size:1.875rem}.flashcard-front p{font-size:.875rem}.flashcard-front p a{color:#fff;text-decoration:underline}.flashcard-front p a:visited{color:#fff}.flashcard-back{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%);transform:rotateY(180deg)}.flashcard-back h3{color:#fff;margin-bottom:.75rem;font-size:1.125rem}.flashcard-back p{opacity:.95;font-size:1rem;line-height:1.75}.flashcard-back p span{font-weight:600}.flashcard-back small{margin-top:1rem}.flashcard-back small a{color:#f59e0b;text-decoration:underline}.flashcard-back small a:visited{color:#f59e0b}.word{cursor:pointer;border-radius:.375rem;padding:0 .25rem;transition:all .15s}.word:hover{color:#4338ca;background-color:#e0e7ff}.overlay{z-index:300;background-color:rgba(0,0,0,.6);justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@media (width>=768px){.overlay{padding:2rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.popup{background-color:#fff;border-radius:1rem;flex-direction:column;width:100%;max-width:500px;max-height:80vh;animation:.3s slideUp;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.popup-content{flex:1;padding:1rem;overflow-y:auto}@media (width>=768px){.popup-content{padding:1.5rem}}.popup-content .close-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:.5rem;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex;position:absolute;top:.75rem;right:.75rem}.popup-content .close-btn:hover{color:#111827;background-color:#f3f4f6}.popup-content .close-btn svg{width:20px;height:20px}.word-content h3{color:#111827;margin-bottom:.5rem;font-size:1.25rem;font-weight:700}.word-content .phonetic{color:#9ca3af;margin-bottom:1rem;font-size:.875rem;font-style:italic}.word-content .pos{color:#4338ca;background-color:#e0e7ff;border-radius:.375rem;margin-bottom:.75rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.word-content p{color:#111827;margin-bottom:.75rem;font-size:1rem;line-height:1.75}.word-content p:last-child{margin-bottom:0}.word-menu{background-color:#f9fafb;border-top:1px solid #e5e7eb;gap:.5rem;padding:.75rem 1rem;display:flex}.word-menu .menu-item{color:#111827;cursor:pointer;text-align:center;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;flex:1;padding:.5rem .75rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:block}.word-menu .menu-item:hover{background-color:#f9fafb;border-color:#d1d5db}.word-menu .menu-item:visited{color:#111827}.word-menu .menu-item.primary{color:#fff;background-color:#4f46e5;border-color:#4f46e5}.word-menu .menu-item.primary:hover{background-color:#4338ca}.word-menu .menu-item.primary:visited{color:#fff}.dictionary-container{max-width:768px;margin:0 auto;padding:2rem 1rem}@media (width>=1024px){.dictionary-container{padding:2rem}}.dictionary-search{margin-bottom:1.5rem}.dictionary-search form{width:100%}.dictionary-search input[type=search]{box-sizing:border-box;background-color:#fff;border:2px solid #e5e7eb;border-radius:1rem;width:100%;padding:1rem;font-size:1.125rem;transition:all .15s}.dictionary-search input[type=search]:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 4px #e0e7ff}.dictionary-search input[type=search]::placeholder{color:#9ca3af}.word-container{background-color:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.header{border-bottom:1px solid #e5e7eb;padding:1.5rem}.header h1{color:#111827;margin-bottom:.5rem;font-size:1.5rem;font-weight:700}@media (width>=768px){.header h1{font-size:1.875rem}}.header .phonetic{color:#4b5563;font-size:1rem;font-style:italic}.tags{border-bottom:1px solid #e5e7eb;flex-wrap:wrap;gap:.5rem;padding:1rem 1.5rem;display:flex}.tags .tag{color:#4338ca;background-color:#eef2ff;border:1px solid #c7d2fe;border-radius:.5rem;padding:.25rem .75rem;font-size:.875rem;transition:all .15s}.tags .tag:hover{background-color:#e0e7ff}.word-info{border-bottom:1px solid #e5e7eb;grid-template-columns:1fr;gap:.75rem;padding:1.5rem;display:grid}@media (width>=768px){.word-info{grid-template-columns:repeat(2,1fr)}}.word-info .pos{color:#4338ca;background-color:#e0e7ff;border-radius:.5rem;grid-column:span 1;padding:.5rem .75rem;font-size:.875rem;font-weight:600}.word-info .collins,.word-info .oxford{color:#4b5563;background-color:#f9fafb;border-radius:.5rem;padding:.5rem .75rem;font-size:.875rem}.word-info .collins p,.word-info .oxford p{align-items:center;gap:.5rem;margin:0;display:flex}.word-info .icon{width:18px;height:18px}.word-info .icon.check{color:#22c55e}.word-info .icon.cross{color:#ef4444}.word-info .frequency{grid-column:span 1;gap:1rem;display:flex}.word-info .frequency .frq,.word-info .frequency .bnc{color:#4b5563;background-color:#f9fafb;border-radius:.5rem;padding:.5rem .75rem;font-size:.875rem}.definitions{border-bottom:1px solid #e5e7eb;padding:1.5rem}.definitions h2{color:#111827;margin-bottom:1rem;font-size:1.125rem;font-weight:600}.definitions p{color:#111827;margin-bottom:.75rem;font-size:1rem;line-height:1.75}.definitions p:last-child{margin-bottom:0}.translations{border-bottom:1px solid #e5e7eb;padding:1.5rem}.translations h2{color:#111827;margin-bottom:1rem;font-size:1.125rem;font-weight:600}.translations p{color:#111827;margin-bottom:.75rem;font-size:1rem;line-height:1.75}.translations p:last-child{margin-bottom:0}.exchange{padding:1.5rem}.exchange p{color:#4b5563;margin-bottom:.5rem;font-size:.875rem;line-height:1.75}.exchange p:last-child{margin-bottom:0}.audio{border-top:1px solid #e5e7eb;padding:1.5rem}.audio h2{color:#111827;margin-bottom:1rem;font-size:1.125rem;font-weight:600}.audio audio{width:100%}.not-found{color:#ef4444;font-weight:600}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{color:#111827;background-color:#f9fafb;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:1rem;line-height:1.5}h1,h2,h3,h4,h5,h6{color:#111827;font-weight:600;line-height:1.25}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{margin-bottom:1rem}p:last-child{margin-bottom:0}a{color:#4f46e5;text-decoration:none;transition:color .15s}a:hover{color:#4338ca}a:visited{color:#4f46e5}.btn{cursor:pointer;border:1px solid transparent;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;line-height:1.5;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.btn-primary{color:#fff;background-color:#4f46e5;border-color:#4f46e5}.btn.btn-primary:hover:not(:disabled){background-color:#4338ca;border-color:#4338ca}.btn.btn-secondary{color:#111827;background-color:#fff;border-color:#e5e7eb}.btn.btn-secondary:hover:not(:disabled){background-color:#f9fafb;border-color:#d1d5db}.btn.btn-danger{color:#fff;background-color:#ef4444;border-color:#ef4444}.btn.btn-danger:hover:not(:disabled){background-color:#dc2626;border-color:#dc2626}.btn.btn-ghost{color:#4b5563;background-color:transparent;border-color:transparent}.btn.btn-ghost:hover:not(:disabled){color:#111827;background-color:#f3f4f6}.btn.btn-sm{padding:.25rem .75rem;font-size:.75rem}.btn.btn-lg{padding:.75rem 1.5rem;font-size:1.125rem}.form-group{margin-bottom:1rem}.form-group label{color:#4b5563;margin-bottom:.25rem;font-size:.875rem;font-weight:500;display:block}textarea,select{color:#111827;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.5rem .75rem;font-size:1rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}input[type=text]{color:#111827;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.5rem .75rem;font-size:1rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}input[type=email]{color:#111827;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.5rem .75rem;font-size:1rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}input[type=password]{color:#111827;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.5rem .75rem;font-size:1rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}input[type=number]{color:#111827;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.5rem .75rem;font-size:1rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}input[type=url]{color:#111827;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.5rem .75rem;font-size:1rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}input[type=search]{color:#111827;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.5rem .75rem;font-size:1rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}textarea:focus,select:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}input[type=text]:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}input[type=email]:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}input[type=password]:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}input[type=number]:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}input[type=url]:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}input[type=search]:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #e0e7ff}input[type=text]::placeholder{color:#9ca3af}input[type=email]::placeholder{color:#9ca3af}input[type=password]::placeholder{color:#9ca3af}input[type=number]::placeholder{color:#9ca3af}input[type=url]::placeholder{color:#9ca3af}input[type=search]::placeholder{color:#9ca3af}textarea::placeholder{color:#9ca3af}select::placeholder{color:#9ca3af}textarea:disabled,select:disabled{cursor:not-allowed;background-color:#f3f4f6}input[type=text]:disabled{cursor:not-allowed;background-color:#f3f4f6}input[type=email]:disabled{cursor:not-allowed;background-color:#f3f4f6}input[type=password]:disabled{cursor:not-allowed;background-color:#f3f4f6}input[type=number]:disabled{cursor:not-allowed;background-color:#f3f4f6}input[type=url]:disabled{cursor:not-allowed;background-color:#f3f4f6}input[type=search]:disabled{cursor:not-allowed;background-color:#f3f4f6}textarea{resize:vertical;min-height:80px}select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}.card{background-color:#fff;border-radius:.75rem;transition:box-shadow .15s,transform .15s;box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.card:hover{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:#4b5563;text-transform:uppercase;letter-spacing:.05em;background-color:#f9fafb;border-bottom:2px solid #e5e7eb;padding:.75rem 1rem;font-size:.75rem;font-weight:600}td{border-bottom:1px solid #e5e7eb;padding:.75rem 1rem;font-size:.875rem}tr{transition:background-color .15s}tr:hover{background-color:#f9fafb}.badge{border-radius:9999px;align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.badge.badge-primary{color:#4338ca;background-color:#e0e7ff}.badge.badge-success{color:#16a34a;background-color:#f0fdf4}.badge.badge-warning{color:#d97706;background-color:#fffbeb}.badge.badge-error{color:#dc2626;background-color:#fef2f2}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 1rem}@media (width>=1024px){.container{padding:0 2rem}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:#4b5563}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}footer{text-align:center;color:#4b5563;background-color:#fff;border-top:1px solid #e5e7eb;padding:2rem 1rem;font-size:.875rem}@media (width>=1024px){footer{padding:3rem 1rem;font-size:1rem}}.loading{color:#4b5563;justify-content:center;align-items:center;padding:3rem;display:flex}.error{color:#dc2626;background-color:#fef2f2;border-radius:.5rem;padding:1rem;font-size:.875rem}.pagination{justify-content:center;align-items:center;gap:.5rem;padding:1rem 0;display:flex}.icon{flex-shrink:0;width:24px;height:24px}.action-icons{align-items:center;gap:.5rem;display:flex}.action-icons .icon{cursor:pointer;opacity:.6;transition:transform .15s,opacity .15s}.action-icons .icon:hover{opacity:1;transform:scale(1.1)}.action-icons .delete-icon:hover{color:#ef4444}.action-icons .edit-icon:hover{color:#4f46e5}