:root{--bg:#0f172a;--bg-soft:#1e293b;--fg:#e2e8f0;--muted:#94a3b8;--accent:#6366f1;--right:#16a34a;--wrong:#dc2626;--card-front:#4338ca;--card-back:#0891b2}*{box-sizing:border-box}body{background:var(--bg);color:var(--fg);flex-direction:column;min-height:100vh;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}header{border-bottom:1px solid #334155;flex-direction:column;gap:.8rem;padding:1rem 1.5rem;display:flex}header h1{margin:0;font-size:1.3rem}.toolbar{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;display:flex}.toolbar button,.file-btn{background:var(--bg-soft);color:var(--fg);cursor:pointer;border:1px solid #334155;border-radius:6px;padding:.5rem .9rem;font-size:.9rem}.toolbar button:hover,.file-btn:hover{background:#334155}#lang-select{background:var(--bg-soft);color:var(--fg);cursor:pointer;border:1px solid #334155;border-radius:6px;padding:.5rem .6rem;font-size:.9rem}#lang-select:hover{background:#334155}main{flex:1;width:100%;max-width:720px;margin:0 auto;padding:1.5rem}.level-grid-wrap{margin-bottom:1rem;overflow-x:auto}.level-grid{border-collapse:separate;border-spacing:6px;text-align:center;width:100%}.level-grid th{background:var(--bg-soft);color:var(--muted);text-transform:uppercase;letter-spacing:.1em;border-radius:6px;padding:.45rem .5rem;font-size:.75rem}.level-grid td{background:var(--bg-soft);border-radius:6px;min-width:52px;padding:.5rem;font-size:1.6rem;font-weight:700;transition:background .25s,color .25s}.level-grid td.active-count{background:var(--accent);color:#fff}.level-grid .learned-col th,.level-grid .learned-col{color:#4ade80}.level-grid td.learned-col.active-count{color:#fff;background:#15803d}.progress-wrap{margin-bottom:1.5rem}.progress-bar{background:var(--bg-soft);border-radius:4px;height:8px;overflow:hidden}#progress-fill{background:var(--accent);width:0;height:100%;transition:width .3s}.card-meta{color:var(--muted);align-items:center;gap:.5rem;margin-bottom:.8rem;font-size:.9rem;display:flex}.level-dots{gap:4px;display:inline-flex}.dot{background:#334155;border-radius:50%;width:12px;height:12px}.dot.filled{background:var(--accent)}.level-number{color:var(--fg);margin-left:auto;font-weight:700}.card{perspective:1200px;cursor:pointer;width:100%;height:280px;margin-bottom:1rem}.card-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s;position:relative}.card.flipped .card-inner{transform:rotateY(180deg)}.card-face{backface-visibility:hidden;border-radius:16px;flex-direction:column;justify-content:space-between;padding:2rem;display:flex;position:absolute;inset:0;box-shadow:0 10px 30px #0006}.card-front{background:linear-gradient(135deg, var(--card-front), #6d28d9)}.card-back{background:linear-gradient(135deg, var(--card-back), #0e7490);transform:rotateY(180deg)}.card-hint{text-transform:uppercase;letter-spacing:.15em;opacity:.8;font-size:.8rem}.card-content{text-align:center;flex:1;justify-content:center;align-items:center;font-size:1.6rem;font-weight:600;line-height:1.3;display:flex}.card-foot{text-align:center;opacity:.75;font-size:.85rem}.answer-buttons{justify-content:center;gap:1rem;animation:.3s fadein;display:flex}@keyframes fadein{0%{opacity:0;transform:translateY(-6px)}to{opacity:1}}.btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;flex:1;max-width:220px;padding:.9rem 1rem;font-size:1rem;font-weight:700;transition:transform .1s,filter .1s}.btn:hover{filter:brightness(1.1)}.btn:active{transform:scale(.97)}.btn-right{background:var(--right)}.btn-wrong{background:var(--wrong)}.done-message{text-align:center;background:var(--bg-soft);border-radius:12px;padding:2rem;font-size:1.1rem}footer{text-align:center;color:var(--muted);padding:1rem;font-size:.8rem}.deck-management{margin-bottom:1.5rem}#deck-bar{background:var(--bg-soft);border:1px solid #334155;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem;display:flex}#deck-select{background:var(--bg);color:var(--fg);border:1px solid #334155;border-radius:4px;flex:1;padding:.4rem .6rem}#deck-name-input{background:var(--bg);color:var(--fg);border:1px solid #334155;border-radius:4px;width:140px;padding:.4rem .6rem}.btn-danger{background:var(--wrong)!important;color:#fff!important}.btn-danger:disabled{opacity:.35;cursor:not-allowed;filter:none}[hidden]{display:none!important}.backend-error{color:#fee2e2;background:#7f1d1d;border:1px solid #b91c1c;border-radius:6px;margin-bottom:1rem;padding:.7rem 1rem;font-size:.9rem}.save-toast{background:var(--right);color:#fff;opacity:0;pointer-events:none;z-index:50;border-radius:8px;padding:.55rem .9rem;font-size:.9rem;transition:opacity .2s,transform .2s;position:fixed;bottom:1.2rem;right:1.2rem;transform:translateY(8px);box-shadow:0 4px 14px #00000059}.save-toast.show{opacity:1;transform:translateY(0)}.modal{z-index:1000;background:#000000d9;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-soft);border-radius:12px;flex-direction:column;width:100%;max-width:600px;max-height:90vh;display:flex;box-shadow:0 20px 50px #00000080}.modal-header{border-bottom:1px solid #334155;flex-flow:row;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.modal-header h2{margin:0;font-size:1.2rem}.btn-close{color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:1.8rem}.editor-rows{flex-direction:column;flex:1;gap:.5rem;padding:1rem 1.5rem;display:flex;overflow-y:auto}.bulk-paste{color:var(--muted);border-bottom:1px solid #334155;flex-direction:column;gap:.4rem;padding:.8rem 1.5rem;font-size:.85rem;display:flex}.bulk-paste textarea{background:var(--bg);color:var(--fg);resize:vertical;border:1px solid #334155;border-radius:4px;padding:.5rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem}.bulk-paste-actions{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.bulk-paste-mode{cursor:pointer;align-items:center;gap:.35rem;display:flex}.bulk-paste .btn{background:var(--accent);flex:none;padding:.4rem .9rem;font-size:.85rem}.editor-row{gap:.5rem;display:flex}.editor-row input{background:var(--bg);color:var(--fg);border:1px solid #334155;border-radius:4px;flex:1;padding:.5rem}#add-row-btn{background:var(--accent)}.modal-footer{border-top:1px solid #334155;justify-content:space-between;padding:1rem 1.5rem;display:flex}.title-wrap{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.6rem;display:flex}.title-right{align-items:center;gap:.6rem;display:flex}.user-badge{color:var(--muted);background:var(--bg-soft);cursor:pointer;border:1px solid #334155;border-radius:999px;align-items:center;gap:.4rem;padding:.2rem .6rem;font-family:inherit;font-size:.85rem;display:inline-flex}.user-badge:hover{background:#334155}.confirm-dialog{z-index:2100;background:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.confirm-box{background:var(--bg-soft);border:1px solid #334155;border-radius:14px;flex-direction:column;gap:1.2rem;width:100%;max-width:360px;padding:1.6rem 1.8rem 1.4rem;display:flex;box-shadow:0 20px 50px #0009}.confirm-box p{color:var(--fg);margin:0;line-height:1.5}.confirm-actions{justify-content:flex-end;gap:.7rem;display:flex}.confirm-actions .btn{flex:none;padding:.6rem 1.2rem;font-size:.95rem}.btn-neutral{background:var(--bg);color:var(--fg);border:1px solid #334155}.btn-neutral:hover{filter:none;background:#334155}.share-toggle{color:var(--muted);cursor:pointer;white-space:nowrap;align-items:center;gap:.35rem;font-size:.85rem;display:flex}.login-overlay{background:var(--bg);z-index:2000;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.loading-screen{background:var(--bg);z-index:2000;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:fixed;inset:0}.spinner{border:4px solid #334155;border-top-color:var(--accent);border-radius:50%;width:44px;height:44px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-overlay[hidden]{display:none!important}.login-card{background:var(--bg-soft);text-align:center;border:1px solid #334155;border-radius:14px;width:100%;max-width:380px;padding:2rem;box-shadow:0 20px 50px #00000080}.login-card h2{margin:0 0 .5rem}.login-desc{color:var(--muted);margin:0 0 1rem;font-size:.9rem}.login-card input{background:var(--bg);width:100%;color:var(--fg);text-align:center;letter-spacing:.15em;border:1px solid #334155;border-radius:8px;margin-bottom:.8rem;padding:.7rem;font-size:1rem}.login-card .btn{width:100%;max-width:none}.login-error{color:#fca5a5;margin-bottom:.8rem;font-size:.85rem}.invite-modal-content{max-width:420px}.invite-body{flex-direction:column;align-items:center;gap:.8rem;padding:1.2rem 1.5rem;display:flex}.invite-code{background:var(--bg);text-align:center;word-break:break-all;width:100%;color:var(--fg);border:1px dashed #475569;border-radius:8px;padding:.8rem;font-size:1.05rem;display:block}.devices-modal-content{max-width:480px}.devices-body{flex-direction:column;gap:.6rem;padding:1.2rem 1.5rem;display:flex;overflow-y:auto}.devices-count{color:var(--muted);margin:0;font-size:.9rem}.devices-section{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:.6rem 0 .2rem;font-size:.8rem}.device-row{background:var(--bg);border:1px solid #334155;border-radius:8px;align-items:center;gap:.6rem;padding:.55rem .7rem;display:flex}.device-icon{font-size:1.3rem;line-height:1}.device-info{flex-direction:column;flex:1;min-width:0;display:flex}.device-label{word-break:break-word;font-size:.95rem}.device-current{color:var(--accent);font-style:normal;font-weight:700}.device-date{color:var(--muted);font-size:.78rem}.device-code{letter-spacing:.05em;color:var(--fg);word-break:break-all;flex:1;font-size:1rem}.btn.device-action{border-radius:6px;flex:none;max-width:none;padding:.4rem .8rem;font-size:.8rem}.btn.devices-generate{width:100%;max-width:none;margin-top:.6rem}.btn.devices-generate:disabled{opacity:.5;cursor:not-allowed;filter:none}@media (width<=600px){#export-btn,#export-json-btn,.file-btn,#rename-deck-btn,#add-deck-btn,#delete-deck-btn,#edit-cards-btn,#share-toggle-label{display:none!important}header{gap:.5rem;padding:.6rem 1rem}header h1{font-size:1rem}.toolbar{flex-wrap:wrap;gap:.4rem}.toolbar button,.file-btn{padding:.45rem .7rem;font-size:.85rem}#lang-select{padding:.45rem .5rem;font-size:.85rem}#deck-bar{flex-wrap:wrap;padding:.4rem}#deck-select-label{white-space:nowrap;font-size:.85rem}#deck-select{flex:1;min-width:0;font-size:1rem}main{padding:.75rem}.level-grid th{letter-spacing:0;padding:.3rem .2rem;font-size:.6rem}.level-grid td{min-width:42px;padding:.35rem .2rem;font-size:1.3rem}.card{height:340px;margin-bottom:.75rem}.card-face{padding:1.5rem 1.2rem}.card-content{font-size:1.4rem}.card-foot{font-size:.8rem}.answer-buttons{gap:.75rem}.btn{max-width:none;padding:1.1rem 1rem;font-size:1.05rem}footer{display:none}}
