*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #1a7f4b;--green-dark: #145f39;--green-light: #e8f5ee;--red: #d94f3d;--text: #1a1a1a;--text-muted: #666;--bg: #f8f9fa;--surface: #ffffff;--border: #e0e0e0;--shadow: 0 2px 8px rgba(0,0,0,.1);--radius: 12px;--radius-sm: 8px}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100dvh;max-width:600px;margin:0 auto;overflow:hidden}.app-header{background:var(--green);color:#fff;padding:12px 20px 0;padding-top:max(12px,env(safe-area-inset-top,12px));display:flex;flex-direction:column;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0003}.app-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.app-header h1{font-size:20px;font-weight:700}.lang-switcher-btn{background:none;border:none;font-size:16px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;color:inherit;padding:2px 6px;border-radius:var(--radius-sm);line-height:1;flex-shrink:0}.lang-switcher-btn:hover{background:#00000014}.app-header nav{display:flex;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:10px}.app-header nav::-webkit-scrollbar{display:none}.app-header nav button{background:#ffffff26;border:none;color:#fff;padding:5px 12px;border-radius:20px;font-size:13px;cursor:pointer;transition:background .2s;white-space:nowrap;flex-shrink:0}.app-header nav button:hover{background:#ffffff40}.app-header nav button.active{background:#fff;color:var(--green);font-weight:600}.app-header nav.nav-icons button{padding:5px 8px;min-width:36px;text-align:center}.nav-icon{font-size:16px}.nav-toggle-btn{margin-left:auto;opacity:.7;font-size:15px;padding:5px 8px!important;flex-shrink:0}.spinner-small{display:inline-block;width:16px;height:16px;border:2px solid #ccc;border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite}.header-user{font-size:13px;opacity:.85;align-self:center}.header-user-btn{background:none;border:none;cursor:pointer;color:inherit;padding:2px 6px;border-radius:var(--radius-sm);transition:background .15s}.header-user-btn:hover{background:#ffffff26;opacity:1}.app-main{flex:1;min-height:0;overflow-y:auto;padding:20px;padding-bottom:max(20px,env(safe-area-inset-bottom,20px))}.build-version{text-align:center;font-size:12px;color:var(--text-muted);opacity:.7;padding:4px 0 max(8px,env(safe-area-inset-bottom,8px))}.view-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.view-header h2{font-size:22px;font-weight:700;flex:1}.btn-back{background:none;border:none;font-size:16px;color:var(--green);cursor:pointer;padding:4px 0;font-weight:600}.btn-primary{background:var(--green);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-sm);font-size:15px;font-weight:600;cursor:pointer;transition:background .2s}.btn-primary:hover{background:var(--green-dark)}.btn-primary.large{width:100%;padding:16px;font-size:17px;border-radius:var(--radius);margin-top:8px}.btn-primary.saved{background:#555}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--green);border:1.5px solid var(--green);padding:8px 14px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:#0000000d}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.header-actions{display:flex;gap:8px;align-items:center}.setting-toggle-label{display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-weight:600;font-size:16px}.toggle-switch{width:48px;height:28px;background:#ccc;border-radius:14px;position:relative;flex-shrink:0;transition:background .2s;cursor:pointer}.toggle-switch.on{background:var(--green)}.toggle-knob{position:absolute;top:3px;left:3px;width:22px;height:22px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle-switch.on .toggle-knob{transform:translate(20px)}.owner-filter{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.owner-tab{background:transparent;color:var(--text-secondary, #666);border:1.5px solid #ccc;padding:6px 14px;border-radius:20px;font-size:14px;cursor:pointer;transition:all .15s}.owner-tab.active{background:var(--green);color:#fff;border-color:var(--green)}.subscribed-section{margin-top:28px}.subscribed-header{font-size:15px;font-weight:600;color:var(--text-secondary, #666);margin:0 0 10px;padding-bottom:6px;border-bottom:1px solid #e5e5e5}.loading{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:18px}.progress-bar{height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--green);border-radius:3px;transition:width .3s ease}.home-view .view-header{justify-content:space-between}.home-view .view-header h2{flex:none}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state p{margin-bottom:8px;font-size:17px}.empty-state .btn-primary.large{margin-top:24px;max-width:300px;margin-left:auto;margin-right:auto}.text-list{list-style:none;display:flex;flex-direction:column;gap:12px}.text-item{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 12px 16px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:transform .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent}.text-item:active{transform:scale(.98);box-shadow:0 1px 4px #0000001a}.text-item-content{flex:1;display:flex;flex-direction:column;gap:4px}.text-title{font-size:17px;font-weight:600}.text-meta{font-size:13px;color:var(--text-muted)}.progress-done{color:var(--green);font-weight:600}.tag-group{margin-top:8px}.tag-group-header{display:flex;align-items:center;gap:6px;width:100%;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--green-dark);padding:8px 12px;background:var(--green-light);border:none;border-radius:var(--radius-sm);cursor:pointer;text-align:left}.tag-group-header:active{opacity:.75}.tag-group-chevron{font-size:11px;flex-shrink:0}.tag-group-count{font-weight:400;color:var(--text-muted);margin-left:2px}.tag-group .text-list{border-radius:0 0 var(--radius-sm) var(--radius-sm);overflow:hidden}.text-item .progress-bar{margin-top:4px}.text-checkbox{width:20px;height:20px;flex-shrink:0;accent-color:var(--green);cursor:pointer}.text-item.selected{background:var(--green-light);border:1.5px solid var(--green)}.avail-icon{flex-shrink:0;font-size:15px;font-weight:700;width:24px;text-align:center}.avail-full{color:var(--green)}.avail-partial{color:#e07b00}.avail-none{color:var(--text-muted)}.avail-download-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center}.download-bar{position:sticky;bottom:20px;background:var(--surface);border-radius:var(--radius);box-shadow:0 4px 20px #00000026;padding:16px;margin-top:16px;display:flex;flex-direction:column;gap:10px;align-items:stretch}.btn-download{background:var(--green);color:#fff;border:none;padding:14px 20px;border-radius:var(--radius-sm);font-size:16px;font-weight:700;cursor:pointer;width:100%;transition:background .2s}.btn-download:hover{background:var(--green-dark)}.download-label{font-size:14px;color:var(--text-muted);text-align:center}.download-bar-progress{height:8px}.playlist-item-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.btn-playlist-download{background:none;border:none;font-size:15px;font-weight:700;color:var(--text-muted);cursor:pointer;padding:4px 6px;line-height:1;border-radius:50%;opacity:.5;transition:opacity .2s,background .2s;min-width:28px}.btn-playlist-download:hover:not(:disabled){opacity:1;background:#f0f0f0}.btn-playlist-download:disabled{cursor:default;font-size:12px;opacity:1;color:var(--green)}.btn-hide-playlist{background:none;border:none;font-size:18px;color:var(--text-muted);cursor:pointer;padding:4px 6px;line-height:1;border-radius:50%;opacity:.4;transition:opacity .2s,background .2s}.btn-hide-playlist:hover{opacity:1;background:#f0f0f0}.tooltip-wrap{position:relative;display:inline-flex;align-items:center;cursor:default}.tooltip-text{visibility:hidden;opacity:0;pointer-events:none;position:absolute;bottom:calc(100% + 6px);right:0;background:#333;color:#fff;font-size:12px;padding:6px 10px;border-radius:var(--radius-sm);white-space:nowrap;max-width:240px;white-space:normal;width:max-content;max-width:220px;z-index:100;transition:opacity .15s}.tooltip-wrap:hover .tooltip-text,.tooltip-wrap:focus-within .tooltip-text,.tooltip-wrap.tooltip-visible .tooltip-text{visibility:visible;opacity:1}.btn-delete{background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;padding:4px 8px;line-height:1;border-radius:50%;transition:color .2s,background .2s}.btn-delete:hover{color:var(--red);background:#fee}.list-controls{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.list-controls-row{display:flex;gap:8px}.filter-input{width:100%;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;font-size:15px;font-family:inherit;color:var(--text);background:var(--surface);transition:border-color .2s}.filter-input:focus{outline:none;border-color:var(--green)}.sort-select{flex:1;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 8px;font-size:14px;font-family:inherit;color:var(--text);background:var(--surface);cursor:pointer}.sort-select:focus{outline:none;border-color:var(--green)}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px}.page-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);width:36px;height:36px;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.page-btn:hover:not(:disabled){border-color:var(--green);color:var(--green)}.page-btn:disabled{opacity:.3;cursor:not-allowed}.page-info{font-size:14px;color:var(--text-muted)}.add-form{display:flex;flex-direction:column;gap:20px}.usage-quota{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;display:flex;flex-direction:column;gap:6px}.usage-quota-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text-muted)}.usage-quota-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.usage-quota-fill{height:100%;border-radius:3px;transition:width .3s}.usage-quota-hint{font-size:12px;color:var(--text-muted);margin:0}.usage-quota-exhausted{color:var(--red);font-weight:600}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;font-size:15px}.form-group input,.form-group textarea{border:2px solid var(--border);border-radius:var(--radius-sm);padding:12px;font-size:16px;font-family:inherit;color:var(--text);background:var(--surface);transition:border-color .2s;width:100%}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--green)}.form-group textarea{resize:vertical;min-height:120px}.language-toggle{display:flex;gap:8px}.btn-lang-small{padding:3px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:13px;cursor:pointer;transition:all .15s}.btn-lang-small.active{border-color:var(--green);background:var(--green-light);color:var(--green-dark);font-weight:600}.language-toggle button{flex:1;padding:10px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:15px;cursor:pointer;transition:all .2s}.language-toggle button.active{border-color:var(--green);background:var(--green-light);color:var(--green-dark);font-weight:600}.error-message{background:#fee;border:1px solid var(--red);color:var(--red);padding:12px;border-radius:var(--radius-sm);font-size:14px}.status-overlay{text-align:center;padding:60px 20px}.status-overlay p{font-size:18px;font-weight:600;margin-top:16px}.status-overlay .status-sub{font-size:14px;color:var(--text-muted);font-weight:400;margin-top:4px}.status-overlay .progress-bar.large{height:10px;margin-top:16px;max-width:300px;margin-left:auto;margin-right:auto}.status-pct{font-size:28px;font-weight:700;color:var(--green);margin-top:8px}.phase-stepper{list-style:none;padding:0;margin:16px auto 0;max-width:320px;text-align:left}.phase-step{display:flex;align-items:center;gap:10px;padding:8px 4px;font-size:15px;font-weight:400}.phase-step-icon{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-weight:700;flex-shrink:0}.phase-step--pending{color:var(--text-muted)}.phase-step--pending .phase-step-icon{color:var(--text-muted);border:1px solid var(--text-muted);font-size:12px}.phase-step--active{color:var(--green-dark);font-weight:600}.phase-step--done{color:var(--green-dark)}.phase-step--done .phase-step-icon{background:var(--green);color:#fff;font-size:14px}.phase-step-progress{font-weight:400;color:var(--text-muted);font-size:13px}.spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.success-state{text-align:center;padding:60px 20px}.success-icon{width:72px;height:72px;background:var(--green);color:#fff;border-radius:50%;font-size:36px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.success-state h2{font-size:28px;margin-bottom:12px}.success-state p{color:var(--text-muted);font-size:16px;max-width:280px;margin:0 auto 24px}.player-view{display:flex;flex-direction:column;gap:24px}.player-progress{display:flex;align-items:center;gap:12px}.player-progress .progress-bar{flex:1}.progress-label{font-size:14px;color:var(--text-muted);white-space:nowrap}.progress-jump{display:flex;align-items:center;gap:4px;flex-shrink:0}.progress-jump-input{width:52px;border:1.5px solid var(--green);border-radius:var(--radius-sm);padding:2px 6px;font-size:14px;font-family:inherit;color:var(--text);background:var(--surface);text-align:center}.progress-jump-input:focus{outline:none}.sentence-display{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;display:flex;flex-direction:column;gap:20px;min-height:180px}.sentence-italian,.sentence-dutch{display:flex;flex-direction:column;gap:8px}.lang-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.sentence-italian p{font-size:22px;font-style:italic;font-weight:500;line-height:1.4;color:var(--green-dark)}.sentence-dutch p{font-size:18px;line-height:1.4;color:var(--text)}.player-controls{display:flex;align-items:center;justify-content:center;gap:24px}.btn-control{background:var(--surface);border:2px solid var(--border);border-radius:50%;width:56px;height:56px;font-size:22px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-control:hover:not(:disabled){border-color:var(--green);color:var(--green)}.btn-control:disabled{opacity:.3;cursor:not-allowed}.btn-play{background:var(--green);border:none;border-radius:50%;width:80px;height:80px;font-size:30px;color:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #1a7f4b66}.btn-play:hover{background:var(--green-dark);transform:scale(1.05)}.btn-play:active{transform:scale(.97)}.play-pattern{background:var(--green-light);border-radius:var(--radius);padding:16px}.play-pattern p{font-size:13px;font-weight:600;color:var(--green-dark);margin-bottom:8px;text-transform:uppercase;letter-spacing:.04em}.play-pattern ol{padding-left:20px;display:flex;flex-direction:column;gap:4px}.play-pattern li{font-size:14px;color:var(--green-dark)}.login-screen,.wait-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.login-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:40px 32px;width:100%;max-width:360px;text-align:center}.login-icon{font-size:48px;margin-bottom:16px}.login-card h1{font-size:22px;font-weight:700;margin-bottom:28px;color:var(--text)}.login-form{display:flex;flex-direction:column;gap:14px}.login-form input[type=password]{border:2px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;font-size:18px;text-align:center;letter-spacing:.1em;width:100%;background:var(--surface);color:var(--text);transition:border-color .2s}.login-form input[type=password]:focus{outline:none;border-color:var(--green)}.login-error{font-size:14px;color:var(--red);background:#fee;border-radius:var(--radius-sm);padding:10px}.login-redirect-btn{margin-top:16px;background:none;border:none;color:var(--text-muted);font-size:13px;text-decoration:underline;cursor:pointer;padding:4px}.settings-view{display:flex;flex-direction:column;gap:24px}.settings-section{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.settings-section h3{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:12px}.setting-item{display:flex;flex-direction:column;gap:6px}.setting-item label{font-size:16px;font-weight:600}.setting-description{font-size:13px;color:var(--text-muted)}.setting-control{display:flex;align-items:center;gap:16px;margin-top:8px}.setting-control input[type=range]{flex:1;accent-color:var(--green);height:6px}.setting-value{font-size:18px;font-weight:700;color:var(--green);min-width:40px;text-align:right}.settings-section.info p{font-size:14px;color:var(--text-muted);line-height:1.6}.list-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.btn-select-all{background:none;border:none;color:var(--green);font-size:14px;font-weight:600;cursor:pointer;padding:4px 0}.list-count{font-size:13px;color:var(--text-muted)}.download-bar-actions{display:flex;gap:10px}.btn-delete-selected{flex:1;background:transparent;color:var(--red);border:1.5px solid var(--red);padding:14px 16px;border-radius:var(--radius-sm);font-size:15px;font-weight:700;cursor:pointer;transition:background .2s}.btn-delete-selected:hover{background:#fee}.btn-download{flex:1}.stats-view{display:flex;flex-direction:column;gap:20px}.stats-totals{display:flex;gap:12px}.stat-card{flex:1;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:4px}.stat-value{font-size:32px;font-weight:700;color:var(--green)}.stat-label{font-size:13px;color:var(--text-muted);text-align:center}.period-tabs{display:flex;gap:8px}.stats-chart{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 8px 8px}.stats-empty{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:16px}.practice-view{display:flex;flex-direction:column;gap:20px}.practice-direction-row{display:flex;align-items:center;gap:10px;background:var(--surface);border-radius:var(--radius);padding:12px 16px;box-shadow:var(--shadow)}.practice-lang{font-size:14px;font-weight:600;color:var(--green)}.practice-arrow{font-size:16px;color:var(--text-muted)}.btn-direction{margin-left:auto;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 12px;font-size:14px;cursor:pointer;color:var(--text)}.btn-direction:hover{background:var(--bg)}.practice-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:40px 24px 32px;display:flex;flex-direction:column;align-items:center;gap:20px;min-height:160px}.practice-prompt{font-size:32px;font-weight:700;text-align:center;color:var(--text);line-height:1.2}.practice-reveal{font-size:22px;font-weight:500;text-align:center;color:var(--text-muted);margin-top:8px;animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.btn-replay{background:none;border:none;font-size:28px;cursor:pointer;opacity:.7;padding:4px}.btn-replay:hover{opacity:1}.practice-controls{display:flex;flex-direction:column;align-items:center;gap:12px;min-height:120px}.btn-listen{background:var(--green);color:#fff;border:none;border-radius:50px;padding:18px 40px;font-size:18px;font-weight:600;cursor:pointer;transition:background .2s,transform .1s;width:100%;max-width:320px}.btn-listen:hover{background:var(--green-dark)}.btn-listen:active{transform:scale(.97)}.btn-listen.listening{background:var(--red);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.practice-feedback{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 24px;width:100%;text-align:center;display:flex;flex-direction:column;gap:8px}.practice-feedback.correct{border-left:4px solid var(--green)}.practice-feedback.wrong{border-left:4px solid var(--red)}.practice-feedback-label{font-size:20px;font-weight:700}.practice-feedback.correct .practice-feedback-label{color:var(--green)}.practice-feedback.wrong .practice-feedback-label{color:var(--red)}.practice-transcript{font-size:14px;color:var(--text-muted)}.practice-answer{font-size:16px;font-weight:600;color:var(--text)}.practice-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 0}.btn-skip{background:none;border:none;color:var(--text-muted);font-size:15px;cursor:pointer;padding:8px 0}.btn-skip:hover{color:var(--text)}.practice-pool{font-size:13px;color:var(--text-muted)}.practice-no-speech{background:#fff3cd;border:1px solid #ffc107;border-radius:var(--radius);padding:16px;font-size:14px;color:#856404;text-align:center}.practice-empty{text-align:center;padding:60px 20px;color:var(--text-muted);display:flex;flex-direction:column;gap:8px;font-size:16px}.admin-view{display:flex;flex-direction:column;gap:16px}.btn-refresh{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px;font-size:16px;cursor:pointer;margin-left:auto}.admin-date{font-size:13px;color:var(--text-muted);margin-bottom:8px}.admin-error{background:#fee;border:1px solid var(--red);border-radius:var(--radius-sm);padding:12px 16px;color:var(--red);font-size:14px}.admin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{width:100%;border-collapse:collapse;font-size:14px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.admin-table th{background:var(--green-light);color:var(--green-dark);font-weight:600;padding:10px 12px;text-align:left;white-space:nowrap;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.admin-table td{padding:10px 12px;border-top:1px solid var(--border);vertical-align:middle}.admin-table tr:hover td{background:var(--bg)}.admin-email{font-weight:500;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-date-cell{color:var(--text-muted);white-space:nowrap}.admin-limit-btn{background:var(--green-light);border:1px solid var(--green);border-radius:var(--radius-sm);padding:4px 10px;font-size:14px;font-weight:600;color:var(--green-dark);cursor:pointer;min-width:60px}.admin-limit-btn:hover{background:var(--green);color:#fff}.admin-group-cell{white-space:nowrap}.admin-group-select{font-size:13px;padding:3px 6px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer}.admin-group-select:disabled{opacity:.5;cursor:default}.upload-request-badge{display:inline-block;margin-left:4px;background:#f59e0b;color:#fff;border-radius:50%;width:16px;height:16px;font-size:11px;font-weight:700;line-height:16px;text-align:center;cursor:default}.admin-limit-edit{display:flex;gap:4px;align-items:center}.admin-limit-input{width:80px;border:1px solid var(--green);border-radius:var(--radius-sm);padding:4px 8px;font-size:14px;font-weight:600}.btn-save-limit{background:var(--green);color:#fff;border:none;border-radius:var(--radius-sm);padding:4px 8px;cursor:pointer;font-size:14px}.btn-cancel-limit{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 8px;cursor:pointer;font-size:14px;color:var(--text-muted)}.admin-usage{display:flex;align-items:center;gap:6px}.admin-usage-bar{flex:1;height:6px;background:var(--border);border-radius:3px;min-width:40px;overflow:hidden}.admin-usage-fill{height:100%;border-radius:3px;transition:width .3s}.admin-usage-pct{font-size:12px;color:var(--text-muted);min-width:30px;text-align:right}.admin-stats-section{display:flex;flex-direction:column;gap:12px}.admin-table-section{display:flex;flex-direction:column;gap:8px;margin-top:8px}.admin-section-title{font-size:15px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.btn-admin-refresh{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:12px;cursor:pointer;white-space:nowrap}.btn-admin-refresh:hover:not(:disabled){background:var(--green-light);border-color:var(--green);color:var(--green-dark)}.btn-admin-refresh:disabled{opacity:.5;cursor:not-allowed}.admin-user-selector{display:flex;flex-wrap:wrap;gap:6px}.admin-user-btn{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:5px 14px;font-size:13px;cursor:pointer;color:var(--text);transition:all .15s}.admin-user-btn:hover{border-color:var(--green);color:var(--green)}.admin-user-btn.active{background:var(--green);border-color:var(--green);color:#fff;font-weight:600}.admin-chart-subtitle{font-size:13px;color:var(--text-muted);margin-top:-4px}.admin-row-selected td{background:var(--green-light)!important}.admin-row-pending td{background:#fff8e1}.btn-admin-delete{background:none;border:none;cursor:pointer;font-size:14px;padding:4px 8px;border-radius:4px;opacity:.6;transition:opacity .15s}.btn-admin-delete:hover:not(:disabled){opacity:1;background:#fee2e2}.btn-admin-delete:disabled{opacity:.4;cursor:not-allowed}.app-gate{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.gate-card{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:48px 32px;max-width:400px;width:90%}.gate-icon{font-size:48px;margin-bottom:16px}.gate-card h2{margin:0 0 12px;color:var(--text)}.gate-card p{color:var(--text-muted);line-height:1.6;margin:0 0 8px}.gate-sub{font-size:13px;margin-bottom:24px!important}.btn-logout{margin-top:16px;padding:10px 24px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:14px;cursor:pointer;color:var(--text-muted)}.btn-logout:hover{border-color:var(--red, #ef4444);color:var(--red, #ef4444)}.admin-env-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px;background:var(--bg);border-radius:8px;border:1px solid var(--border)}.admin-env-desc{font-size:13px;color:var(--text-muted);margin:4px 0 0;line-height:1.5}.btn-admin-copy{flex-shrink:0;padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:13px;cursor:pointer;white-space:nowrap}.btn-admin-copy:hover:not(:disabled){background:#fef3c7;border-color:#f59e0b}.btn-admin-copy:disabled{opacity:.5;cursor:not-allowed}.btn-generate-link{margin-left:auto;padding:6px 12px;background:var(--green-light);border:1px solid var(--green);color:var(--green-dark);border-radius:8px;font-size:13px;cursor:pointer;font-weight:600}.btn-generate-link:hover{background:var(--green);color:#fff}.generate-numbers{display:grid;grid-template-columns:1fr 1fr;gap:16px}.number-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:16px;background:var(--surface);color:var(--text)}.generate-hint{font-size:13px;color:var(--text-muted);margin:-8px 0 0}.review-toggle{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text);cursor:pointer;padding:12px 0 4px}.review-toggle input[type=checkbox]{width:18px;height:18px;flex-shrink:0;cursor:pointer;accent-color:var(--green)}.generate-history{margin-top:20px;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.generate-history summary{padding:10px 14px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--surface)}.generate-history-list{list-style:none;margin:0;padding:0}.generate-history-item{display:flex;flex-direction:column;gap:2px;padding:10px 14px;border-top:1px solid var(--border);cursor:pointer;transition:background .1s}.generate-history-item:hover{background:var(--green-light)}.generate-history-date{font-size:11px;color:var(--text-muted)}.generate-history-desc{font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.generate-history-meta{font-size:11px;color:var(--text-muted)}.review-intro{font-size:14px;color:var(--text-muted);padding:0 0 16px}.review-blocks{display:flex;flex-direction:column;gap:24px;margin-bottom:20px}.review-block{border:1px solid var(--border);border-radius:var(--radius);padding:16px;background:var(--surface)}.info-view{display:flex;flex-direction:column;gap:0}.info-markdown{padding:16px;line-height:1.7;color:var(--text);font-size:14px;overflow-x:auto}.info-markdown h1{font-size:22px;font-weight:700;margin:0 0 16px;color:var(--green-dark)}.info-markdown h2{font-size:18px;font-weight:600;margin:24px 0 8px;border-bottom:1px solid var(--border);padding-bottom:4px}.info-markdown h3{font-size:15px;font-weight:600;margin:16px 0 4px}.info-markdown pre{background:#1e1e1e;color:#d4d4d4;border-radius:8px;padding:12px;font-size:11px;overflow-x:auto;margin:12px 0;line-height:1.5;font-family:SF Mono,Fira Code,monospace}.info-markdown code{background:var(--bg);border-radius:4px;padding:2px 6px;font-size:12px;font-family:SF Mono,monospace}.info-markdown pre code{background:none;padding:0;font-size:inherit}.info-markdown table{border-collapse:collapse;width:100%;margin:12px 0}.info-markdown th,.info-markdown td{border:1px solid var(--border);padding:8px 12px;font-size:13px}.info-markdown th{background:var(--green-light);color:var(--green-dark)}.info-markdown ul,.info-markdown ol{padding-left:20px}.info-markdown li{margin:4px 0}.info-markdown p{margin:8px 0}.info-markdown strong{font-weight:600}.playlists-view,.playlist-detail-view{display:flex;flex-direction:column;gap:0}.playlist-create-row{display:flex;flex-direction:column;gap:10px;margin-top:16px}.playlist-create-actions{display:flex;gap:8px}.playlist-name-edit{display:flex;gap:8px;align-items:center;flex:1}.playlist-name-edit .filter-input{flex:1}.playlist-item{cursor:default;touch-action:pan-y}.drag-handle{flex-shrink:0;font-size:18px;color:var(--text-muted);cursor:grab;padding:4px 8px 4px 0;touch-action:none;-webkit-user-select:none;user-select:none}.drag-handle:active{cursor:grabbing}.playlist-player-bar{background:var(--green);color:#fff;padding:8px 16px;display:flex;align-items:center;gap:10px;font-size:13px;border-radius:var(--radius) var(--radius) 0 0;margin:-20px -20px 0}.playlist-player-name{font-weight:700;flex-shrink:0}.playlist-player-progress{background:#ffffff40;border-radius:12px;padding:2px 8px;font-weight:600;flex-shrink:0}.playlist-player-title{opacity:.9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:0}.confirm-dialog{background:var(--surface);border-radius:var(--radius);padding:24px 20px;margin:20px;width:100%;max-width:360px;box-shadow:0 8px 32px #0003}.confirm-message{margin:0 0 20px;font-size:15px;line-height:1.4}.confirm-actions{display:flex;gap:10px;justify-content:flex-end}.confirm-btn{min-width:100px}.modal-card{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;padding:24px 20px max(24px,env(safe-area-inset-bottom,24px));width:100%;max-width:600px;max-height:80dvh;overflow-y:auto;display:flex;flex-direction:column;gap:0}.modal-card h3{font-size:18px;font-weight:700;margin-bottom:16px}.playlist-modal-list{list-style:none;display:flex;flex-direction:column;gap:4px;max-height:40dvh;overflow-y:auto}.playlist-modal-item{display:flex;align-items:center;gap:12px;padding:12px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}.playlist-modal-item:hover{background:var(--bg)}.text-title-row{display:flex;align-items:center;gap:4px}.text-title-edit{display:flex;flex-direction:column}.btn-rename{background:none;border:none;font-size:12px;color:var(--text-muted);cursor:pointer;padding:2px 3px;flex-shrink:0;opacity:.5;line-height:1}.btn-rename:hover{opacity:1;color:var(--green)}.btn-privacy{background:none;border:none;font-size:12px;cursor:pointer;padding:2px 3px;flex-shrink:0;opacity:.6;line-height:1}.btn-privacy:hover{opacity:1}.star-rating{display:inline-flex;align-items:center;gap:1px;flex-shrink:0}.star-btn{background:none;border:none;cursor:pointer;font-size:14px;padding:0;line-height:1;color:#ccc;transition:color .1s}.star-btn.filled{color:#f5a623}.star-rating:not(.star-rating--readonly) .star-btn:hover,.star-rating:not(.star-rating--readonly) .star-btn:hover~.star-btn{color:#f5a623}.star-rating--readonly .star-btn{cursor:default}.star-picker{display:flex;align-items:center;gap:4px}.star-picker-btn{background:none;border:none;cursor:pointer;font-size:24px;padding:0 2px;line-height:1;color:#ccc;transition:color .1s}.star-picker-btn.filled,.star-picker-btn:hover{color:#f5a623}.star-picker-label{font-size:13px;color:var(--text-muted, #666);margin-left:4px}.lang-pair-selector{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--green-light);border-radius:var(--radius-sm);margin:8px 0;flex-wrap:wrap}.lang-pair-label{font-size:12px;font-weight:600;color:var(--green-dark);text-transform:uppercase;letter-spacing:.04em}.lang-pair-lang{font-size:14px}.lang-pair-arrow{color:var(--green-dark);font-size:14px}.lang-checklist-wrap{position:relative}.lang-checklist-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 8px;font-size:13px;cursor:pointer;min-width:80px;text-align:left}.lang-checklist-btn:focus{outline:2px solid var(--green)}.lang-checklist-panel{position:absolute;top:calc(100% + 4px);left:0;z-index:100;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);list-style:none;padding:4px 0;min-width:140px}.lang-checklist-item{padding:6px 12px}.lang-checklist-item label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:14px;white-space:nowrap}.lang-checklist-item:first-child{border-bottom:1px solid var(--border);margin-bottom:2px;padding-bottom:8px}.pair-badge{font-size:13px;margin-right:3px}.pair-badge-0{color:var(--green)}.pair-badge-1{color:#e8a020}.pair-badge-2{opacity:.5}.lang-filter{display:flex;gap:2px}.lang-filter-btn{background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:14px;padding:2px 6px;opacity:.5}.lang-filter-btn.active{opacity:1;border-color:var(--green);background:var(--green-light)}.lang-filter-btn:hover{opacity:1}.difficulty-filter{display:flex;gap:2px}.difficulty-filter-btn{background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:12px;padding:3px 8px;color:var(--text-muted, #666)}.difficulty-filter-btn.active{background:#fff8ee;border-color:#f5a623;color:#f5a623}.difficulty-filter-btn:hover{border-color:#f5a623;color:#f5a623}.privacy-icon{font-size:11px;margin-right:2px;flex-shrink:0}.btn-playlist{background:none;border:none;font-size:16px;cursor:pointer;padding:4px 6px;border-radius:var(--radius-sm);flex-shrink:0;opacity:.6;transition:opacity .2s}.btn-playlist:hover{opacity:1}.tab-bar{display:flex;gap:4px;padding:8px 0 0;border-bottom:2px solid var(--border);margin-bottom:16px;overflow-x:auto;scrollbar-width:none}.tab-bar::-webkit-scrollbar{display:none}.tab-btn{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;padding:8px 14px;font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--green);border-bottom-color:var(--green);background:var(--green-light);font-weight:600}.invite-add-row{display:flex;gap:8px;margin-bottom:8px}.invite-list{list-style:none;margin-top:8px;display:flex;flex-direction:column;gap:4px}.invite-item{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px;font-size:14px}.tag-filter-wrap{position:relative;flex:1;min-width:120px}.tag-filter-selected{display:flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--green);border-radius:var(--radius-sm);padding:6px 10px;font-size:14px;color:var(--text)}.tag-filter-selected span{flex:1}.tag-clear{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:16px;padding:0;line-height:1}.tag-dropdown-list{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);list-style:none;margin:0;padding:0;max-height:200px;overflow-y:auto;z-index:200;box-shadow:0 4px 12px #00000026}.tag-dropdown-item{padding:8px 12px;cursor:pointer;font-size:14px}.tag-dropdown-item:hover{background:var(--green-light)}.lang-regen-wrap{position:relative;flex-shrink:0}.btn-lang-regen{background:none;border:none;padding:4px 6px;cursor:pointer;font-size:16px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;min-width:28px;min-height:28px;line-height:1}.btn-lang-regen:hover{background:var(--green-light)}.btn-lang-regen:disabled{cursor:default}.lang-regen-dropdown{position:absolute;right:0;top:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);list-style:none;margin:4px 0 0;padding:4px 0;min-width:150px;z-index:200;box-shadow:0 4px 12px #00000026}.lang-regen-option{padding:8px 12px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:8px}.lang-regen-option:hover{background:var(--green-light)}.text-tags{display:flex;flex-wrap:wrap;align-items:center;gap:4px;margin-top:4px}.tag-chip{display:inline-flex;align-items:center;gap:3px;background:var(--green-light);color:var(--green-dark);border-radius:10px;padding:2px 8px;font-size:12px;line-height:1.4}.tag-chip-remove{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:12px;padding:0;line-height:1;margin-left:2px}.tag-chip-remove:hover{color:var(--red)}.tag-edit-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:12px;padding:2px 6px;border-radius:10px}.tag-edit-btn:hover{background:var(--green-light);color:var(--green-dark)}.tag-add-wrap{display:flex;align-items:center;gap:4px}.tag-add-input{padding:3px 8px;font-size:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);width:110px}.tag-add-btn{padding:3px 8px!important;font-size:12px!important}.btn-activity-trail{background:none;border:none;font-size:13px;cursor:pointer;padding:2px 5px;border-radius:4px;color:var(--text-muted);opacity:.6;line-height:1}.btn-activity-trail:hover{opacity:1;color:var(--green)}.btn-activity-trail.active{opacity:1;color:var(--green);background:var(--green-light)}.activity-trail-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;margin-top:4px}.activity-trail-panel h3{font-size:14px;font-weight:600;margin:0 0 12px;display:flex;align-items:center;justify-content:space-between;color:var(--text)}.btn-close-trail{background:none;border:none;font-size:18px;cursor:pointer;color:var(--text-muted);line-height:1;padding:0 2px}.btn-close-trail:hover{color:var(--text)}.activity-trail{display:flex;flex-direction:column;gap:16px;max-height:400px;overflow-y:auto}.activity-day{display:flex;flex-direction:column;gap:6px}.activity-day-header{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding-bottom:4px;border-bottom:1px solid var(--border)}.activity-event{display:flex;align-items:baseline;gap:8px;font-size:13px;line-height:1.4}.activity-event-icon{font-size:14px;flex-shrink:0}.activity-event-time{font-size:11px;color:var(--text-muted);flex-shrink:0;min-width:40px}.activity-event-label{font-weight:500;color:var(--text);flex-shrink:0}.activity-event-detail{font-size:12px;color:var(--text-muted)}.streak-bar{display:flex;gap:16px;padding:4px 16px 6px;font-size:13px;align-items:center;border-top:1px solid rgba(255,255,255,.2);flex-wrap:wrap}.streak-item{display:flex;align-items:center;gap:3px;color:#fff}.streak-item strong{font-size:15px}.streak-progress{color:#ffffffd9;font-size:12px}.streak-paused{color:#ffffffbf;font-style:italic;font-size:12px}.btn-streak-reset{background:none;border:none;font-size:12px;cursor:pointer;padding:1px 3px;opacity:.5;line-height:1;margin-left:4px}.btn-streak-reset:hover{opacity:1}.setting-number-input{width:70px;padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font-size:14px}.setting-select{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font-size:14px}.conversation-view{display:flex;flex-direction:column;height:100%;min-height:0}.conv-context-label{display:flex;justify-content:space-between;align-items:center;padding:6px 16px;font-size:12px;color:var(--text-muted);background:var(--green-light);border-bottom:1px solid var(--border)}.conv-context-count{font-weight:500}.conv-level-badge{font-size:12px;font-weight:700;background:var(--green);color:#fff;border-radius:50%;width:26px;height:26px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.conv-chat{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;min-height:0}.conv-msg{display:flex;align-items:flex-end;gap:8px}.conv-msg-ai{align-self:flex-start}.conv-msg-user{align-self:flex-end;flex-direction:row-reverse}.conv-msg-avatar{font-size:20px;flex-shrink:0;margin-bottom:2px}.conv-msg-bubble{max-width:82%;padding:10px 14px;border-radius:var(--radius);font-size:15px;line-height:1.5;white-space:pre-wrap}.conv-msg-ai .conv-msg-bubble{background:var(--surface);border:1px solid var(--border);border-bottom-left-radius:4px}.conv-msg-user .conv-msg-bubble{background:var(--green);color:#fff;border-bottom-right-radius:4px}.conv-msg-loading{padding:14px 18px}.conv-dots{display:flex;gap:5px;align-items:center}.conv-dots span{width:8px;height:8px;border-radius:50%;background:var(--text-muted);animation:conv-bounce 1.2s infinite ease-in-out}.conv-dots span:nth-child(2){animation-delay:.2s}.conv-dots span:nth-child(3){animation-delay:.4s}@keyframes conv-bounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.1);opacity:1}}.conv-diff-check{padding:12px 16px;background:#fff8e6;border-top:1px solid #f0d080;text-align:center}.conv-diff-check p{margin:0 0 8px;font-weight:600;font-size:14px;color:var(--text)}.conv-diff-buttons{display:flex;gap:8px;justify-content:center}.conv-diff-btn{flex:1;max-width:110px;padding:7px 10px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;border:none;cursor:pointer;transition:opacity .15s}.conv-diff-btn.easier{background:var(--green-light);color:var(--green-dark)}.conv-diff-btn.ok{background:var(--border);color:var(--text)}.conv-diff-btn.harder{background:#fde8e8;color:var(--red)}.conv-diff-btn:hover{opacity:.85}.conv-input-area{border-top:1px solid var(--border);padding:10px 12px 12px;background:var(--surface);display:flex;flex-direction:column;gap:8px}.conv-level-controls{display:flex;align-items:center;gap:8px}.conv-level-btn{width:28px;height:28px;border-radius:50%;border:2px solid var(--green);background:transparent;color:var(--green);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.conv-level-btn:disabled{opacity:.3;cursor:default}.conv-level-btn:not(:disabled):hover{background:var(--green);color:#fff}.conv-level-label{font-size:13px;color:var(--text-muted);flex:1;text-align:center}.conv-input-row{display:flex;gap:8px;align-items:flex-end}.conv-input{flex:1;resize:none;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:15px;font-family:inherit;background:var(--bg);color:var(--text);transition:border-color .15s;min-height:44px}.conv-input:focus{outline:none;border-color:var(--green)}.conv-input::placeholder{color:var(--text-muted)}.conv-send-btn{width:44px;height:44px;border-radius:50%;border:none;background:var(--green);color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.conv-send-btn:disabled{opacity:.4;cursor:default}.conv-send-btn:not(:disabled):hover{background:var(--green-dark)}.question-display{background:var(--green-light);border:1.5px solid var(--green)}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.question-close-btn{background:transparent;border:none;font-size:18px;cursor:pointer;color:var(--text-muted);padding:0;line-height:1}.question-close-btn:hover{color:var(--red)}.question-loading{padding:16px 0;text-align:center}.question-text-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:12px}.question-text{flex:1;margin:0;font-size:17px;line-height:1.5;white-space:pre-wrap;color:var(--text)}.question-replay-btn{background:transparent;border:none;font-size:20px;cursor:pointer;padding:0;flex-shrink:0;opacity:.7;transition:opacity .15s}.question-replay-btn:hover{opacity:1}.question-answer-row{display:flex;gap:8px;align-items:center}.question-input{flex:1;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:9px 12px;font-size:15px;font-family:inherit;background:#fff;min-width:0}.question-input:focus{outline:none;border-color:var(--green)}.question-mic-btn{width:42px;height:42px;border-radius:50%;border:1.5px solid var(--green);background:#fff;color:var(--green);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}.question-mic-btn:disabled{opacity:.4;cursor:default}.question-mic-btn.listening{background:var(--red);color:#fff;border-color:var(--red);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.question-evaluation{display:flex;flex-direction:column;gap:10px}.question-evaluation p{margin:0;font-size:15px;line-height:1.5}.conj-display{background:#f0f4ff}.conj-dutch{font-size:18px;font-weight:600;margin:0 0 10px;color:var(--text)}.conj-forms{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.conj-form{font-size:15px;color:var(--text-muted);padding:3px 8px;border-radius:var(--radius-sm);transition:background .2s,color .2s}.conj-form.active{background:#dbe4ff;color:#2c4db5;font-weight:600}.player-extra-btns{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:8px 0 4px}.trans-lang-selector{display:flex;gap:4px;align-items:center;flex-wrap:wrap;margin:6px 0 4px}.trans-lang-btn{background:none;border:1px solid var(--border);border-radius:20px;cursor:pointer;font-size:13px;padding:3px 10px;color:#555;white-space:nowrap}.trans-lang-btn.active{background:var(--green);border-color:var(--green);color:#fff}.trans-lang-add{background:none;border:1px dashed var(--border);border-radius:50%;cursor:pointer;font-size:16px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:#888;flex-shrink:0}.trans-lang-add:hover{border-color:var(--green);color:var(--green)}.trans-lang-processing{display:flex;align-items:center;padding:0 4px}.add-lang-panel{background:#f5f5f5;border-radius:var(--radius);padding:12px;margin:4px 0 8px}.spinner-sm{display:inline-block;width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:spin .8s linear infinite}.admin-ops-view{display:flex;flex-direction:column;gap:0}.backup-status-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.backup-status-row{display:flex;align-items:center;gap:6px;padding:3px 0;font-size:13px}.backup-status-label{flex:1;color:var(--text-muted)}.backup-status-ok{color:var(--green);font-size:12px}.backup-status-err{color:var(--red);font-size:12px;cursor:help}.backup-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--border)}.backup-status-dot[data-status=klaar]{background:var(--green)}.backup-status-dot[data-status=bezig]{background:#f59e0b;animation:pulse 1.2s ease-in-out infinite}.backup-status-dot[data-status=fout]{background:var(--red)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.backup-list{display:flex;flex-direction:column;gap:10px}.backup-card{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;background:var(--surface)}.backup-card-safety{background:#fffbeb;border-color:#fde68a}.backup-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.backup-card-header>div{display:flex;align-items:center;gap:6px;min-width:0}.backup-id{font-size:13px;font-family:monospace;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.backup-type-badge{font-size:11px;background:#fde68a;color:#92400e;border-radius:10px;padding:1px 7px;white-space:nowrap}.backup-card-meta{font-size:12px;color:var(--text-muted);margin-bottom:4px}.backup-card-counts{font-size:12px;color:var(--text-muted)}.broadcast-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:14px;font-weight:500;border-left:4px solid currentColor;flex-wrap:wrap}.broadcast-banner--info{background:#eff6ff;color:#1d4ed8;border-left-color:#3b82f6}.broadcast-banner--belangrijk{background:#fffbeb;color:#92400e;border-left-color:#f59e0b}.broadcast-banner--kritiek{background:#fef2f2;color:#991b1b;border-left-color:#ef4444}.broadcast-message{flex:1;min-width:0;white-space:pre-wrap}.broadcast-dismiss{background:none;border:none;cursor:pointer;font-size:16px;padding:0 4px;opacity:.6;line-height:1;flex-shrink:0;color:inherit}.broadcast-dismiss:hover{opacity:1}.broadcast-form{display:flex;flex-direction:column}.broadcast-form-label{font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:6px}.broadcast-textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;font-size:14px;font-family:inherit;resize:vertical;box-sizing:border-box}.broadcast-textarea:focus{outline:none;border-color:var(--green)}.broadcast-level-row{display:flex;gap:8px;flex-wrap:wrap}.broadcast-level-btn{padding:6px 16px;border-radius:20px;border:2px solid transparent;font-size:13px;font-weight:600;cursor:pointer;opacity:.6}.broadcast-level-btn.active{opacity:1}.broadcast-level-btn--info{background:#eff6ff;color:#1d4ed8;border-color:#3b82f6}.broadcast-level-btn--info.active{background:#3b82f6;color:#fff}.broadcast-level-btn--belangrijk{background:#fffbeb;color:#92400e;border-color:#f59e0b}.broadcast-level-btn--belangrijk.active{background:#f59e0b;color:#fff}.broadcast-level-btn--kritiek{background:#fef2f2;color:#991b1b;border-color:#ef4444}.broadcast-level-btn--kritiek.active{background:#ef4444;color:#fff}.chat-panel{display:flex;flex-direction:column;flex:1;min-height:0}.chat-messages{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:2px}.chat-messages-spacer{flex:1}.chat-date-header{text-align:center;font-size:12px;color:var(--text-muted);margin:12px 0 6px;font-weight:500}.chat-bubble-row{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:4px}.chat-bubble-row.own{align-items:flex-end}.chat-sender{font-size:11px;color:var(--text-muted);margin-bottom:2px;padding-left:4px}.chat-bubble{max-width:75%;background:var(--surface);border:1px solid var(--border);border-radius:16px 16px 16px 4px;padding:8px 12px;display:flex;align-items:flex-end;gap:8px;flex-wrap:wrap}.chat-bubble.own{background:var(--green);color:#fff;border-color:var(--green);border-radius:16px 16px 4px}.chat-text{font-size:14px;line-height:1.4;word-break:break-word}.chat-time{font-size:11px;opacity:.6;white-space:nowrap;flex-shrink:0;align-self:flex-end}.chat-input-wrapper{position:relative;flex-shrink:0}.chat-input-row{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--border);background:var(--bg)}.chat-emoji-btn{background:none;border:none;cursor:pointer;font-size:20px;padding:0 2px;line-height:1;opacity:.7;flex-shrink:0;align-self:center}.chat-emoji-btn:hover{opacity:1}.chat-gif{max-width:220px;max-height:180px;border-radius:8px;display:block}.emoji-picker{position:absolute;bottom:calc(100% + 4px);right:0;width:360px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;z-index:600;overflow:hidden}.emoji-picker--maximized{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;max-height:none;border-radius:0;z-index:700;display:flex;flex-direction:column}.emoji-picker--maximized .emoji-picker-header{padding:20px 16px 0;padding-top:max(20px,env(safe-area-inset-top,20px))}.emoji-picker--maximized .emoji-picker-search{font-size:15px;padding:10px 14px}.emoji-picker--maximized .emoji-picker-maximize-btn{font-size:18px;padding:8px 10px}.emoji-picker--maximized .emoji-grid{flex:1;max-height:none;min-height:0}.emoji-picker--maximized .gif-grid{flex:1;max-height:none;min-height:0;grid-template-columns:1fr;align-content:start}.emoji-picker-header{padding:8px 8px 0;display:flex;flex-direction:column;gap:6px}.emoji-picker-search-row{display:flex;gap:4px;align-items:center}.emoji-picker-search{flex:1;border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:13px;font-family:inherit;background:var(--bg);box-sizing:border-box}.emoji-picker-maximize-btn{flex-shrink:0;background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:14px;padding:4px 6px;line-height:1;color:var(--text-muted, #666)}.emoji-picker-maximize-btn:hover{background:var(--bg)}.emoji-picker-search:focus{outline:none;border-color:var(--green)}.emoji-picker-tabs{display:flex;gap:4px;padding-bottom:6px;border-bottom:1px solid var(--border)}.emoji-tab-btn{flex:1;padding:4px 0;border:none;border-radius:6px;background:none;cursor:pointer;font-size:12px;font-weight:600;color:var(--text-muted, #666)}.emoji-tab-btn.active{background:var(--green);color:#fff}.emoji-category-bar{display:flex;overflow-x:auto;padding:4px 6px;gap:2px;border-bottom:1px solid var(--border);scrollbar-width:none}.emoji-category-bar::-webkit-scrollbar{display:none}.emoji-cat-btn{background:none;border:none;cursor:pointer;font-size:18px;padding:4px 5px;border-radius:6px;flex-shrink:0;opacity:.7;line-height:1}.emoji-cat-btn:hover,.emoji-cat-btn.active{background:var(--green-light);opacity:1}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;padding:6px;max-height:180px;overflow-y:auto;scrollbar-width:thin}.emoji-btn{background:none;border:none;cursor:pointer;font-size:22px;padding:4px 2px;border-radius:6px;line-height:1;text-align:center}.emoji-btn:hover{background:var(--green-light)}.emoji-empty{padding:12px;text-align:center;color:var(--text-muted, #888);font-size:13px}.gif-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:8px;max-height:360px;overflow-y:auto;scrollbar-width:thin}.gif-item{background:none;border:none;cursor:pointer;padding:0;border-radius:6px;overflow:hidden}.gif-item img{width:100%;height:auto;display:block}.gif-item:hover{opacity:.85}.chat-input{flex:1;border:1px solid var(--border);border-radius:20px;padding:9px 14px;font-size:14px;font-family:inherit;background:var(--surface)}.chat-input:focus{outline:none;border-color:var(--green)}.chat-send-btn{border-radius:50%;width:40px;height:40px;padding:0;font-size:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.chat-empty{text-align:center;color:var(--text-muted);font-size:14px;padding:32px 16px}.chat-user-list{flex:1;overflow-y:auto;padding:8px 0}.chat-user-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left}.chat-user-item:hover{background:var(--surface)}.chat-user-avatar-wrap{position:relative;flex-shrink:0}.chat-user-avatar{width:40px;height:40px;border-radius:50%;background:var(--green-light);color:var(--green-dark);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700}.chat-presence-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:#ccc;border:2px solid var(--surface, #fff);vertical-align:middle;flex-shrink:0}.chat-user-avatar-wrap .chat-presence-dot{position:absolute;bottom:1px;right:1px}.chat-presence-dot.online{background:#22c55e}.settings-user{display:flex;align-items:center;gap:6px;margin-left:auto}.settings-user-name{font-size:14px;font-weight:500;color:var(--text-muted)}.chat-user-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.chat-user-name{font-size:14px;font-weight:600;color:var(--text)}.chat-user-email{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-user-arrow{font-size:20px;color:var(--text-muted);flex-shrink:0}.chat-widget{position:fixed;bottom:16px;right:16px;z-index:500;display:flex;flex-direction:column;align-items:flex-end}.chat-widget-btn{width:52px;height:52px;border-radius:50%;background:var(--green);color:#fff;border:none;font-size:22px;cursor:pointer;box-shadow:0 4px 16px #00000040;display:flex;align-items:center;justify-content:center;position:relative;transition:transform .15s}.chat-widget-btn:hover{transform:scale(1.07)}.chat-widget-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;pointer-events:none}.chat-widget-badge--bar{position:static;margin-left:6px;font-size:10px;vertical-align:middle}.chat-widget-badge--inline{position:static;margin-left:5px;font-size:10px;min-width:16px;height:16px;vertical-align:middle}.chat-widget-badge--user{position:static;margin-left:auto;font-size:11px;min-width:20px;height:20px}.chat-widget-panel{width:340px;height:480px;display:flex;flex-direction:column;background:var(--bg);border-radius:12px 12px 0 0;box-shadow:0 8px 32px #00000038;overflow:hidden;border:1px solid var(--border);border-bottom:none}.chat-widget-panel--maximized{position:fixed;top:0;right:0;bottom:0;left:0;width:auto;height:auto;border-radius:0;border:none;z-index:500}.chat-widget-titlebar{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--green);color:#fff;flex-shrink:0}.chat-widget-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:6px}.chat-widget-titlebar-actions{display:flex;gap:4px}.chat-widget-action-btn{background:#ffffff26;border:none;color:#fff;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;line-height:1}.chat-widget-action-btn:hover{background:#ffffff4d}@media (max-width: 600px){.chat-widget{bottom:0;right:0}.chat-widget-btn{margin:0 12px 12px 0}.chat-widget-panel{width:100%;border-radius:12px 12px 0 0;height:75dvh}}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;max-width:320px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#1a1a1a;color:#fff;border-radius:var(--radius-sm);box-shadow:0 4px 16px #00000040;font-size:14px;line-height:1.4;pointer-events:all;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast-icon{font-size:18px;flex-shrink:0}.toast-message{flex:1;min-width:0}.toast-close{background:none;border:none;color:#fff9;cursor:pointer;font-size:18px;line-height:1;padding:0 2px;flex-shrink:0}.toast-close:hover{color:#fff}.pull-indicator{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 0;color:var(--green-dark);font-size:13px}.pull-indicator-inner{width:32px;height:32px;border-radius:50%;background:#fff;border:2px solid var(--green);display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 2px 8px #0000001f;flex-shrink:0;transition:transform .05s linear}@keyframes ptr-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pull-indicator-inner.spinning{animation:ptr-spin .7s linear infinite}.pull-indicator-hint{font-size:12px;color:var(--text-muted)}.btn-detail{background:none;border:none;font-size:12px;color:var(--text-muted);cursor:pointer;padding:2px 3px;flex-shrink:0;opacity:.5;line-height:1}.btn-detail:hover{opacity:1;color:var(--green)}.text-detail-list{display:grid;grid-template-columns:auto 1fr;gap:6px 12px;font-size:14px;margin:0 0 8px}.text-detail-list dt{color:var(--text-muted);font-weight:500}.text-detail-list dd{margin:0}.add-text-mode-toggle{display:flex;gap:0;margin:0 0 16px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.add-text-mode-toggle button{flex:1;padding:9px 12px;background:var(--surface);border:none;border-right:1px solid var(--border);font-size:14px;cursor:pointer;color:var(--text-muted);transition:background .15s}.add-text-mode-toggle button:last-child{border-right:none}.add-text-mode-toggle button.active{background:var(--green);color:#fff;font-weight:600}.add-text-mode-toggle button:disabled{opacity:.4;cursor:default}.batch-file-list{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}.batch-file-row{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 10px;font-size:13px}.batch-file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.batch-deel-label{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted);flex-shrink:0}.batch-deel-input{width:44px;padding:3px 5px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;text-align:center}.batch-title-preview{font-size:12px;color:var(--text-muted);flex:1;font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.batch-remove-btn{background:none;border:none;cursor:pointer;font-size:16px;color:var(--text-muted);padding:0 2px;line-height:1;flex-shrink:0}.batch-remove-btn:hover{color:var(--red)}.batch-results-list{list-style:none;padding:0;margin:12px 0 16px;text-align:left;width:100%}.batch-result-item{display:flex;align-items:baseline;gap:8px;padding:5px 0;border-bottom:1px solid var(--border);font-size:14px}.batch-result-item:last-child{border-bottom:none}.batch-result-icon{flex-shrink:0;font-weight:700}.batch-result-item.ok .batch-result-icon{color:var(--green)}.batch-result-item.fail .batch-result-icon{color:var(--red)}.batch-result-title{flex:1}.batch-result-error{font-size:12px;color:var(--red)}.wordlists-view,.wordlist-detail-view,.word-practice-view{padding:0}.wordlist-table-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-top:8px}.wordlist-table-header{display:grid;grid-template-columns:1fr 1fr 60px;gap:8px;padding:8px 12px;background:var(--green-light);font-size:13px;font-weight:600;color:var(--green-dark)}.wordlist-table-header--scores{grid-template-columns:1fr 1fr 48px 48px 72px}.wordlist-row{display:grid;grid-template-columns:1fr 1fr 60px;gap:8px;align-items:center;padding:8px 12px;border-top:1px solid var(--border);font-size:14px}.wordlist-row--scores{grid-template-columns:1fr 1fr 48px 48px 72px}.wordlist-score-col{text-align:center;font-size:11px}.word-score{color:var(--green-dark);letter-spacing:1px;font-size:11px}.word-score-empty{opacity:.2;font-size:11px}.wordlist-score-filter{display:flex;align-items:center;gap:6px;margin-top:10px;flex-wrap:wrap}.wordlist-score-filter-label{font-size:13px;color:var(--text-muted);white-space:nowrap}.score-filter-btn{background:none;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-weight:600;padding:2px 8px;cursor:pointer;color:var(--text-muted);transition:background .15s,color .15s,border-color .15s}.score-filter-btn.active,.score-filter-btn:hover{background:var(--green-light);border-color:var(--green);color:var(--green-dark)}.score-filter-clear{background:none;border:none;font-size:13px;color:var(--text-muted);cursor:pointer;padding:2px 4px}.wordlist-row:first-of-type{border-top:none}.wordlist-cell{word-break:break-word}.wordlist-edit-input{width:100%;padding:4px 8px;border:1.5px solid var(--green);border-radius:var(--radius-sm);font-size:14px;background:var(--surface);color:var(--text)}.tag-input{display:flex;flex-wrap:wrap;align-items:center;gap:4px;min-height:34px;padding:4px 6px;border:1.5px solid var(--green);border-radius:var(--radius-sm);background:var(--surface);cursor:text}.tag{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;background:var(--green-light);color:var(--text);border-radius:4px;font-size:13px;white-space:nowrap}.tag-remove{background:none;border:none;padding:0 1px;cursor:pointer;font-size:14px;line-height:1;color:var(--text-muted);display:flex;align-items:center}.tag-remove:hover{color:var(--red)}.tag-text-input{flex:1;min-width:60px;border:none;outline:none;background:transparent;font-size:14px;color:var(--text);padding:0}.practice-card-wrap{perspective:1000px;cursor:pointer;-webkit-tap-highlight-color:transparent;margin-bottom:20px}.practice-card-inner{position:relative;transform-style:preserve-3d;transition:transform .45s ease}.practice-card-inner--flipped{transform:rotateY(180deg)}.practice-card-face{backface-visibility:hidden;-webkit-backface-visibility:hidden}.practice-card-face--hidden{visibility:hidden}.practice-card-face--back{transform:rotateY(180deg);position:absolute;top:0;left:0;right:0;bottom:0}.practice-card-subword{font-size:14px;color:var(--text-muted);margin-top:12px;border-top:1px solid var(--border);padding-top:10px;text-align:center}.practice-prompt-card{background:var(--surface);border:2px solid var(--green-light);border-radius:var(--radius);padding:28px 20px;text-align:center;box-shadow:var(--shadow)}.practice-prompt-word{font-size:28px;font-weight:700;color:var(--text);line-height:1.3}.btn-mic{width:100%;padding:14px;border:2px solid var(--green);border-radius:var(--radius);background:var(--surface);color:var(--green-dark);font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s}.btn-mic:hover{background:var(--green-light)}.btn-mic--active{background:var(--green-light);border-color:var(--green-dark);animation:mic-pulse-border 1s infinite}@keyframes mic-pulse-border{0%,to{border-color:var(--green)}50%{border-color:var(--green-dark)}}.mic-pulse{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--green-dark);animation:mic-dot-pulse .8s infinite}@keyframes mic-dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}.practice-close-feedback{background:#fff8e1;border:2px solid #f59e0b;border-radius:var(--radius);padding:16px 20px;text-align:center;color:#78350f}.practice-result{padding:20px;border-radius:var(--radius);text-align:center}.practice-result--correct{background:var(--green-light);border:2px solid var(--green)}.practice-result--wrong{background:#fef2f2;border:2px solid var(--red)}.btn-secondary.active{background:var(--green-light);border-color:var(--green);color:var(--green-dark);font-weight:600}.filter-select{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--surface);color:var(--text)}.cycling-view{display:flex;flex-direction:column;height:100%;padding:0}.cycling-meta{padding:6px 16px 12px;font-size:13px;color:var(--text-muted)}.cycling-stage{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 20px;gap:24px}.cycling-hint{color:var(--text-muted);font-size:15px;text-align:center;line-height:1.6}.cycling-word,.cycling-translation{display:flex;flex-direction:column;align-items:center;gap:8px;animation:cycling-fade-in .3s ease}@keyframes cycling-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cycling-flag{font-size:32px}.cycling-text{font-size:28px;font-weight:600;text-align:center;color:var(--text);line-height:1.3}.cycling-text--translation{font-size:22px;font-weight:400;color:var(--text-muted)}.cycling-controls{padding:24px 20px;display:flex;justify-content:center}.actions-dropdown{position:absolute;right:0;top:calc(100% + 4px);background:#fff;border:1px solid #ddd;border-radius:var(--radius-sm);box-shadow:0 4px 12px #0000001f;min-width:200px;z-index:200;overflow:hidden}.actions-dropdown-item{display:block;width:100%;text-align:left;padding:10px 14px;background:none;border:none;border-bottom:1px solid #f0f0f0;font-size:14px;cursor:pointer;color:var(--text)}.actions-dropdown-item:last-child{border-bottom:none}.actions-dropdown-item:hover:not(:disabled){background:#f5f5f5}.actions-dropdown-item:disabled{color:var(--text-muted);cursor:default}
