*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--navy-dark: #0d1b2a;--navy: #1b263b;--navy-light: #415a77;--navy-lighter: #778da9;--accent: #4cc9f0;--accent-light: #7dd8f5;--success: #06d6a0;--success-dark: #05b087;--error: #ef476f;--error-dark: #d63d5f;--warning: #ffd166;--white: #e0e1dd;--text: #e0e1dd;--text-muted: #a0a4a8}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:linear-gradient(135deg,var(--navy-dark) 0%,var(--navy) 100%);min-height:100dvh;color:var(--text);overflow-x:hidden}#app{min-height:100dvh}.screen{display:none;width:100%;min-height:100dvh;padding:1.5rem;padding-top:max(1.5rem,env(safe-area-inset-top));padding-bottom:max(1.5rem,env(safe-area-inset-bottom))}.screen.active{display:flex;flex-direction:column;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.container{width:100%;max-width:900px;margin:0 auto}.title{font-size:clamp(1.75rem,5vw,2.5rem);font-weight:700;text-align:center;margin-bottom:.5rem;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{font-size:1rem;text-align:center;color:var(--text-muted);margin-bottom:2rem}.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:2rem}.category-card{background:#415a774d;border:2px solid rgba(76,201,240,.2);border-radius:1rem;padding:1.25rem;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center;color:var(--text)}.category-card:hover{transform:translateY(-3px);border-color:var(--accent);background:#4cc9f01a;box-shadow:0 8px 25px #4cc9f033}.category-icon{font-size:2rem}.category-name{font-weight:600;font-size:1rem}.category-desc{font-size:.75rem;color:var(--text-muted)}.topic-list{display:flex;flex-direction:column;gap:.75rem}.topic-card{background:#415a774d;border:2px solid rgba(76,201,240,.2);border-radius:1rem;padding:1rem 1.5rem;cursor:pointer;transition:all .2s ease;display:flex;justify-content:space-between;align-items:center;color:var(--text)}.topic-card:hover{border-color:var(--accent);background:#4cc9f01a}.topic-info{display:flex;flex-direction:column;gap:.25rem}.topic-name{font-weight:600}.topic-questions{font-size:.8rem;color:var(--text-muted)}.topic-arrow{font-size:1.25rem;color:var(--accent)}.back-btn{background:transparent;border:none;color:var(--accent);font-size:1rem;cursor:pointer;padding:.5rem 0;margin-bottom:1rem;transition:color .2s}.back-btn:hover{color:var(--accent-light)}.exercise-container{width:100%;max-width:700px;margin:0 auto}.exercise-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.progress-container{flex:1;min-width:150px}.progress-bar{height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--success));border-radius:4px;transition:width .3s ease;width:0%}.progress-text{font-size:.8rem;color:var(--text-muted);margin-top:.25rem;display:block}.score-display{display:flex;align-items:center;gap:.5rem;background:#ffd16633;padding:.5rem 1rem;border-radius:2rem}.score-icon{font-size:1.25rem}.score-value{font-weight:700;font-size:1.1rem;color:var(--warning)}.exercise-type{display:none}.exercise-type.active{display:block;animation:fadeIn .3s ease}.question-card{background:#415a7766;border-radius:1rem;padding:1.5rem;margin-bottom:1.5rem;border:1px solid rgba(76,201,240,.2)}.question-text{font-size:1.2rem;line-height:1.6;text-align:center}.question-text .blank{display:inline-block;min-width:80px;border-bottom:2px dashed var(--accent);margin:0 .25rem}.options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media (max-width: 500px){.options-grid{grid-template-columns:1fr}}.option-btn{background:#415a774d;border:2px solid rgba(119,141,169,.3);border-radius:.75rem;padding:1rem;cursor:pointer;transition:all .2s ease;color:var(--text);font-size:1rem;text-align:center}.option-btn:hover:not(.disabled){border-color:var(--accent);background:#4cc9f01a}.option-btn.selected{border-color:var(--accent);background:#4cc9f033}.option-btn.correct{border-color:var(--success);background:#06d6a033}.option-btn.wrong{border-color:var(--error);background:#ef476f33}.option-btn.disabled{pointer-events:none;opacity:.8}.choice-buttons{display:flex;gap:1rem;justify-content:center;margin-bottom:1rem}.choice-btn{flex:1;max-width:150px;padding:1.25rem 2rem;font-size:1.5rem;font-weight:700;background:#415a774d;border:2px solid rgba(119,141,169,.3);border-radius:1rem;color:var(--text);cursor:pointer;transition:all .2s ease}.choice-btn:hover{border-color:var(--accent);background:#4cc9f01a}.choice-btn.correct{border-color:var(--success);background:#06d6a04d}.choice-btn.wrong{border-color:var(--error);background:#ef476f4d}.input-container{display:flex;gap:.75rem;margin-bottom:1rem}.answer-input{flex:1;padding:1rem;font-size:1.1rem;background:#415a774d;border:2px solid rgba(119,141,169,.3);border-radius:.75rem;color:var(--text);outline:none;transition:border-color .2s}.answer-input:focus{border-color:var(--accent)}.answer-input::placeholder{color:var(--text-muted)}.feedback-box{background:#415a7733;border-radius:.75rem;padding:1rem;margin-top:1rem;min-height:60px;opacity:0;transition:opacity .3s ease}.feedback-box.visible{opacity:1}.feedback-box.success{background:#06d6a026;border:1px solid var(--success)}.feedback-box.error{background:#ef476f26;border:1px solid var(--error)}.feedback-title{font-weight:700;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.feedback-title.success{color:var(--success)}.feedback-title.error{color:var(--error)}.feedback-text{font-size:.95rem;color:var(--text-muted);line-height:1.5}.word-pool{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1.5rem;min-height:50px;padding:1rem;background:#415a7733;border-radius:1rem;border:2px dashed rgba(119,141,169,.3)}.word-chip{background:var(--accent);color:var(--navy-dark);padding:.5rem 1rem;border-radius:2rem;font-weight:600;cursor:grab;transition:all .2s ease;-webkit-user-select:none;user-select:none}.word-chip:hover{transform:scale(1.05)}.word-chip.dragging{opacity:.5}.sort-categories{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1rem}.sort-box{background:#415a774d;border:2px dashed rgba(119,141,169,.4);border-radius:1rem;padding:1rem;min-height:120px;transition:all .2s ease}.sort-box.dragover{border-color:var(--accent);background:#4cc9f01a}.sort-box-title{font-weight:700;text-align:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid rgba(119,141,169,.3);color:var(--accent)}.sort-box-content{display:flex;flex-wrap:wrap;gap:.35rem;justify-content:center}.puzzle-bank{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1.5rem;min-height:50px;padding:1rem;background:#415a7733;border-radius:1rem}.puzzle-word{background:var(--navy-light);color:var(--text);padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.puzzle-word:hover{background:var(--accent);color:var(--navy-dark)}.puzzle-word.used{opacity:.3;pointer-events:none}.puzzle-solution{background:#415a774d;border:2px solid rgba(119,141,169,.3);border-radius:1rem;padding:1.5rem;min-height:80px;margin-bottom:1rem;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;align-items:center}.solution-word{background:var(--accent);color:var(--navy-dark);padding:.5rem 1rem;border-radius:.5rem;font-weight:600;cursor:pointer}.solution-word:hover{opacity:.8}.hint-text{color:var(--text-muted);font-style:italic;text-align:center}.puzzle-actions{display:flex;gap:.75rem;justify-content:center;margin-bottom:1rem}.matching-container{display:flex;gap:4rem;margin-bottom:1rem;position:relative}.matching-column{flex:1;display:flex;flex-direction:column;gap:.75rem;z-index:1}.match-item{background:#415a774d;border:2px solid rgba(119,141,169,.3);border-radius:.75rem;padding:1rem;cursor:pointer;transition:all .2s ease;text-align:center;font-size:.95rem}.match-item:hover{border-color:var(--accent)}.match-item.selected{border-color:var(--accent);background:#4cc9f033}.match-item.matched,.match-item.correct{pointer-events:none}.match-item.wrong{border-color:var(--error);background:#ef476f26;pointer-events:none}.matching-lines{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2}.matching-lines svg{width:100%;height:100%;overflow:visible}.comma-sentence{font-size:1.3rem;line-height:2;text-align:center}.comma-spot{display:inline-block;width:20px;height:20px;cursor:pointer;position:relative;vertical-align:middle}.comma-spot:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:#778da966;border-radius:50%;transition:all .2s ease}.comma-spot:hover:after{background:var(--accent);transform:translate(-50%,-50%) scale(1.3)}.comma-spot.marked:after{content:",";width:auto;height:auto;background:none;color:var(--accent);font-size:1.5rem;font-weight:700}.comma-spot.correct:after{color:var(--success)}.comma-spot.wrong:after{color:var(--error);text-decoration:line-through}.comma-spot.missed:after{content:",";width:auto;height:auto;background:none;color:var(--warning);font-size:1.5rem;font-weight:700}.memory-stats{display:flex;justify-content:center;gap:2rem;margin-bottom:1rem;color:var(--text-muted)}.memory-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;max-width:500px;margin:0 auto}@media (max-width: 400px){.memory-grid{grid-template-columns:repeat(3,1fr)}}.memory-card{aspect-ratio:1;background:var(--navy-light);border-radius:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;text-align:center;padding:.5rem;transition:all .3s ease;transform-style:preserve-3d;position:relative}.memory-card.flipped{background:var(--accent);color:var(--navy-dark)}.memory-card.matched{background:var(--success);color:#fff;pointer-events:none}.memory-card:not(.flipped):not(.matched):after{content:"?";font-size:1.5rem;color:var(--text-muted)}.memory-card:hover:not(.flipped):not(.matched){transform:scale(1.05);background:var(--navy-lighter)}.btn{padding:1rem 2rem;font-size:1.1rem;font-weight:600;border:none;border-radius:.75rem;cursor:pointer;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-light));color:var(--navy-dark)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 5px 20px #4cc9f066}.btn-secondary{background:#778da94d;color:var(--text);border:1px solid rgba(119,141,169,.5)}.btn-secondary:hover{background:#778da980}.btn-check{background:var(--accent);color:var(--navy-dark);padding:.75rem 1.5rem}.btn-check:hover{background:var(--accent-light)}.btn-next{width:100%;margin-top:1.5rem;background:linear-gradient(135deg,var(--success),var(--success-dark));color:#fff}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.results-card{background:#415a774d;border-radius:1.5rem;padding:2rem;text-align:center;border:1px solid rgba(76,201,240,.2)}.results-title{font-size:2rem;margin-bottom:1.5rem;background:linear-gradient(135deg,var(--warning),#ffa500);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.results-score{margin-bottom:2rem}.big-score{display:block;font-size:4rem;font-weight:700;color:var(--warning);line-height:1}.score-label{color:var(--text-muted);font-size:1.1rem}.results-stats{display:flex;justify-content:center;gap:2rem;margin-bottom:1.5rem}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-icon{font-size:1.5rem}.stat-value{font-size:1.5rem;font-weight:700}.stat-label{font-size:.85rem;color:var(--text-muted)}.results-message{font-size:1.1rem;color:var(--accent);margin-bottom:1.5rem;padding:1rem;background:#4cc9f01a;border-radius:.75rem}.error-list{text-align:left;margin-bottom:1.5rem;background:#ef476f1a;border-radius:.75rem;padding:1rem}.error-list h3{margin-bottom:.75rem;color:var(--error)}.error-item{padding:.75rem;margin-bottom:.5rem;background:#0003;border-radius:.5rem;font-size:.9rem}.error-item:last-child{margin-bottom:0}.error-question{color:var(--text-muted);margin-bottom:.25rem}.error-answer{color:var(--success)}.results-actions{display:flex;flex-direction:column;gap:.75rem}.footer{text-align:center;padding-top:2rem;margin-top:auto;color:var(--text-muted);font-size:.9rem}.footer-link{color:var(--accent);text-decoration:none;display:inline-block;margin-top:.5rem}.footer-link:hover{text-decoration:underline}#lang-toggle{position:fixed;top:1rem;right:1rem;display:flex;gap:.25rem;z-index:1000}.lang-btn{background:#415a7780;border:1px solid rgba(119,141,169,.3);color:var(--text);padding:.4rem .6rem;border-radius:.4rem;font-size:.8rem;cursor:pointer;transition:all .2s ease}.lang-btn:hover{background:#4cc9f033}.lang-btn.active{background:var(--accent);color:var(--navy-dark);border-color:var(--accent)}@media (max-width: 600px){.screen{padding:1rem}.category-grid{grid-template-columns:repeat(2,1fr)}.exercise-header{flex-direction:column;align-items:stretch}.results-stats{gap:1rem}.stat-value{font-size:1.25rem}}.admin-toggle{position:fixed;bottom:1rem;right:1rem;width:3rem;height:3rem;border-radius:50%;background:#4cc9f026;border:1px solid rgba(76,201,240,.3);color:var(--accent);font-size:1.2rem;cursor:pointer;z-index:999;opacity:.4;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.admin-toggle:hover{opacity:1;background:#4cc9f04d;transform:rotate(90deg)}.admin-login-card{background:var(--card-bg);border:1px solid var(--border);border-radius:1rem;padding:2rem;max-width:400px;margin:2rem auto;text-align:center}.admin-login-card p{color:var(--text-secondary);margin-bottom:1.5rem}.admin-container{max-width:900px}.admin-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.admin-header .title{margin:0;flex:1;text-align:center}.admin-categories{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-bottom:2rem}.admin-cat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:.75rem;padding:1.25rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.75rem}.admin-cat-card:hover{border-color:var(--accent);background:#4cc9f00d;transform:translateY(-2px)}.admin-cat-card .cat-icon{font-size:1.5rem}.admin-cat-card .cat-info{flex:1}.admin-cat-card .cat-name{font-weight:600;color:var(--text-primary);display:block}.admin-cat-card .cat-topics{font-size:.85rem;color:var(--text-secondary)}.admin-editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.admin-editor-header h2{color:var(--text-primary);margin:0}.admin-editor-actions{display:flex;gap:.5rem}.admin-back-editor{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.95rem;padding:.5rem .75rem;border-radius:.5rem;transition:background .2s}.admin-back-editor:hover{background:#4cc9f01a}.admin-topics-list{display:flex;flex-direction:column;gap:.75rem}.admin-topic-item{background:var(--card-bg);border:1px solid var(--border);border-radius:.75rem;padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.admin-topic-info{flex:1}.admin-topic-name{font-weight:600;color:var(--text-primary);display:block}.admin-topic-desc{font-size:.85rem;color:var(--text-secondary)}.admin-topic-count{font-size:.8rem;color:var(--accent);margin-top:.25rem}.admin-topic-actions{display:flex;gap:.5rem}.admin-topic-actions button{padding:.4rem .75rem;border-radius:.5rem;border:1px solid var(--border);background:var(--card-bg);color:var(--text-primary);cursor:pointer;font-size:.85rem;transition:all .2s}.admin-topic-actions button:hover{border-color:var(--accent);background:#4cc9f01a}.admin-topic-actions .btn-delete{color:#ff6b6b;border-color:#ff6b6b4d}.admin-topic-actions .btn-delete:hover{background:#ff6b6b1a;border-color:#ff6b6b}.admin-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.admin-modal-content{background:var(--navy-dark);border:1px solid var(--border);border-radius:1rem;width:100%;max-width:650px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.admin-modal-header h3{margin:0;color:var(--text-primary)}.admin-modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.admin-modal-close:hover{background:#ffffff1a;color:var(--text-primary)}.admin-modal-body{padding:1.5rem;overflow-y:auto;flex:1}.admin-modal-body label{display:block;color:var(--text-secondary);font-size:.85rem;font-weight:600;margin-bottom:.4rem;margin-top:1rem}.admin-modal-body label:first-child{margin-top:0}.admin-input{width:100%;padding:.65rem .85rem;border:1px solid var(--border);border-radius:.5rem;background:var(--card-bg);color:var(--text-primary);font-size:.95rem;font-family:inherit;box-sizing:border-box;transition:border-color .2s}.admin-input:focus{outline:none;border-color:var(--accent)}.admin-textarea{width:100%;padding:.75rem .85rem;border:1px solid var(--border);border-radius:.5rem;background:var(--card-bg);color:var(--text-primary);font-size:.85rem;font-family:Fira Code,Consolas,monospace;resize:vertical;min-height:200px;box-sizing:border-box;line-height:1.5;transition:border-color .2s}.admin-textarea:focus{outline:none;border-color:var(--accent)}.admin-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border)}@media (max-width: 600px){.admin-header{flex-direction:column;text-align:center}.admin-categories{grid-template-columns:1fr}.admin-modal-content{max-height:95vh}.admin-topic-item{flex-direction:column;align-items:stretch}.admin-topic-actions{justify-content:flex-end}}
