@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--color-bg:#f8fafc;--color-surface:#fff;--color-surface-2:#f1f5f9;--color-border:#8b5cf633;--color-border-hover:#8b5cf666;--color-primary:#7c3aed;--color-primary-light:#8b5cf6;--color-primary-glow:#7c3aed4d;--color-secondary:#06b6d4;--color-accent:#f59e0b;--color-success:#10b981;--color-danger:#ef4444;--color-info:#3b82f6;--color-text:#1e293b;--color-text-muted:#475569;--color-text-dim:#64748b;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #0000000d;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001f;--shadow-glow:0 0 20px #7c3aed33;--transition:.2s ease;--transition-slow:.4s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}a{color:var(--color-primary-light);transition:color var(--transition);text-decoration:none}a:hover{color:var(--color-secondary)}textarea,input,button{font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-surface)}::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:999px}.spinner{border:3px solid #8b5cf633;border-top-color:var(--color-primary-light);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.spinner-sm{border:2px solid #0000004d;border-top-color:var(--color-primary);vertical-align:middle;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.page-loading,.center-loading{justify-content:center;align-items:center;min-height:60vh;display:flex}.btn-primary{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);box-shadow:0 4px 12px var(--color-primary-glow);border:none;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px var(--color-primary-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);background:0 0;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:500;display:inline-flex}.btn-secondary:hover{border-color:var(--color-border-hover);color:var(--color-text);background:#8b5cf60d}.btn-full{justify-content:center;width:100%}.btn-icon{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;width:36px;height:36px;transition:all var(--transition);background:#0000000d;justify-content:center;align-items:center;font-size:.9rem;display:inline-flex}.btn-icon:hover{border-color:var(--color-primary);background:#8b5cf626}.btn-icon.btn-delete:hover{border-color:var(--color-danger);background:#ef444426}.btn-back{color:var(--color-text-muted);cursor:pointer;transition:color var(--transition);background:0 0;border:none;margin-bottom:8px;padding:4px 0;font-size:.85rem;display:block}.btn-back:hover{color:var(--color-primary-light)}.btn-logout{color:#fc8181;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:0 0;border:1px solid #ef444466;padding:7px 16px;font-size:.82rem;font-weight:500}.btn-logout:hover{border-color:var(--color-danger);background:#ef444426}.btn-study-big{color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);background:linear-gradient(135deg,#059669,#10b981);border:none;align-items:center;gap:8px;padding:10px 22px;font-size:.92rem;font-weight:600;display:inline-flex;box-shadow:0 4px 12px #10b9814d}.btn-study-big:hover{transform:translateY(-1px);box-shadow:0 6px 20px #10b98166}.alert{border-radius:var(--radius-md);margin-bottom:16px;padding:12px 16px;font-size:.88rem;font-weight:500}.alert-error{color:#fc8181;background:#ef44441f;border:1px solid #ef44444d}.alert-info{color:#93c5fd;background:#3b82f61f;border:1px solid #3b82f64d}.alert-success{color:#6ee7b7;background:#10b9811f;border:1px solid #10b9814d}.form-group{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.form-group label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:600}.form-group input,.form-group textarea{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:all var(--transition);resize:vertical;background:#0000000a;outline:none;padding:12px 14px;font-size:.95rem}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-primary-light);background:#8b5cf60d;box-shadow:0 0 0 3px #8b5cf626}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-dim)}.form-row{justify-content:flex-end;gap:12px;display:flex}.navbar{z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);background:#ffffffd9;position:sticky;top:0}.navbar-inner{align-items:center;gap:32px;max-width:1200px;height:60px;margin:0 auto;padding:0 24px;display:flex}.navbar-brand{align-items:center;gap:10px;text-decoration:none;display:flex}.brand-icon{font-size:1.5rem}.brand-text{background:linear-gradient(135deg, var(--color-primary-light), var(--color-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.2rem;font-weight:800}.navbar-links{flex:1;gap:8px;display:flex}.nav-link{border-radius:var(--radius-sm);color:var(--color-text-muted);transition:all var(--transition);padding:6px 14px;font-size:.88rem;font-weight:500;text-decoration:none}.nav-link:hover,.nav-link.active{color:var(--color-primary-light);background:#8b5cf61f}.navbar-user{align-items:center;gap:12px;margin-left:auto;display:flex}.user-greeting{color:var(--color-text-muted);font-size:.88rem}.role-badge{letter-spacing:.03em;border-radius:999px;align-items:center;gap:4px;padding:3px 10px;font-size:.76rem;font-weight:700;display:inline-flex}.role-admin{color:var(--color-accent);background:#f59e0b26;border:1px solid #f59e0b4d}.role-user{color:var(--color-secondary);background:#06b6d41f;border:1px solid #06b6d440}.app-layout{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:32px 24px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:32px;display:flex}.page-title{background:linear-gradient(135deg, #1e293b, var(--color-primary-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.8rem;font-weight:800;line-height:1.2}.page-desc{color:var(--color-text-muted);margin-top:4px;font-size:.9rem}.header-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.sets-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.set-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);flex-direction:column;gap:16px;padding:20px;display:flex;position:relative;overflow:hidden}.set-card:before{content:"";opacity:0;transition:opacity var(--transition);background:linear-gradient(135deg,#8b5cf60d,#0000);position:absolute;inset:0}.set-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-lg), var(--shadow-glow);transform:translateY(-3px)}.set-card:hover:before{opacity:1}.set-card-icon{border-radius:var(--radius-md);background:#8b5cf61a;justify-content:center;align-items:center;width:50px;height:50px;font-size:2rem;display:flex}.set-card-body{flex:1}.set-card-title{color:var(--color-text);margin-bottom:6px;font-size:1.05rem;font-weight:700;line-height:1.3}.set-card-desc{color:var(--color-text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:10px;font-size:.84rem;display:-webkit-box;overflow:hidden}.set-card-meta{justify-content:space-between;align-items:center;gap:8px;display:flex}.meta-badge{color:var(--color-primary-light);background:#8b5cf61f;border-radius:999px;padding:3px 10px;font-size:.8rem;font-weight:500}.meta-date{color:var(--color-text-dim);font-size:.78rem}.set-card-actions{justify-content:flex-end;gap:8px;display:flex}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 20px;display:flex}.empty-icon{font-size:3.5rem;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.empty-state h3{color:var(--color-text);font-size:1.2rem;font-weight:700}.empty-state p{color:var(--color-text-muted);font-size:.9rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000000b3;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:520px;box-shadow:var(--shadow-lg);animation:.25s slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.modal-header h2{font-size:1.1rem;font-weight:700}.modal-close{color:var(--color-text-muted);cursor:pointer;transition:color var(--transition);background:0 0;border:none;padding:4px;font-size:1.1rem}.modal-close:hover{color:var(--color-text)}.modal-body{padding:20px 24px}.modal-footer{justify-content:flex-end;gap:10px;padding-top:8px;display:flex}.add-question-card{background:var(--color-surface);border:1px solid var(--color-primary);border-radius:var(--radius-lg);margin-bottom:24px;padding:24px;box-shadow:0 0 20px #7c3aed1a}.add-question-card h3{color:var(--color-primary-light);margin-bottom:16px;font-size:1rem;font-weight:700}.ai-badge{color:var(--color-secondary);background:#06b6d41f;border-radius:999px;margin-left:8px;padding:2px 8px;font-size:.75rem;font-weight:500}.questions-list{flex-direction:column;gap:16px;display:flex}.question-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:border-color var(--transition);gap:16px;padding:20px;display:flex}.question-item:hover{border-color:var(--color-border-hover)}.question-number{width:32px;height:32px;color:var(--color-primary-light);background:#8b5cf626;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:.8rem;font-weight:700;display:flex}.question-content{flex-direction:column;flex:1;gap:12px;display:flex}.question-q,.question-a{align-items:flex-start;gap:10px;display:flex}.q-label,.a-label{flex-shrink:0;margin-top:1px;font-size:1rem}.question-q p{color:var(--color-text);font-size:.95rem;font-weight:600}.question-a p{color:var(--color-text-muted);font-size:.9rem;line-height:1.6}.keywords-preview{flex-wrap:wrap;align-items:center;gap:6px;padding-top:4px;display:flex}.kw-label{color:var(--color-text-dim);font-size:.78rem;font-weight:500}.kw-tag{color:var(--color-accent);background:#f59e0b1f;border:1px solid #f59e0b33;border-radius:999px;padding:2px 8px;font-size:.76rem;font-weight:500}.question-actions{flex-direction:column;flex-shrink:0;gap:6px;display:flex}.question-edit{flex:1}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative;overflow:hidden}.auth-bg{background:radial-gradient(at 20% 20%,#7c3aed26 0%,#0000 60%),radial-gradient(at 80% 80%,#06b6d41a 0%,#0000 60%);position:absolute;inset:0}.auth-orb{filter:blur(80px);border-radius:50%;animation:8s ease-in-out infinite drift;position:absolute}.orb-1{background:#7c3aed26;width:400px;height:400px;animation-delay:0s;top:-100px;left:-100px}.orb-2{background:#06b6d41a;width:300px;height:300px;animation-delay:-3s;bottom:-80px;right:-80px}.orb-3{background:#f59e0b14;width:200px;height:200px;animation-delay:-5s;top:50%;left:60%}@keyframes drift{0%,to{transform:translate(0)scale(1)}33%{transform:translate(20px,-20px)scale(1.05)}66%{transform:translate(-15px,15px)scale(.95)}}.auth-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg), 0 0 60px #7c3aed1a;background:#fffffff2;padding:40px;position:relative}.auth-header{text-align:center;margin-bottom:28px}.auth-logo{margin-bottom:12px;font-size:3rem;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.auth-title{background:linear-gradient(135deg, var(--color-primary-light), var(--color-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.8rem;font-weight:800}.auth-subtitle{color:var(--color-text-muted);margin-top:6px;font-size:.88rem}.auth-form{flex-direction:column;display:flex}.auth-switch{text-align:center;color:var(--color-text-muted);margin-top:20px;font-size:.85rem}.study-layout{flex-direction:column;flex:1;gap:20px;width:100%;max-width:860px;margin:0 auto;padding:24px;display:flex}.study-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.study-header-left{align-items:center;gap:16px;display:flex}.study-mode-badge{color:#6ee7b7;background:#10b9811f;border:1px solid #10b98133;border-radius:999px;padding:4px 12px;font-size:.82rem;font-weight:600}.btn-shuffle{border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:#8b5cf61a;padding:8px 16px;font-size:.85rem}.btn-shuffle:hover,.btn-shuffle.active{border-color:var(--color-primary);color:var(--color-primary-light);background:#8b5cf626}.study-progress-wrap{align-items:center;gap:12px;display:flex}.study-progress-bar{background:#00000012;border-radius:999px;flex:1;height:6px;overflow:hidden}.study-progress-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-secondary));border-radius:999px;height:100%;transition:width .4s}.study-progress-text{color:var(--color-text-muted);white-space:nowrap;font-size:.85rem;font-weight:600}.flashcard-container{flex:1;min-height:320px}.flashcard{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);min-height:320px;transition:box-shadow var(--transition-slow);box-shadow:var(--shadow-md);flex-direction:column;padding:36px;display:flex}.flashcard.show-answer{box-shadow:var(--shadow-md), 0 0 30px #10b98114;border-color:#10b9814d}.flashcard-question{flex-direction:column;gap:16px;display:flex}.fc-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-dim);align-items:center;gap:8px;font-size:.78rem;font-weight:700;display:flex}.answer-label{color:#10b981cc}.fc-hint{color:var(--color-text-dim);text-transform:none;letter-spacing:0;font-size:.72rem;font-weight:400}.fc-content{color:var(--color-text);font-size:1.05rem;line-height:1.7}.fc-divider{background:linear-gradient(90deg, transparent, var(--color-border), transparent);height:1px;margin:20px 0 8px}.btn-show-answer{color:#6ee7b7;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);background:linear-gradient(135deg,#10b98126,#10b9810d);border:1px solid #10b9814d;align-self:flex-start;margin-top:16px;padding:10px 22px;font-size:.9rem;font-weight:600}.btn-show-answer:hover{background:#10b98133;border-color:#10b98180;transform:translateY(-1px)}.fc-keywords-info{border-top:1px solid var(--color-border);margin-top:16px;padding-top:12px}.kw-count-label{color:var(--color-accent);font-size:.8rem;font-weight:600}.keyword-blur-container{flex-direction:column;gap:12px;display:flex}.keyword-actions{flex-wrap:wrap;gap:8px;display:flex}.btn-reveal-all,.btn-hide-all{cursor:pointer;transition:all var(--transition);border:1px solid;border-radius:999px;padding:5px 12px;font-size:.78rem;font-weight:600}.btn-reveal-all{color:#6ee7b7;background:#10b9811a;border-color:#10b9814d}.btn-reveal-all:hover{background:#10b98133}.btn-hide-all{color:var(--color-text-muted);background:#6b72801a;border-color:#6b72804d}.btn-hide-all:hover{background:#6b728033}.answer-text{color:var(--color-text);word-break:break-word;font-size:1rem;line-height:1.8}.keyword-token{cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none;vertical-align:middle;border-radius:4px;margin:0 1px;padding:0 4px;display:inline-block}.keyword-token.hidden{background:var(--color-primary);color:var(--color-primary);letter-spacing:-1px;text-align:center;border-radius:4px;min-width:50px;animation:2s ease-in-out infinite tokenPulse}.keyword-token.hidden:hover{background:var(--color-primary-light);color:var(--color-primary-light);box-shadow:0 0 10px var(--color-primary-glow);transform:scale(1.05)}.keyword-token.revealed{color:var(--color-accent);background:#f59e0b26;border:1px solid #f59e0b4d;font-weight:600}.keyword-token.revealed:hover{background:#f59e0b40}@keyframes tokenPulse{0%,to{opacity:1}50%{opacity:.7}}.study-nav{flex-wrap:wrap;justify-content:center;align-items:center;gap:20px;display:flex}.btn-nav{background:var(--color-surface-2);border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);min-width:110px;padding:12px 28px;font-size:.95rem;font-weight:600}.btn-nav:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary-light);background:#8b5cf61a}.btn-nav:disabled{opacity:.3;cursor:not-allowed}.dot-indicators{flex-wrap:wrap;justify-content:center;gap:6px;max-width:300px;display:flex}.dot{cursor:pointer;width:8px;height:8px;transition:all var(--transition);background:#00000026;border:none;border-radius:50%;padding:0}.dot.dot-active{background:var(--color-primary-light);border-radius:4px;width:24px}.dot:hover{background:#8b5cf680}.keyboard-hint{text-align:center;color:var(--color-text-dim);padding-bottom:8px;font-size:.78rem}html{background:var(--color-bg)}.users-table-wrap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.users-table{border-collapse:collapse;width:100%;font-size:.9rem}.users-table thead tr{border-bottom:1px solid var(--color-border);background:#8b5cf614}.users-table th{text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-dim);padding:14px 16px;font-size:.75rem;font-weight:700}.users-table td{color:var(--color-text);vertical-align:middle;border-bottom:1px solid #8b5cf614;padding:14px 16px}.users-table tbody tr:last-child td{border-bottom:none}.users-table tbody tr:hover{background:#8b5cf60a}.current-user-row td{background:#7c3aed0d}.td-id{color:var(--color-text-dim);font-size:.8rem}.td-username{font-weight:600}.td-date{color:var(--color-text-muted);font-size:.82rem}.username-text{margin-right:6px}.you-badge{color:var(--color-primary-light);vertical-align:middle;background:#8b5cf633;border:1px solid #8b5cf64d;border-radius:999px;padding:1px 6px;font-size:.68rem;font-weight:700}.table-actions{align-items:center;gap:6px;display:flex}.form-select{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:all var(--transition);cursor:pointer;appearance:none;background:#0000000a url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E") right 14px center no-repeat;outline:none;width:100%;padding:12px 36px 12px 14px;font-family:inherit;font-size:.95rem}.form-select:focus{border-color:var(--color-primary-light);box-shadow:0 0 0 3px #8b5cf626}.form-select option{background:var(--color-surface-2);color:var(--color-text)}.bulk-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:28px}.bulk-steps{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);align-items:center;gap:0;margin-bottom:28px;padding:20px 28px;display:flex}.bulk-step{flex:1;align-items:center;gap:10px;display:flex}.bulk-step-circle{background:var(--color-surface-2);border:2px solid var(--color-border);width:34px;height:34px;color:var(--color-text-dim);transition:all var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.bulk-step.active .bulk-step-circle{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));border-color:var(--color-primary);color:#fff;box-shadow:0 0 12px var(--color-primary-glow)}.bulk-step.done .bulk-step-circle{background:var(--color-success);border-color:var(--color-success);color:#fff}.bulk-step-label{color:var(--color-text-dim);white-space:nowrap;transition:color var(--transition);font-size:.85rem;font-weight:600}.bulk-step.active .bulk-step-label{color:var(--color-primary)}.bulk-step.done .bulk-step-label{color:var(--color-success)}.bulk-step-line{background:var(--color-border);border-radius:2px;flex:1;height:2px;margin:0 12px}.upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all var(--transition);background:#8b5cf605;margin-bottom:24px;padding:48px 32px}.upload-zone:hover,.upload-zone.dragover{border-color:var(--color-primary-light);background:#8b5cf60d;transform:scale(1.005)}.upload-zone-icon{margin-bottom:12px;font-size:3rem;animation:3s ease-in-out infinite float}.upload-zone-title{color:var(--color-text);margin-bottom:6px;font-size:1.1rem;font-weight:700}.upload-zone-hint{color:var(--color-text-muted);font-size:.88rem}.bulk-divider{text-align:center;margin:8px 0 20px;position:relative}.bulk-divider:before{content:"";background:var(--color-border);height:1px;position:absolute;top:50%;left:0;right:0}.bulk-divider span{background:var(--color-surface);color:var(--color-text-dim);padding:0 16px;font-size:.82rem;font-weight:500;position:relative}.bulk-paste-area{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);transition:all var(--transition);resize:vertical;background:#00000005;outline:none;padding:14px;font-family:Courier New,Courier,monospace;font-size:.85rem;line-height:1.6}.bulk-paste-area:focus{border-color:var(--color-primary-light);background:#8b5cf608;box-shadow:0 0 0 3px #8b5cf61a}.bulk-format-hint{border-radius:var(--radius-md);color:var(--color-text-muted);background:#3b82f60f;border:1px solid #3b82f633;align-items:flex-start;gap:10px;margin-top:16px;padding:12px 16px;font-size:.84rem;display:flex}.bulk-hint-icon{flex-shrink:0;font-size:1.1rem}.bulk-code-hint{color:var(--color-primary);background:#8b5cf60f;border-radius:4px;margin-top:4px;padding:4px 8px;font-family:Courier New,monospace;font-size:.8rem;display:block}.preview-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.preview-stats{align-items:center;gap:8px;display:flex}.preview-stat-badge{border-radius:999px;padding:4px 12px;font-size:.82rem;font-weight:600}.preview-stat-badge.total{color:var(--color-text-muted);background:#64748b1f;border:1px solid #64748b33}.preview-stat-badge.selected{color:var(--color-primary-light);background:#8b5cf61f;border:1px solid #8b5cf640}.preview-ctrl-actions{gap:8px;display:flex}.btn-sm{padding:6px 14px;font-size:.82rem}.set-selector-bar{border-radius:var(--radius-md);background:#8b5cf60a;border:1px solid #8b5cf626;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;padding:14px 16px;display:flex}.set-selector-label{color:var(--color-text);white-space:nowrap;font-size:.9rem;font-weight:600}.bulk-set-select{flex:1;min-width:200px;max-width:400px;font-size:.9rem}.import-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-md);max-height:480px;margin-bottom:20px;overflow-y:auto}.import-table{border-collapse:collapse;width:100%;font-size:.88rem}.import-table thead th{background:var(--color-surface-2);text-align:left;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;z-index:1;border-bottom:1px solid var(--color-border);padding:10px 14px;font-size:.8rem;font-weight:700;position:sticky;top:0}.import-table tbody tr{transition:background var(--transition);cursor:pointer;border-bottom:1px solid #0000000a}.import-table tbody tr:hover{background:#8b5cf60a}.import-table td{vertical-align:top;padding:10px 14px}.import-row.deselected{opacity:.45}.col-check{text-align:center;width:44px}.col-num{text-align:center;width:44px;color:var(--color-text-dim);font-weight:600}.td-question{color:var(--color-text);max-width:280px;font-weight:600}.td-answer{color:var(--color-text-muted);max-width:340px}.bulk-checkbox{cursor:pointer;width:17px;height:17px;accent-color:var(--color-primary)}.preview-footer{flex-wrap:wrap;justify-content:flex-end;gap:12px;padding-top:8px;display:flex}.import-summary-bar{border-radius:var(--radius-md);background:#8b5cf60a;border:1px solid #8b5cf626;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:14px 16px;display:flex}.import-status-running{color:var(--color-primary);font-size:.95rem;font-weight:600}.import-status-done{color:var(--color-text);font-size:.95rem;font-weight:600}.import-counters{flex-wrap:wrap;gap:8px;display:flex}.import-counter{border-radius:999px;padding:3px 10px;font-size:.82rem;font-weight:600}.import-counter.success{color:var(--color-success);background:#10b9811f;border:1px solid #10b98140}.import-counter.error{color:var(--color-danger);background:#ef44441f;border:1px solid #ef444440}.import-counter.skip{color:var(--color-text-dim);background:#64748b1a;border:1px solid #64748b33}.import-progress-wrap{align-items:center;gap:12px;margin-bottom:20px;display:flex}.import-progress-bar{background:var(--color-surface-2);border-radius:999px;flex:1;height:10px;overflow:hidden}.import-progress-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-primary-light));border-radius:999px;height:100%;transition:width .3s}.import-progress-text{color:var(--color-text-muted);white-space:nowrap;font-size:.82rem;font-weight:600}.import-results-list{flex-direction:column;gap:6px;max-height:520px;margin-bottom:20px;padding-right:4px;display:flex;overflow-y:auto}.import-result-row{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);transition:all var(--transition);align-items:flex-start;gap:12px;padding:12px 14px;display:flex}.import-result-row.status-processing{background:#8b5cf60a;border-color:#8b5cf666}.import-result-row.status-success{background:#10b9810a;border-color:#10b98159}.import-result-row.status-error{background:#ef44440a;border-color:#ef444459}.import-result-row.status-skipped{opacity:.45}.result-num{min-width:24px;color:var(--color-text-dim);padding-top:2px;font-size:.78rem;font-weight:700}.result-status-icon{justify-content:center;align-items:center;min-width:28px;padding-top:1px;font-size:1rem;display:flex}.result-content{flex:1;min-width:0}.result-question{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;margin-bottom:3px;font-size:.88rem;font-weight:600;overflow:hidden}.result-answer{color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;overflow:hidden}.result-error-msg{color:var(--color-danger);margin-top:4px;font-size:.8rem}.result-label{text-align:right;min-width:90px}.status-label{border-radius:999px;padding:3px 10px;font-size:.78rem;font-weight:600}.status-label.pending{color:var(--color-text-dim);background:#64748b1a}.status-label.processing{color:var(--color-primary-light);background:#8b5cf61f;animation:1.2s ease-in-out infinite pulse}.status-label.success{color:var(--color-success);background:#10b9811f}.status-label.error{color:var(--color-danger);background:#ef44441f}.status-label.skipped{color:var(--color-text-dim);background:#64748b1a}.set-selector-section{margin-bottom:20px}.set-selector-bar{border-radius:var(--radius-md) var(--radius-md) 0 0;margin-bottom:0}.set-selector-section:not(:has(.create-set-inline)) .set-selector-bar{border-radius:var(--radius-md);margin-bottom:20px}.set-selector-row{flex-wrap:wrap;flex:1;align-items:center;gap:10px;display:flex}.no-sets-hint{color:var(--color-text-muted);font-size:.88rem;font-style:italic}.btn-create-set-toggle{border-radius:var(--radius-sm);color:var(--color-primary-light);cursor:pointer;transition:all var(--transition);white-space:nowrap;background:#8b5cf614;border:1px solid #8b5cf64d;flex-shrink:0;align-items:center;gap:6px;padding:7px 16px;font-size:.85rem;font-weight:600;display:inline-flex}.btn-create-set-toggle:hover{border-color:var(--color-primary);background:#8b5cf626}.btn-create-set-toggle.active{color:var(--color-danger);background:#ef444414;border-color:#ef44444d}.btn-create-set-toggle.active:hover{background:#ef444424}.create-set-inline{border-radius:0 0 var(--radius-md) var(--radius-md);background:#8b5cf608;border:1px solid #8b5cf633;border-top:none;margin-bottom:20px;padding:20px;animation:.2s slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.create-set-inline-header{flex-wrap:wrap;align-items:baseline;gap:12px;margin-bottom:16px;display:flex}.create-set-inline-title{color:var(--color-primary-light);font-size:.95rem;font-weight:700}.create-set-inline-hint{color:var(--color-text-dim);font-size:.8rem}.create-set-inline-fields{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;display:grid}@media (width<=600px){.create-set-inline-fields{grid-template-columns:1fr}}.create-set-inline-actions{justify-content:flex-end;gap:10px;display:flex}.learned-progress-bar-wrap{align-items:center;gap:12px;margin-bottom:10px;display:flex}.learned-progress-bar{background:var(--color-surface-2);border-radius:999px;flex:1;height:8px;overflow:hidden}.learned-progress-fill{background:linear-gradient(90deg,#10b981,#34d399);border-radius:999px;height:100%;transition:width .4s}.learned-progress-label{color:var(--color-success);white-space:nowrap;font-size:.82rem;font-weight:600}.study-nav-center{flex-direction:column;align-items:center;gap:10px;display:flex}.btn-mark-learned{border-radius:var(--radius-md);color:var(--color-success);cursor:pointer;transition:all var(--transition);background:#10b98114;border:1.5px solid #10b98159;align-items:center;gap:6px;padding:8px 20px;font-size:.88rem;font-weight:600;display:inline-flex}.btn-mark-learned:hover{border-color:var(--color-success);background:#10b98126;transform:translateY(-1px)}.btn-mark-learned.is-learned{border-color:var(--color-success);color:var(--color-success);cursor:default;background:#10b98126}@keyframes markFlash{0%{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 16px #10b98100}to{box-shadow:0 0 #10b98100}}.flashcard-container.mark-flash{animation:.6s markFlash}.all-learned-screen{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:60px 20px;display:flex}.all-learned-icon{font-size:5rem;animation:1s infinite alternate bounce}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-12px)}}.all-learned-title{background:linear-gradient(135deg, var(--color-success), #34d399);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.6rem;font-weight:800;line-height:1.3}.all-learned-desc{color:var(--color-text-muted);font-size:.95rem}.all-learned-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:8px;display:flex}.setdetail-learned-wrap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:24px;padding:16px 20px}.setdetail-learned-row{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.setdetail-learned-label{color:var(--color-text-muted);font-size:.88rem}.setdetail-learned-label strong{color:var(--color-success)}.setdetail-learned-pct{color:var(--color-success);font-size:.88rem;font-weight:700}.setdetail-learned-bar{background:var(--color-surface-2);border-radius:999px;height:8px;overflow:hidden}.setdetail-learned-fill{background:linear-gradient(90deg,#10b981,#34d399);border-radius:999px;height:100%;transition:width .4s}.learned-panel-wrap{border-top:1px solid var(--color-border);margin-top:12px;padding-top:10px}.learned-panel-toggle{cursor:pointer;width:100%;color:var(--color-text-muted);transition:color var(--transition);background:0 0;border:none;justify-content:space-between;align-items:center;padding:6px 0;font-size:.88rem;font-weight:600;display:flex}.learned-panel-toggle:hover,.learned-panel-toggle.open{color:var(--color-primary-light)}.learned-panel-chevron{transition:transform var(--transition);font-size:.7rem}.learned-panel{margin-top:10px;animation:.18s slideDown}.learned-panel-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.learned-panel-hint{color:var(--color-text-dim);font-size:.8rem;font-style:italic}.btn-reset-all-learned{border-radius:var(--radius-sm);color:var(--color-danger);cursor:pointer;transition:all var(--transition);background:#ef444412;border:1px solid #ef44444d;align-items:center;gap:6px;padding:5px 14px;font-size:.82rem;font-weight:600;display:inline-flex}.btn-reset-all-learned:hover{border-color:var(--color-danger);background:#ef444424}.learned-panel-list{flex-direction:column;gap:6px;max-height:320px;display:flex;overflow-y:auto}.learned-item{border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition);background:#10b9810a;border:1px solid #10b98133;align-items:flex-start;gap:10px;padding:10px 12px;display:flex}.learned-item:hover{background:#10b98117}.learned-item input{flex-shrink:0;margin-top:2px}.learned-item-content{cursor:pointer;flex-direction:column;flex:1;gap:3px;display:flex}.learned-item-q{color:var(--color-text);font-size:.88rem;font-weight:600}.learned-item-a{color:var(--color-text-muted);font-size:.8rem}.question-number.learned-num{color:var(--color-success);background:#10b98126;border:1px solid #10b9814d}.question-number.learned-num:after{content:"✓";font-size:.6rem;position:absolute;top:-4px;right:-4px}.question-number{position:relative}
