*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #f4f6fb;--color-surface: #ffffff;--color-primary: #4f46e5;--color-primary-hover: #4338ca;--color-primary-light: #ede9fe;--color-secondary: #6b7280;--color-secondary-hover: #4b5563;--color-accent: #0891b2;--color-accent-hover: #0e7490;--color-danger: #dc2626;--color-danger-hover: #b91c1c;--color-success: #16a34a;--color-text: #1e293b;--color-text-light: #64748b;--color-border: #e2e8f0;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .1);--transition: .2s ease}body{font-family:Segoe UI,Tahoma,Arial,system-ui,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.7;min-height:100vh;direction:rtl;text-align:right;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);text-decoration:none;gap:6px;letter-spacing:.01em}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:0 2px 8px #4f46e540}.btn-secondary{background:#f1f5f9;color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:#e2e8f0}.btn-accent{background:var(--color-accent);color:#fff}.btn-accent:hover{background:var(--color-accent-hover);box-shadow:0 2px 8px #0891b240}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:var(--color-danger-hover);box-shadow:0 2px 8px #dc262640}.btn-outline-danger{background:transparent;color:var(--color-danger);border:1.5px solid var(--color-danger)}.btn-outline-danger:hover{background:var(--color-danger);color:#fff}.btn-sm{padding:7px 14px;font-size:.84rem}input[type=text],input[type=email],input[type=password],textarea{width:100%;padding:10px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;transition:border-color var(--transition),box-shadow var(--transition);background:var(--color-surface)}input:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e51a}textarea{resize:vertical}.loading-screen,.error-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.05rem;color:var(--color-text-light);letter-spacing:.01em}.loading-text,.empty-text{text-align:center;color:var(--color-text-light);padding:40px 20px}.home-page{max-width:900px;margin:0 auto;padding:40px 20px;min-height:100vh;display:flex;flex-direction:column}.home-header{text-align:center;margin-bottom:48px}.home-header h1{font-size:2.2rem;font-weight:800;color:var(--color-primary);margin-bottom:8px;letter-spacing:-.02em}.home-header p{color:var(--color-text-light);font-size:1.05rem}.home-user-bar{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:14px;flex-wrap:wrap}.home-user-email{color:var(--color-text-light);font-size:.88rem}.role-badge-home{font-size:.78rem!important}.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.tool-card{background:var(--color-surface);border-radius:var(--radius);padding:28px 24px;box-shadow:var(--shadow);border:1px solid var(--color-border);display:flex;flex-direction:column;gap:12px;transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition)}.tool-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:transparent}.tool-card h3{font-size:1.1rem;font-weight:700}.tool-card p{color:var(--color-text-light);font-size:.88rem;flex:1;line-height:1.6}.tool-card.coming-soon{opacity:.55}.badge-soon{display:inline-block;padding:4px 14px;background:#f1f5f9;border-radius:20px;font-size:.78rem;color:var(--color-text-light);font-weight:600;align-self:flex-start}.home-footer{margin-top:auto;padding:40px 0 18px;text-align:center}.home-footer-logo{height:26px;opacity:.35;transition:opacity .2s}.home-footer-logo:hover{opacity:.6}.home-report-badge{position:absolute;top:10px;left:10px;background:#ef4444;color:#fff;font-size:.75rem;font-weight:700;min-width:22px;height:22px;line-height:22px;text-align:center;border-radius:50px;padding:0 6px;box-shadow:0 2px 6px #ef444466}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;right:-20%;width:600px;height:600px;background:#ffffff0f;border-radius:50%;pointer-events:none}.login-page:after{content:"";position:absolute;bottom:-30%;left:-15%;width:450px;height:450px;background:#ffffff0a;border-radius:50%;pointer-events:none}.login-card{position:relative;z-index:1;width:100%;max-width:420px;animation:loginFadeIn .5s ease-out}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.site-footer{display:flex;flex-direction:column;align-items:center;gap:6px;padding:1.5rem 1rem;color:#ffffff73;font-size:.75rem}.site-footer-logo{height:28px;width:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.35}.login-form{background:var(--color-surface);padding:36px 32px 32px;border-radius:20px;box-shadow:0 20px 60px #00000026,0 1px 3px #00000014;width:100%;display:flex;flex-direction:column;gap:20px}.login-header{text-align:center}.login-header h2{font-size:1.45rem;font-weight:700;color:var(--color-text);margin-bottom:4px}.login-subtitle{font-size:.9rem;color:var(--color-text-light)}.login-error{display:flex;align-items:center;gap:8px;background:#fef2f2;color:var(--color-danger);padding:12px 16px;border-radius:12px;font-size:.88rem;border:1px solid #fecaca;line-height:1.5}.login-error svg{flex-shrink:0}.error-msg{background:#fef2f2;color:var(--color-danger);padding:10px 14px;border-radius:var(--radius-sm);font-size:.9rem;text-align:center}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:.85rem;font-weight:600;color:var(--color-text);padding-inline-start:2px}.login-input-wrap{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;inset-inline-start:14px;color:var(--color-text-light);pointer-events:none;flex-shrink:0;transition:color var(--transition)}.login-input-wrap:focus-within .login-input-icon{color:var(--color-primary)}.login-input-wrap input{width:100%;padding:12px 14px 12px 44px;padding-inline-start:44px;padding-inline-end:14px;border:1.5px solid var(--color-border);border-radius:12px;font-size:.95rem;color:var(--color-text);background:var(--color-bg);transition:border-color var(--transition),box-shadow var(--transition);outline:none}.login-input-wrap input::placeholder{color:#b0b7c3}.login-input-wrap input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e51f;background:var(--color-surface)}.login-input-wrap input[type=password],.login-input-wrap input.has-toggle{padding-inline-end:44px}.login-toggle-pass{position:absolute;inset-inline-end:10px;background:none;border:none;cursor:pointer;color:var(--color-text-light);padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:color var(--transition),background var(--transition)}.login-toggle-pass:hover{color:var(--color-primary);background:#4f46e50f}.login-submit{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px 20px;border:none;border-radius:12px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,opacity .2s ease;box-shadow:0 4px 14px #667eea59;margin-top:4px}.login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #667eea73}.login-submit:active:not(:disabled){transform:translateY(0)}.login-submit:disabled{opacity:.7;cursor:not-allowed}.login-spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:loginSpin .6s linear infinite}@keyframes loginSpin{to{transform:rotate(360deg)}}.login-contact-note{text-align:center;font-size:.82rem;color:var(--color-text-light);line-height:1.7}@media(max-width:480px){.login-form{padding:28px 20px 24px;border-radius:16px}.login-card{max-width:100%}}.admin-page,.deck-editor-page{max-width:900px;margin:0 auto;padding:32px 20px}.admin-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;flex-wrap:wrap;gap:12px}.admin-header h1{font-size:1.6rem;font-weight:800;letter-spacing:-.01em}.editable-title{cursor:pointer}.editable-title .edit-hint{font-size:.7rem;opacity:0;transition:opacity .2s}.editable-title:hover .edit-hint{opacity:.5}.back-link{display:inline-flex;align-items:center;gap:4px;color:var(--color-primary);text-decoration:none;font-size:.9rem;font-weight:500;margin-bottom:8px;transition:color var(--transition)}.back-link:hover{color:var(--color-primary-hover);text-decoration:underline}.create-deck-form{display:flex;gap:12px;margin-bottom:32px}.create-deck-form input{flex:1}.create-error-msg{color:var(--color-danger);font-size:.85rem;margin-top:-20px;margin-bottom:16px}.deck-list{display:flex;flex-direction:column;gap:12px}.deck-item{background:var(--color-surface);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow);border:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;transition:box-shadow var(--transition),border-color var(--transition)}.deck-item:hover{box-shadow:var(--shadow-md);border-color:transparent}.deck-info{flex:1;min-width:150px}.deck-info h3{font-size:1.05rem;font-weight:600;margin-bottom:2px}.card-count{font-size:.85rem;color:var(--color-text-light)}.deck-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.owner-badge{font-size:.75rem;color:var(--color-text-light);background:#f0f0f5;padding:2px 8px;border-radius:10px;white-space:nowrap;direction:ltr}.filter-bar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:16px;padding:10px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.filter-bar label{font-size:.9rem;color:var(--color-text-light);white-space:nowrap}.owner-filter-bar{display:flex;align-items:center;gap:10px}.owner-filter-bar select{padding:6px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.88rem;background:var(--color-bg);color:var(--color-text);direction:ltr;min-width:200px}.type-filter-bar{display:flex;align-items:center;gap:10px}.deck-type-icon{margin-left:5px;font-size:.9em}.inline-dropdown-wrapper{position:relative;display:inline-block}.inline-dropdown{position:absolute;top:100%;left:50%;transform:translate(-50%);z-index:100;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:0 4px 16px #0000001f;min-width:160px;padding:4px 0;margin-top:4px}.inline-dropdown button{display:block;width:100%;text-align:right;padding:8px 14px;border:none;background:none;font-size:.85rem;color:var(--color-text);cursor:pointer;white-space:nowrap}.inline-dropdown button:hover{background:var(--color-bg)}.deck-actions{display:flex;gap:8px;flex-wrap:wrap}.edit-inline{display:flex;gap:8px;align-items:center}.edit-inline input{width:auto;max-width:250px}.order-arrows{display:flex;flex-direction:column;gap:2px}.btn-order{padding:2px 8px!important;font-size:10px!important;line-height:1;background:var(--color-bg)!important;border:1px solid var(--color-border)!important;color:var(--color-text-secondary)!important;border-radius:4px!important;cursor:pointer;transition:background .15s,color .15s}.btn-order:hover:not(:disabled){background:var(--color-primary)!important;color:#fff!important}.btn-order:disabled{opacity:.3;cursor:not-allowed}.dots-menu-wrapper{position:relative}.dots-menu-btn{background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);width:34px;height:34px;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-light);transition:background var(--transition);line-height:1}.dots-menu-btn:hover{background:var(--color-border)}.dots-menu{position:absolute;top:100%;left:0;margin-top:4px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);min-width:140px;z-index:100;overflow:hidden}.dots-menu button{display:block;width:100%;padding:10px 16px;border:none;background:none;text-align:right;font-size:.9rem;cursor:pointer;color:var(--color-text);transition:background var(--transition)}.dots-menu button:hover{background:var(--color-bg)}.dots-menu-danger{color:var(--color-danger)!important}.dots-menu-danger:hover{background:#fef2f2!important}.dots-menu-divider{height:1px;background:var(--color-border);margin:6px 0}.dots-menu-section-title{padding:6px 16px 2px;font-size:.75rem;font-weight:700;color:var(--color-text-muted);text-align:right}.dots-menu-toggle{display:flex;align-items:center;gap:8px;padding:8px 16px;cursor:pointer;font-size:.85rem;white-space:nowrap}.dots-menu-toggle:hover{background:var(--color-bg)}.dots-menu-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.dots-menu-link{display:block;width:100%;padding:8px 16px;text-align:right;font-size:.9rem;color:var(--color-text);text-decoration:none}.dots-menu-link:hover{background:var(--color-bg)}.reverse-sync-alert{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;margin:0 0 12px;background:#fef3cd;border:1px solid #ffc107;border-radius:8px;font-size:.9rem;color:#856404}.editor-header-actions{display:flex;gap:8px;align-items:center}.save-btn{transition:background .2s,opacity .2s}.save-btn:disabled{opacity:.5;cursor:default;background:#a0aec0}.save-btn-active{animation:savePulse 1.5s ease-in-out infinite}@keyframes savePulse{0%,to{box-shadow:0 0 #6366f166}50%{box-shadow:0 0 0 6px #6366f100}}.leave-modal{background:#fff;border-radius:var(--radius);padding:28px 32px;max-width:420px;width:90%;margin:auto;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 8px 30px #00000026;text-align:center}.leave-modal h3{font-size:1.15rem;font-weight:600;margin:0 0 8px}.leave-modal p{font-size:.9rem;color:var(--color-text-light);margin:0 0 20px}.leave-modal-actions{display:flex;flex-direction:column;gap:8px}.leave-modal-actions .btn{width:100%}.editor-section{margin-bottom:40px}.editor-section h2{font-size:1.2rem;font-weight:700;margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--color-border)}.simple-editor{border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;background:#fff}.se-toolbar{display:flex;gap:2px;padding:4px 6px;background:#f8f8fb;border-bottom:1px solid var(--color-border)}.se-btn{width:30px;height:28px;border:1px solid transparent;border-radius:4px;background:transparent;cursor:pointer;font-size:.85rem;font-weight:700;color:var(--color-text);display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.se-btn:hover{background:#eee;border-color:#ddd}.se-btn-bold{font-family:serif}.se-btn-underline{text-decoration:underline;font-family:serif}.se-btn-color{font-family:serif;font-weight:700}.se-btn-align{font-size:.7rem;font-weight:400;letter-spacing:-1px}.se-sep{width:1px;height:18px;background:#ddd;margin:0 4px;align-self:center}.se-content{padding:10px 12px;min-height:4.5em;outline:none;font-size:.95rem;line-height:1.7;direction:rtl;text-align:right;white-space:pre-wrap;word-wrap:break-word}.se-content:empty:before{content:attr(data-placeholder);color:#aaa;pointer-events:none}.se-btn-source{margin-right:auto;font-size:.7rem;font-family:monospace;color:#888}.se-btn-source.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.se-source{width:100%;padding:10px 12px;border:none;outline:none;font-family:monospace;font-size:.85rem;line-height:1.6;resize:vertical;background:#1e1e2e;color:#cdd6f4;direction:ltr;text-align:left;box-sizing:border-box}.se-content mark{background:#fef3c7;color:inherit;padding:0 2px;border-radius:2px}.fmt-red{color:#c0392b}.fmt-blue{color:#2563eb}.fmt-green{color:#16a34a}.fmt-left{text-align:left;direction:ltr}.fmt-center{text-align:center}.fmt-right{text-align:right;direction:rtl}.card-form{background:var(--color-surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);border:1px solid var(--color-border);display:flex;flex-direction:column;gap:20px}.card-side-input label{display:block;font-weight:600;margin-bottom:8px;font-size:.9rem;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.5px}.type-toggle{display:flex;gap:0;margin-bottom:10px}.toggle-btn{padding:6px 16px;border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;font-size:.85rem;transition:all var(--transition)}.toggle-btn:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.toggle-btn:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0;border-left:none}.toggle-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.image-input{display:flex;flex-direction:column;gap:10px}.image-preview{max-width:200px;max-height:150px;border-radius:var(--radius-sm);object-fit:contain;border:1px solid var(--color-border)}.card-form-actions{display:flex;gap:10px}.cards-list{display:flex;flex-direction:column;gap:16px}.card-item{background:var(--color-surface);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border:1px solid var(--color-border);transition:box-shadow var(--transition)}.card-item:hover{box-shadow:var(--shadow-md)}.card-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.card-number{font-weight:600;color:var(--color-text-light);font-size:.9rem}.card-item-actions{display:flex;gap:8px}.card-preview{display:grid;grid-template-columns:1fr 1fr;gap:16px}.card-preview-side{padding:12px;background:var(--color-bg);border-radius:var(--radius-sm)}.card-preview-side strong{display:block;font-size:.8rem;color:var(--color-text-light);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.card-preview-side img{max-width:100%;max-height:120px;border-radius:4px;object-fit:contain}.card-preview-side p{font-size:.95rem;word-break:break-word}.embed-container{display:flex;flex-direction:column;align-items:center;padding:24px 16px;min-height:100vh;background:var(--color-bg)}.embed-loading,.embed-error{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1rem;color:var(--color-text-light)}.embed-deck-title{font-size:1.1rem;font-weight:600;color:var(--color-text);margin-bottom:20px;text-align:center}.embed-card-wrapper{perspective:1000px;width:100%;max-width:480px;height:300px;cursor:pointer;margin-bottom:16px;animation:cardSlideIn .3s ease}@keyframes cardSlideIn{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}.embed-card{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .5s ease}.embed-card.flipped{transform:rotateY(180deg)}.embed-card-face{position:absolute;width:100%;height:100%;backface-visibility:hidden;display:flex;align-items:center;justify-content:center;padding:24px;border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:auto;text-align:center}.embed-card-front{background:var(--color-surface);border:1px solid var(--color-border)}.embed-card-back{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;transform:rotateY(180deg);border:none}.embed-card-face p{font-size:1.2rem;line-height:1.5;word-break:break-word}.embed-card-face img{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius-sm)}.study-progress{width:100%;max-width:480px;margin-bottom:8px;display:flex;flex-direction:row;align-items:center;gap:10px}.study-progress-counter{display:flex;flex-direction:row;align-items:center;gap:4px;white-space:nowrap}.study-progress-label{font-size:.68rem;color:var(--color-text-light);opacity:.6}.study-progress-text{font-size:.88rem;font-weight:700;color:var(--color-text);white-space:nowrap;font-variant-numeric:tabular-nums;direction:ltr;unicode-bidi:isolate}.study-progress-bar{flex:1;height:10px;background:var(--color-border);border-radius:99px;overflow:hidden}.study-progress-fill{height:100%;background:var(--color-primary);border-radius:99px;transition:width .2s ease}.embed-hint{font-size:.85rem;color:var(--color-text-light);margin-bottom:16px;min-height:1.3em}.study-actions{display:flex;gap:16px;width:100%;max-width:480px;margin-bottom:16px}.study-btn{flex:1;padding:16px 20px;font-size:1.1rem;font-weight:700;border-radius:var(--radius);border:none;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.study-btn:hover{transform:translateY(-2px)}.study-btn:active{transform:translateY(0)}.study-btn-wrong{background:#dc2626;color:#fff}.study-btn-wrong:hover{box-shadow:0 4px 14px #dc26264d}.study-btn-knew{background:#16a34a;color:#fff}.study-btn-knew:hover{box-shadow:0 4px 14px #16a34a4d}.study-remaining{font-size:.85rem;color:var(--color-text-light);margin-top:4px}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:1000}.confetti-piece{position:absolute;left:var(--ox);top:var(--oy);width:var(--size, 10px);height:var(--size, 10px);background:var(--color);border-radius:var(--br, 2px);animation:fireworkBurst var(--dur, 1.8s) ease-out var(--delay) forwards}@keyframes fireworkBurst{0%{transform:translate(0) rotate(0) scale(.3);opacity:0}8%{transform:translate(0) rotate(0) scale(1.2);opacity:1}15%{transform:translate(calc(var(--tx) * .1),calc(var(--ty) * .1)) rotate(30deg) scale(1);opacity:1}70%{opacity:.9}to{transform:translate(var(--tx),var(--ty)) rotate(var(--rot, 720deg)) scale(0);opacity:0}}.finish-mistakes{font-size:1rem;color:var(--color-text-light);margin-bottom:8px}.quiz-settings{max-width:700px;margin:0 auto 20px;padding:14px 20px;background:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.95rem;font-weight:500;color:var(--color-text)}.toggle-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.finish-screen{text-align:center;background:var(--color-surface);padding:48px 36px;border-radius:16px;box-shadow:var(--shadow-lg);max-width:460px;width:100%;border:1px solid var(--color-border)}.finish-icon{font-size:3.2rem;margin-bottom:16px}.finish-title{font-size:1.45rem;font-weight:800;color:var(--color-text);margin-bottom:24px;line-height:1.6;letter-spacing:-.01em}.finish-time{display:flex;align-items:center;justify-content:center;gap:8px;font-size:1.05rem;color:var(--color-text-light);margin-bottom:32px}.finish-time-icon{font-size:1.2rem}.finish-buttons{display:flex;flex-direction:column;align-items:center;gap:10px}.finish-btn{background:var(--color-primary);color:#fff;padding:12px 28px;font-size:1rem;font-weight:600;border-radius:var(--radius-sm);text-decoration:none;text-align:center;transition:background var(--transition),box-shadow var(--transition),transform var(--transition)}.finish-btn:hover{background:var(--color-primary-hover);box-shadow:0 4px 14px #4f46e54d;transform:translateY(-1px)}.finish-logo-link{display:block;margin:64px auto 20px;text-align:center;cursor:pointer;transition:opacity .2s;opacity:.33}.finish-logo-link:hover{opacity:.55}.finish-logo{display:block;max-width:80px;height:auto;margin:0 auto}.btn-preview{background:#8b5cf6;color:#fff}.btn-preview:hover{background:#7c3aed}.preview-overlay{position:fixed;inset:0;background:#0f172a80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.preview-modal{background:var(--color-surface);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:540px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.preview-modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--color-border);font-weight:600}.preview-modal-actions{display:flex;gap:8px;align-items:center}.preview-iframe{width:100%;height:650px;border:none}.mcq-options-editor{display:flex;flex-direction:column;gap:10px}.mcq-option-row{display:flex;align-items:center;gap:10px}.mcq-radio{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.mcq-remove-opt{background:none;border:none;color:var(--color-danger);cursor:pointer;font-size:1.1rem;padding:4px;flex-shrink:0;opacity:.6;transition:opacity var(--transition)}.mcq-remove-opt:hover{opacity:1}.mcq-question-preview{display:flex;flex-direction:column;gap:12px}.mcq-q-content img{max-width:100%;max-height:200px;border-radius:var(--radius-sm);object-fit:contain}.mcq-q-content p{font-size:1rem;line-height:1.5}.mcq-options-preview{display:flex;flex-direction:column;gap:6px}.mcq-opt-preview{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--color-bg);border-radius:var(--radius-sm);font-size:.9rem}.mcq-opt-preview.correct{background:#dcfce7}.mcq-opt-letter{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--color-border);font-weight:600;font-size:.8rem;flex-shrink:0}.mcq-correct-badge{margin-right:auto;margin-left:0;color:#16a34a;font-weight:700}.mcq-brand-header{font-size:1.3rem;font-weight:700;color:var(--color-primary);text-align:center;margin-bottom:8px}.mcq-player-header{width:100%;max-width:560px;display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.mcq-subtitle{font-size:.95rem;font-weight:600;color:var(--color-text)}.mcq-quiz-title{font-size:1.1rem;font-weight:600}.mcq-timer{font-size:.95rem;color:var(--color-text-light);font-variant-numeric:tabular-nums}.mcq-question-card{width:100%;max-width:560px;background:var(--color-surface);border-radius:14px;box-shadow:var(--shadow-md);border:1px solid var(--color-border);padding:20px 20px 22px;margin-bottom:14px}@keyframes cardEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes cardExit{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.mcq-question-card.card-enter{animation:cardEnter .2s ease forwards}.mcq-question-card.card-exit{animation:cardExit .15s ease forwards}.mcq-q-number{font-size:.85rem;color:var(--color-text-light);margin-bottom:16px;font-weight:500}.mcq-q-body{margin-bottom:18px}.mcq-q-body p{font-size:1.15rem;font-weight:700;line-height:1.6;color:#1e293b}.mcq-q-body img{max-width:100%;max-height:250px;border-radius:var(--radius-sm);object-fit:contain}.mcq-options-list{display:flex;flex-direction:column;gap:12px}.mcq-option-btn{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;border:1.5px solid #e5e7eb;border-radius:10px;background:var(--color-surface);cursor:pointer;font-size:1rem;text-align:right;transition:transform .12s ease,border-color .15s,box-shadow .15s,background .15s;-webkit-tap-highlight-color:transparent;outline:none}.mcq-option-btn:hover:not(.locked){border-color:var(--color-primary);box-shadow:0 1px 4px #6366f11f}.mcq-option-btn:active:not(.locked){transform:scale(.98);border-color:var(--color-primary);background:#f5f3ff}.mcq-option-btn:focus,.mcq-option-btn:focus-visible{outline:none;box-shadow:none}.mcq-option-btn.locked{cursor:default;opacity:.7}.mcq-option-btn.locked:hover{border-color:var(--color-border);background:var(--color-surface)}.mcq-option-btn.locked.selected{opacity:1}.mcq-option-btn.locked.selected:hover{border-color:var(--color-border);background:var(--color-surface)}.mcq-option-btn.opt-correct-live{border-color:#16a34a!important;background:#dcfce7!important;opacity:1!important}.mcq-option-btn.opt-wrong-live{border-color:#dc2626!important;background:#fee2e2!important;opacity:1!important}.mcq-continue-btn{display:block;width:60%;margin:20px auto 0;padding:14px 24px;background:#dc2626;color:#fff;border:none;border-radius:var(--radius);font-size:1.1rem;font-weight:700;cursor:pointer;box-shadow:0 3px 10px #dc26264d;transition:transform .15s ease,box-shadow .15s ease,background .15s}.mcq-continue-btn:hover{background:#b91c1c;transform:translateY(-2px);box-shadow:0 5px 16px #dc262666}.mcq-continue-btn:active{transform:translateY(0)}.mcq-continue-btn.correct{background:#16a34a;box-shadow:0 3px 10px #16a34a4d}.mcq-continue-btn.correct:hover{background:#15803d;box-shadow:0 5px 16px #16a34a66}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-6px)}30%{transform:translate(6px)}45%{transform:translate(-4px)}60%{transform:translate(4px)}75%{transform:translate(-2px)}90%{transform:translate(2px)}}.mcq-question-card.shake{animation:shake .4s ease}.mode-toggle-group{display:flex;gap:8px;width:100%}.mode-toggle-btn{flex:1;padding:10px 16px;border:2px solid var(--color-border);border-radius:8px;background:var(--color-surface);color:var(--color-text-light);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.mode-toggle-btn:hover{border-color:var(--color-primary-light)}.mode-toggle-btn.active{border-color:var(--color-primary);background:#ede9fe;color:var(--color-primary)}.mode-badge{display:inline-block;font-size:.75rem;font-weight:600;padding:2px 10px;border-radius:12px;margin-right:8px}.mode-exam{background:#ede9fe;color:var(--color-primary)}.mode-training{background:#dcfce7;color:#16a34a}.mcq-nav{width:100%;max-width:560px;display:flex;align-items:center;justify-content:space-between;gap:12px}.mcq-dots{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.mcq-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--color-border);background:transparent;cursor:pointer;padding:0;transition:all var(--transition)}.mcq-dot.answered{background:var(--color-primary);border-color:var(--color-primary)}.mcq-dot.active{border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e533}.mcq-score-display{margin-bottom:24px}.mcq-score-circle{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),#7c3aed);display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.mcq-score-number{color:#fff;font-size:1.6rem;font-weight:700}.mcq-score-detail{color:var(--color-text-light);font-size:1rem}.mcq-review{width:100%;max-width:560px;margin-top:32px}.mcq-review h3{font-size:1.1rem;font-weight:600;margin-bottom:16px;text-align:center}.mcq-review-item{background:var(--color-surface);border-radius:var(--radius);padding:20px;margin-bottom:12px;border-right:4px solid var(--color-border)}.mcq-review-item.review-correct{border-right-color:#16a34a}.mcq-review-item.review-wrong{border-right-color:#dc2626}.mcq-review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.mcq-review-num{font-weight:600;color:var(--color-text-light)}.mcq-review-badge{font-size:.8rem;font-weight:600;padding:3px 10px;border-radius:20px}.badge-correct{background:#dcfce7;color:#16a34a}.badge-wrong{background:#fef2f2;color:#dc2626}.mcq-review-question{margin-bottom:12px}.mcq-review-question p{font-weight:600;line-height:1.5}.mcq-review-question img{max-width:100%;max-height:180px;border-radius:var(--radius-sm);object-fit:contain}.mcq-review-options{display:flex;flex-direction:column;gap:6px}.mcq-review-opt{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);font-size:.9rem;background:var(--color-bg)}.mcq-review-opt.opt-correct{background:#dcfce7}.mcq-review-opt.opt-correct .mcq-opt-letter{background:#16a34a;color:#fff}.mcq-review-opt.opt-wrong{background:#fef2f2}.mcq-review-opt.opt-wrong .mcq-opt-letter{background:#dc2626;color:#fff}@media(max-width:600px){.home-header h1{font-size:1.6rem}.tools-grid{grid-template-columns:1fr}.deck-item{flex-direction:column;align-items:flex-start}.deck-actions{width:100%}.card-preview{grid-template-columns:1fr}.create-deck-form{flex-direction:column}.embed-card-wrapper{height:250px}.embed-card-face p{font-size:1.15rem}.admin-header{flex-direction:column}.mcq-question-card{padding:20px 16px}.mcq-q-body p{font-size:1.1rem}.mcq-nav{flex-wrap:wrap;justify-content:center}.mcq-score-circle{width:80px;height:80px}.mcq-score-number{font-size:1.3rem}}.question-footer{display:flex;justify-content:flex-end;width:100%;max-width:560px;padding:2px 4px 0;margin-top:-8px}.report-error-btn{display:inline;padding:2px 0;font-size:.65rem;color:#c4c8cf;background:none;border:none;cursor:pointer;transition:color .2s;line-height:1.4}.report-error-btn:hover{color:#6b7280}.report-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;display:flex;align-items:center;justify-content:center}.report-modal{background:#fff;border-radius:16px;padding:24px 28px;max-width:380px;width:90%;box-shadow:var(--shadow-lg);direction:rtl}.report-title{font-size:1rem;font-weight:600;margin:0 0 16px;text-align:center}.report-options{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.report-radio-label{display:flex;align-items:center;gap:8px;font-size:.88rem;cursor:pointer}.report-radio-label input[type=radio]{accent-color:var(--color-primary)}.report-note{width:100%;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;resize:vertical;margin-bottom:14px;font-family:inherit}.report-actions{display:flex;gap:8px;justify-content:center}.report-success{text-align:center;padding:20px 0}.report-success-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:#d1fae5;color:#059669;font-size:1.4rem;font-weight:700;margin-bottom:10px}.report-success p{font-size:.9rem;color:var(--color-text-secondary);margin:0}.admin-header-actions{display:flex;gap:8px;align-items:center}.admin-user-name{font-size:.88rem;color:var(--color-text-light);padding-left:8px;border-left:1px solid var(--color-border)}.reports-pending-badge{display:inline-block;background:#fef2f2;color:#dc2626;padding:2px 10px;border-radius:12px;font-size:.78rem;font-weight:500;margin-right:8px}.reports-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}.reports-filters select{padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;background:#fff;font-family:inherit;min-width:140px}.reports-table-wrapper{overflow-x:auto}.reports-table{width:100%;border-collapse:collapse;font-size:.85rem}.reports-table th,.reports-table td{padding:10px 12px;border-bottom:1px solid var(--color-border);text-align:right;vertical-align:middle}.reports-table th{background:#f8fafc;font-weight:600;font-size:.8rem;color:var(--color-text-light);white-space:nowrap}.reports-table tr:hover{background:#f8fafc}.report-resolved{opacity:.55}.report-status-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.75rem;font-weight:500;white-space:nowrap}.report-status-badge.pending{background:#fef2f2;color:#dc2626}.report-status-badge.resolved{background:#f0fdf4;color:#16a34a}.report-note-cell{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.report-date-cell{white-space:nowrap;font-size:.78rem;color:var(--color-text-light)}.report-actions-cell{display:flex;gap:6px;flex-wrap:nowrap}.btn-success{background:#16a34a;color:#fff;border:none}.btn-success:hover{background:#15803d}.report-count-badge{display:inline-block;font-size:.7rem;background:#fef2f2;color:#dc2626;padding:1px 7px;border-radius:10px;margin-right:6px;font-weight:500;vertical-align:middle;text-decoration:none;cursor:pointer;transition:background .2s}.report-count-badge:hover{background:#fee2e2}@media(max-width:700px){.reports-filters{flex-direction:column}.reports-filters select{width:100%}.reports-table{font-size:.78rem}.reports-table th,.reports-table td{padding:8px 6px}}.questions-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:4px}.sort-select{padding:5px 10px;border:1px solid var(--color-border);border-radius:8px;font-size:.85rem;background:var(--color-bg);color:var(--color-text);cursor:pointer}.stat-badge{font-size:.72rem;padding:2px 8px;border-radius:10px;font-weight:600;white-space:nowrap}.stat-badge-success{background:#dcfce7;color:#16a34a}.stat-badge-warning{background:#fef9c3;color:#a16207}.stat-badge-danger{background:#fee2e2;color:#dc2626}.stat-badge-info{background:#dbeafe;color:#2563eb}.stat-badge-neutral{background:#f3f4f6;color:#6b7280}.question-stats-box{display:flex;flex-wrap:wrap;gap:10px;align-items:center;padding:8px 12px;margin-top:8px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;font-size:.8rem;color:var(--color-text-light)}.question-stats-box .stats-label{font-weight:600;color:var(--color-text)}.question-stats-box .stats-correct{color:#16a34a}.question-stats-box .stats-wrong{color:#dc2626}.stats-reset-link{margin-right:auto;background:none;border:none;color:#999;font-size:.7rem;cursor:pointer;padding:2px 6px;border-radius:4px;transition:color .15s,background .15s}.stats-reset-link:hover{color:var(--color-danger);background:#fee2e2}.stats-reset-link:disabled{opacity:.5;cursor:default}@media(max-width:600px){.question-stats-box{font-size:.73rem;gap:6px;padding:6px 8px}}.inline-reports{margin-top:8px;padding:10px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px}.inline-reports-title{font-size:.8rem;font-weight:600;color:#dc2626;margin-bottom:8px}.inline-report-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:6px 0;border-top:1px solid #fee2e2}.inline-report-row:first-of-type{border-top:none;padding-top:0}.inline-report-type{font-size:.78rem;color:#991b1b;font-weight:500}.inline-report-note{font-size:.75rem;color:#6b7280;font-style:italic}.inline-report-row .btn-success{margin-inline-start:auto}.highlight-flash{animation:highlightPulse 2s ease-out}@keyframes highlightPulse{0%{box-shadow:0 0 0 4px #3b82f680}to{box-shadow:none}}@media(max-width:600px){.inline-reports{padding:8px}.inline-report-row{font-size:.73rem;gap:6px}}.import-overlay{position:fixed;inset:0;background:#00000080;z-index:900;display:flex;align-items:flex-start;justify-content:center;padding:24px 16px;overflow-y:auto}.import-modal{background:var(--color-bg);border-radius:14px;width:100%;max-width:780px;padding:24px;box-shadow:0 12px 40px #0003;position:relative}.import-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.import-modal-header h2{font-size:1.15rem;margin:0}.import-modal--wide{max-width:920px}.import-new-body{display:flex;gap:16px;min-height:380px}.import-groups-panel{width:220px;flex-shrink:0;border:1px solid var(--color-border);border-radius:10px;overflow:hidden;display:flex;flex-direction:column}.import-panel-title{font-size:.85rem;font-weight:600;padding:10px 14px;margin:0;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.import-groups-list{overflow-y:auto;flex:1}.import-group-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 14px;border:none;background:none;cursor:pointer;font-size:.84rem;text-align:right;border-bottom:1px solid var(--color-border);transition:background .15s}.import-group-btn:hover{background:#6366f10f}.import-group-btn.active{background:#6366f11f;font-weight:600;color:var(--color-primary)}.import-group-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-group-arrow{font-size:.75rem;opacity:.4}.import-group-btn.active .import-group-arrow{opacity:1}.import-items-panel{flex:1;display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:10px;overflow:hidden}.import-items-placeholder{flex:1;display:flex;align-items:center;justify-content:center;color:var(--color-text-light);font-size:.88rem}.import-items-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--color-surface);border-bottom:1px solid var(--color-border);font-size:.84rem}.import-items-count{font-weight:600}.import-items-header-actions{display:flex;align-items:center;gap:12px}.import-stats-toggle{display:flex;align-items:center;gap:4px;cursor:pointer;font-size:.82rem}.stat-badge-sm{font-size:.72rem!important;padding:1px 6px!important;white-space:nowrap;flex-shrink:0}.import-items-list{overflow-y:auto;flex:1;max-height:340px}.import-item-row{display:flex;align-items:center;gap:8px;padding:8px 14px;border-bottom:1px solid var(--color-border);font-size:.83rem;transition:background .12s}.import-item-row:hover{background:#6366f10a}.import-item-row--selected{background:#6366f114}.import-item-num{color:var(--color-text-light);font-size:.78rem;min-width:28px}.import-item-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.import-loading-text,.import-empty-text{padding:20px 14px;text-align:center;color:var(--color-text-light);font-size:.85rem}.import-inline-preview{margin-top:14px;border:1px solid var(--color-border);border-radius:10px;overflow:hidden}.import-inline-preview-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:var(--color-surface);border-bottom:1px solid var(--color-border);font-size:.84rem}.import-inline-preview-body{padding:14px}.import-confirm-overlay{position:fixed;inset:0;background:#00000073;z-index:960;display:flex;align-items:center;justify-content:center;padding:24px}.import-confirm-box{background:var(--color-bg);border-radius:12px;padding:28px;max-width:400px;width:100%;text-align:center;box-shadow:0 8px 30px #0003}.import-confirm-box h3{margin:0 0 12px;font-size:1.1rem}.import-confirm-box p{margin:0 0 6px;font-size:.9rem}.import-confirm-note{color:var(--color-text-light);font-size:.85rem!important;margin-bottom:18px!important}.import-confirm-actions{display:flex;gap:10px;justify-content:center}.import-select-all{display:flex;align-items:center;gap:6px;font-size:.82rem;cursor:pointer}.import-table-wrapper{overflow-x:auto;border:1px solid var(--color-border);border-radius:10px}.import-table{width:100%;border-collapse:collapse;font-size:.84rem}.import-table th{background:var(--color-surface);padding:10px 12px;text-align:right;font-weight:600;border-bottom:1px solid var(--color-border);white-space:nowrap}.import-table td{padding:10px 12px;border-bottom:1px solid var(--color-border);vertical-align:middle}.import-table tbody tr:hover{background:#6366f10a}.import-row-selected{background:#6366f114!important}.import-item-label{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-preview-btn{padding:2px 8px!important;font-size:.9rem!important}.import-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 0;font-size:.84rem}.import-action-bar{display:flex;justify-content:center;align-items:center;gap:12px;padding:16px 0 4px}.export-image-warning{background:#fef3c7;color:#92400e;padding:10px 14px;border-radius:8px;font-size:.85rem;margin-bottom:12px;line-height:1.6}.export-count{font-size:.85rem;color:var(--color-text-light)}.import-preview-overlay{position:fixed;inset:0;background:#00000073;z-index:950;display:flex;align-items:center;justify-content:center;padding:24px}.import-preview-modal{background:var(--color-bg);border-radius:12px;width:100%;max-width:520px;padding:20px;box-shadow:0 8px 30px #0003;max-height:80vh;overflow-y:auto}.import-preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.import-preview-header h3{margin:0;font-size:1rem}.import-preview-body{display:flex;flex-direction:column;gap:12px}.import-preview-text{font-size:.95rem;line-height:1.6;background:var(--color-surface);padding:12px;border-radius:8px}.import-preview-img{max-width:100%;border-radius:8px}.import-preview-options{display:flex;flex-direction:column;gap:6px}.import-preview-opt{padding:8px 12px;border:1px solid var(--color-border);border-radius:8px;display:flex;align-items:center;justify-content:space-between;font-size:.88rem}.import-preview-opt.correct{background:#dcfce7;border-color:#86efac}.import-preview-card-side{padding:10px;background:var(--color-surface);border-radius:8px}.import-preview-card-side strong{display:block;margin-bottom:6px;font-size:.82rem;color:var(--color-text-light)}@media(max-width:700px){.import-new-body{flex-direction:column}.import-groups-panel{width:100%;max-height:160px}.import-items-list{max-height:260px}}@media(max-width:600px){.import-modal{padding:16px}}.import-buttons-group{display:flex;gap:8px;flex-wrap:wrap}.text-import-body{display:flex;flex-direction:column;gap:16px}.text-import-input-section{display:flex;flex-direction:column;gap:10px}.text-import-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.text-import-toolbar label{font-size:.88rem;font-weight:500}.text-import-textarea{width:100%;min-height:200px;padding:12px;border:1px solid var(--color-border);border-radius:10px;font-family:Courier New,monospace;font-size:.88rem;line-height:1.6;resize:vertical;direction:ltr;text-align:left;background:var(--color-surface)}.text-import-textarea::placeholder{color:#aaa;font-size:.82rem}.text-import-actions{display:flex;gap:8px;flex-wrap:wrap}.text-import-format-hint{font-size:.82rem}.text-import-format-hint summary{cursor:pointer;color:var(--color-primary);font-weight:500}.text-import-format-hint pre{background:var(--color-surface);padding:10px 14px;border-radius:8px;font-size:.8rem;line-height:1.6;overflow-x:auto;direction:ltr;text-align:left;margin-top:6px;border:1px solid var(--color-border)}.text-import-results{display:flex;flex-direction:column;gap:12px}.text-import-summary{display:flex;gap:16px;align-items:center;font-size:.92rem;font-weight:600}.text-import-valid{color:#16a34a}.text-import-invalid{color:#dc2626}.text-import-errors{padding:12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px}.text-import-errors h4{margin:0 0 8px;font-size:.85rem;color:#dc2626}.text-import-error-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:.82rem;border-top:1px solid #fee2e2}.text-import-error-row:first-of-type{border-top:none}.access-denied-page{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:2rem;background:#f8f9fa}.access-denied-card{background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;padding:2.5rem;text-align:center;max-width:420px;width:100%}.access-denied-card h1{font-size:1.4rem;color:#dc3545;margin-bottom:1rem}.access-denied-card p{color:#666;margin-bottom:.5rem;font-size:.95rem}.access-denied-card .btn{margin-top:1.5rem}.user-management-page .user-create-section{margin-bottom:2rem;padding:1.25rem;background:#f9fafb;border-radius:10px;border:1px solid #e5e7eb}.user-management-page .user-create-section h2{font-size:1.1rem;margin-bottom:1rem;color:#333}.user-create-form{display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}.user-create-form input[type=email]{flex:1;min-width:200px;padding:.55rem .75rem;border-radius:8px;border:1px solid #d1d5db;font-size:.95rem}.user-create-form select{padding:.55rem .75rem;border-radius:8px;border:1px solid #d1d5db;font-size:.95rem;min-width:120px}.created-info-box{margin-top:1rem;padding:1rem;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:8px}.created-info-box p{margin:0 0 .5rem;font-size:.9rem;color:#065f46}.created-info-details{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem}.created-info-details strong{color:#065f46}.password-display{font-family:monospace;background:#fff;padding:2px 6px;border-radius:4px;border:1px solid #d1fae5;letter-spacing:.5px}.created-info-warning{color:#b45309!important;font-weight:600;margin-top:.75rem!important;font-size:.85rem!important}.user-list-section h2{font-size:1.1rem;margin-bottom:1rem;color:#333}.users-table-wrapper{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--color-border)}.users-table{width:100%;border-collapse:collapse;font-size:.92rem}.users-table thead{background:#f8fafc}.users-table th{padding:.75rem 1rem;text-align:right;font-weight:600;color:var(--color-text-light);white-space:nowrap}.users-table td{padding:.75rem 1rem;border-top:1px solid var(--color-border);vertical-align:middle}.users-table tbody tr:hover{background:#f8fafc}.users-table .current-user-row{background:#fefce8}.you-badge{color:#92400e;font-size:.8rem;font-weight:500}.editable-name{cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .15s}.editable-name:hover{background:#f0f0f5}.name-placeholder{color:#b0b0b0;font-style:italic}.role-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.78rem;font-weight:600;white-space:nowrap;letter-spacing:.01em}.role-badge-super_admin{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.role-badge-admin{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}.role-badge-editor{background:#f3f4f6;color:#4b5563;border:1px solid #d1d5db}.role-edit-inline{display:flex;gap:.5rem;align-items:center}.role-edit-inline select{padding:.35rem .5rem;border-radius:6px;border:1px solid #d1d5db;font-size:.85rem}.user-actions{display:flex;gap:.5rem;align-items:center}@media(max-width:640px){.user-create-form{flex-direction:column}.user-create-form input[type=email],.user-create-form select{width:100%;min-width:unset}.users-table th,.users-table td{padding:.5rem .6rem;font-size:.85rem}.role-edit-inline,.user-actions{flex-wrap:wrap}}.success-msg{background:#d1fae5;color:#065f46;padding:.6rem 1rem;border-radius:var(--radius-sm);font-size:.9rem;margin-top:.5rem}.student-create-form{display:flex;flex-direction:column;gap:.75rem}.form-row{display:flex;gap:.75rem;flex-wrap:wrap}.form-row input{flex:1;min-width:180px;padding:.6rem .8rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem}.class-checkboxes{display:flex;flex-wrap:wrap;gap:.75rem;margin:.5rem 0}.class-checkboxes-label{font-weight:600;font-size:.9rem;width:100%;margin-bottom:.25rem}.checkbox-label{display:flex;align-items:center;gap:.4rem;font-size:.9rem;cursor:pointer;padding:.3rem .7rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:background var(--transition)}.checkbox-label:hover{background:#f3f4f6}.checkbox-disabled{opacity:.5;cursor:not-allowed}.checkbox-disabled input[type=checkbox]{pointer-events:none}.badge-locked{font-size:.75rem;color:var(--color-text-light)}.tamkeen-item-wrapper{display:flex;flex-direction:column}.locked-hint-msg{font-size:.75rem;color:#b45309;background:#fef3c7;padding:4px 10px;border-radius:6px;margin-top:2px;margin-bottom:4px;animation:hintFadeIn .25s ease}@keyframes hintFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes shakeHint{0%,to{transform:translate(0)}20%{transform:translate(-5px)}40%{transform:translate(5px)}60%{transform:translate(-4px)}80%{transform:translate(3px)}}.shake-hint{animation:shakeHint .4s ease}.class-tag{display:inline-block;background:#ede9fe;color:#5b21b6;padding:.2rem .6rem;border-radius:999px;font-size:.78rem;font-weight:500;margin:.1rem}.class-tag-sm{display:inline-block;background:#ede9fe;color:#5b21b6;padding:.15rem .5rem;border-radius:999px;font-size:.7rem;font-weight:500}.class-select-inline{padding:.25rem .4rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.8rem;background:var(--color-surface);cursor:pointer}.disabled-row{opacity:.55}.role-badge-disabled{background:#fecaca;color:#991b1b}.search-input{padding:.5rem .8rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;min-width:200px}.list-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem}.modal-overlay{position:fixed;inset:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--color-surface);border-radius:16px;padding:1.75rem;max-width:480px;width:100%;box-shadow:var(--shadow-lg)}.modal-content h3{margin-bottom:1rem;font-size:1.15rem;font-weight:700}.modal-content input[type=text]{width:100%;padding:.6rem .8rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem;margin-bottom:.75rem}.modal-info{font-size:.85rem;color:var(--color-text-light);margin-bottom:1rem;line-height:1.8}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.35rem;font-size:.9rem;font-weight:600;color:var(--color-text-secondary)}.form-group input{width:100%;padding:.6rem .75rem;border:1px solid var(--color-border);border-radius:8px;font-size:1rem}.modal-actions{display:flex;gap:.5rem;margin-top:1rem}.sp{min-height:100vh;background:linear-gradient(170deg,#f0eef8,#f4f6fb 40% 100%)}.sp-header{display:flex;align-items:center;justify-content:space-between;padding:1.4rem 1.5rem;max-width:900px;margin:0 auto}.sp-greeting{font-size:1.3rem;font-weight:800;color:var(--color-primary)}.sp-logout{background:transparent;border:1px solid var(--color-border);color:var(--color-text-light);padding:6px 18px;border-radius:20px;font-size:.82rem;font-weight:500;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s}.sp-logout:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.sp-body{max-width:900px;margin:0 auto;padding:.5rem 1.5rem 3rem}.sp-section{margin-bottom:2.5rem;border-radius:12px;padding:8px;border:2px solid transparent;transition:box-shadow .4s ease,border-color .4s ease}.sp-section--highlight{border-color:#f59e0b;box-shadow:0 0 18px #f59e0b40}.sp-guide-msg{padding:8px 14px;margin-bottom:10px;background:#fef3c7;color:#92400e;font-size:.85rem;font-weight:600;border-radius:8px;text-align:center;animation:guideSlideIn .35s ease}@keyframes guideSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sp-section-title{font-size:1.1rem;font-weight:700;color:var(--color-text);margin-bottom:.8rem}.sp-subsection-title{font-size:.88rem;font-weight:600;color:var(--color-text-light);margin-bottom:.5rem;margin-top:1rem;display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:8px}.sp-subsection-title--cards{background:#8b5cf614;color:#7c3aed}.sp-subsection-title--quizzes{background:#64748b1a;color:#475569}.sp-subsection-title:first-of-type{margin-top:0}.badge-experimental{display:inline-block;background:#fef3c7;color:#92400e;padding:.1rem .5rem;border-radius:999px;font-size:.7rem;font-weight:600}.sp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.sp-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:24px 20px;box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:space-between;gap:12px;text-decoration:none;color:inherit;transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition)}.sp-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:transparent}.sp-card--new{opacity:.55}.sp-card-body{display:flex;flex-direction:column;gap:4px;flex:1}.sp-card-type{font-weight:800;font-size:1.1rem;color:#6366f1;display:flex;align-items:center;gap:6px}.sp-card-type--drill{color:#0ea5e9}.sp-card-subtitle{font-weight:600;font-size:.95rem;color:var(--color-text);margin-top:2px}.sp-card-title{font-weight:700;font-size:1.05rem;color:var(--color-text);display:flex;align-items:center;gap:6px}.sp-card-icon{font-size:1.2rem;flex-shrink:0}.sp-card-info{font-size:.85rem;color:var(--color-text-light);line-height:1.5}.sp-card-action{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;text-align:center;padding:10px 18px;border-radius:10px;font-size:.88rem;font-weight:600;background:#6366f1;color:#fff;transition:background .15s}.sp-card:hover .sp-card-action{background:#4f46e5}.sp-card-action--outline{background:#22c55e;color:#fff}.sp-card:hover .sp-card-action--outline{background:#16a34a}.sp-card-action--drill{background:linear-gradient(135deg,#0ea5e9,#0284c7)}.sp-card:hover .sp-card-action--drill{background:linear-gradient(135deg,#0284c7,#0369a1)}.sp-card-action--outline-drill{background:#22c55e;color:#fff}.sp-card:hover .sp-card-action--outline-drill{background:#16a34a}.sp-tamkeen-section{margin-top:1rem;padding-top:3.5rem;border-top:1px solid var(--color-border)}.sp-tamkeen{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:380px;margin:0 auto;padding:28px 28px 24px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 4px 20px #0000001a;cursor:pointer;gap:8px;transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition)}.sp-tamkeen:hover{box-shadow:0 8px 32px #00000021;transform:translateY(-3px);border-color:transparent}.sp-tamkeen-title{font-size:1.1rem;font-weight:700;color:var(--color-text)}.sp-tamkeen-desc{font-size:.85rem;color:var(--color-text-light);margin-bottom:4px}.sp-tamkeen-btn{padding:10px 28px;background:#f59a00;color:#fff;border-radius:22px;font-size:.9rem;font-weight:600;transition:background .15s}.sp-tamkeen:hover .sp-tamkeen-btn{background:#d97706}.sp-tamkeen--main{max-width:420px;margin:0 auto 1.2rem;background:#fff7ed;border:1px solid #FDBA74;box-shadow:0 6px 28px #f59a001f}.sp-tamkeen--main:hover{box-shadow:0 10px 40px #f59a002e;border-color:#f59a00}.sp-tamkeen--main .sp-tamkeen-btn{padding:11px 32px;font-size:.95rem;font-weight:700}.sp-empty{text-align:center;padding:3rem 1.5rem;color:var(--color-text-light);font-size:.95rem}.sp-picker-title{text-align:center;font-size:1.2rem;margin-bottom:1.5rem}.sp-class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;max-width:700px;margin:0 auto}.sp-class-card{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fff;border-radius:16px;padding:2rem 1.2rem;text-decoration:none;color:var(--color-text);box-shadow:0 2px 12px #0000000f;transition:transform .15s,box-shadow .15s;cursor:pointer}.sp-class-card:hover{transform:translateY(-3px);box-shadow:0 6px 24px #6366f121}.sp-class-card-icon{font-size:2.5rem;margin-bottom:.7rem}.sp-class-card-name{font-size:1.05rem;font-weight:700;text-align:center}.sp-header-actions{display:flex;align-items:center;gap:12px}.sp-back-link{color:var(--color-text-light);text-decoration:none;font-size:.88rem;padding:6px 14px;border-radius:20px;border:1px solid var(--color-border);transition:all .15s}.sp-back-link:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.btn-block{width:100%;text-align:center}.student-error{text-align:center;padding:3rem 1rem}.student-error p{margin-bottom:1rem;font-size:1.1rem}.student-player-page{max-width:700px;margin:0 auto;padding:1rem}.student-player-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.student-player-title{font-weight:600;font-size:1rem;display:flex;align-items:center;gap:.5rem}.finish-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1rem;flex-wrap:wrap}.train-form{background:var(--color-surface);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.train-decks{margin-bottom:1rem}.train-options{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:1rem}.train-option-group{display:flex;flex-direction:column;gap:.25rem;min-width:180px}.train-option-group label{font-weight:600;font-size:.9rem}.train-option-group select{padding:.5rem .7rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem}.train-option-group small{font-size:.8rem;color:var(--color-text-light)}.train-actions{display:flex;gap:.75rem}.collection-actions{display:flex;gap:.5rem;align-items:center}@media(max-width:640px){.sp-header{padding:1rem;flex-wrap:wrap;gap:.5rem}.sp-greeting{font-size:1.1rem}.sp-body{padding:.5rem 1rem 2rem}.sp-grid{grid-template-columns:1fr}.form-row,.train-options,.train-actions{flex-direction:column}.finish-actions{flex-direction:column;align-items:center}.list-header{flex-direction:column}.modal-content{max-width:100%}}.retry-toast{background:#fef3c7;color:#92400e;border:1px solid #fde68a;border-radius:var(--radius-sm);padding:.5rem 1rem;font-size:.85rem;text-align:center;margin-bottom:.75rem;animation:retryFadeIn .25s ease}@keyframes retryFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.nav-banner{margin-bottom:1.5rem}.nav-banner-link{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#ede9fe,#e0e7ff);border:1px solid #c7d2fe;border-radius:var(--radius);text-decoration:none;color:var(--color-text);transition:box-shadow var(--transition),transform var(--transition)}.nav-banner-link:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.nav-banner-icon{font-size:1.8rem;flex-shrink:0}.nav-banner-link div{flex:1;display:flex;flex-direction:column;gap:.15rem}.nav-banner-link strong{font-size:1rem;color:#4338ca}.nav-banner-link span{font-size:.85rem;color:var(--color-text-light)}.nav-banner-arrow{font-size:1.3rem;color:#4338ca;flex-shrink:0}.tool-card-highlight{border:1.5px solid #c7d2fe;background:linear-gradient(135deg,#faf5ff,#eef2ff)}.tool-card-highlight:hover{border-color:#a5b4fc}.study-mode-modal{max-width:440px;text-align:center}.study-mode-modal h3{font-size:1.15rem;margin-bottom:.3rem}.study-mode-subtitle{color:var(--color-text-light);font-size:.9rem;margin-bottom:1.2rem}.study-mode-options{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.study-mode-card{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:1.1rem 1rem;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;transition:border-color var(--transition),background var(--transition),transform var(--transition);text-align:center}.study-mode-card:hover{border-color:var(--color-primary);background:#f0f0ff;transform:translateY(-2px)}.study-mode-card-focus{border-color:#fbbf24;background:#fffbeb}.study-mode-card-focus:hover{border-color:#f59e0b;background:#fef3c7}.study-mode-icon{font-size:1.8rem}.study-mode-label{font-size:1.05rem;font-weight:600;color:var(--color-text)}.study-mode-desc{font-size:.82rem;color:var(--color-text-light);line-height:1.4}.study-mode-cancel{width:100%}.study-mode-analyzing{display:flex;flex-direction:column;align-items:center;gap:.8rem;padding:2rem 1rem}.study-mode-analyzing h3{margin-bottom:0}.study-mode-analyzing p{color:var(--color-text-light);font-size:.9rem}.analyzing-spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tamkeen-card{cursor:pointer;border:2px solid #fbbf24!important;background:linear-gradient(135deg,#fffbeb,#fef3c7);text-align:center}.tamkeen-icon{font-size:2.2rem;margin-bottom:.3rem}.tamkeen-desc{font-size:.82rem;color:var(--color-text-light);margin-bottom:.8rem;line-height:1.5}.tamkeen-modal{max-width:460px}.tamkeen-modal--fixed{display:flex;flex-direction:column;max-height:80vh;overflow:hidden}.tamkeen-modal h3{text-align:center;margin-bottom:.3rem;flex-shrink:0}.tamkeen-modal-desc{text-align:center;color:var(--color-text-light);font-size:.88rem;margin-bottom:1.2rem;flex-shrink:0}.tamkeen-scroll-body{flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-left:.25rem;padding-right:.25rem;margin-bottom:.5rem;min-height:0}.tamkeen-section{margin-bottom:1rem}.tamkeen-section--collapsible{border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-bottom:.6rem;overflow:hidden}.tamkeen-unit-toggle{display:flex;align-items:center;gap:.4rem;width:100%;padding:.7rem .75rem;background:var(--color-surface);border:none;cursor:pointer;font-size:.93rem;font-weight:600;color:var(--color-text);text-align:right;transition:background var(--transition);-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.tamkeen-unit-toggle:hover{background:#f0f0f5}.tamkeen-unit-toggle:active{background:#e8e8ef}.tamkeen-unit-arrow{font-size:.85rem;color:var(--color-text-light);width:1rem;text-align:center;flex-shrink:0}.tamkeen-unit-toggle-name{flex:1}.tamkeen-unit-toggle-count{font-weight:400;font-size:.82rem;color:var(--color-text-light)}.tamkeen-unit-selected-badge{font-size:.75rem;font-weight:500;color:#fff;background:var(--color-primary);padding:.1rem .45rem;border-radius:10px;margin-inline-start:.3rem}.tamkeen-section--collapsible .class-checkboxes{padding:.4rem .75rem .6rem;border-top:1px solid var(--color-border)}.tamkeen-modal--fixed>.tamkeen-section,.tamkeen-modal--fixed>.tamkeen-modal-actions{flex-shrink:0}.tamkeen-modal-actions{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.tamkeen-modal-actions .btn{padding:12px;font-size:.95rem;font-weight:600}.btn-tamkeen-start{background:#f59a00;color:#fff}.btn-tamkeen-start:hover{background:#d97706;box-shadow:0 2px 8px #f59a004d}@media(max-width:640px){.tamkeen-modal--fixed{max-height:calc(100vh - 1.5rem);max-height:calc(100dvh - 1.5rem);padding:1rem .85rem;border-radius:12px}.tamkeen-modal--fixed h3{font-size:1.05rem;margin-bottom:.2rem}.tamkeen-modal-desc{font-size:.82rem;margin-bottom:.8rem}.tamkeen-unit-toggle{padding:.85rem .75rem;font-size:.9rem;min-height:44px}.tamkeen-unit-toggle-count{font-size:.78rem}.tamkeen-unit-selected-badge{font-size:.7rem}.tamkeen-section--collapsible .class-checkboxes{padding:.3rem .5rem .5rem}.tamkeen-section--collapsible .checkbox-label{padding:.45rem .6rem;min-height:40px;font-size:.88rem}.tamkeen-count-options{gap:.35rem}.tamkeen-count-btn{padding:.35rem .75rem;font-size:.88rem;min-height:38px}}.tamkeen-label{display:block;font-weight:600;font-size:.92rem;margin-bottom:.5rem}.tamkeen-count-options{display:flex;gap:.5rem;flex-wrap:wrap}.tamkeen-count-btn{padding:.4rem 1rem;border:2px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;font-size:.95rem;font-weight:500;transition:all var(--transition)}.tamkeen-count-btn:hover{border-color:var(--color-primary)}.tamkeen-count-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.train-transition{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;animation:trainTransitionIn .4s ease}.train-transition-icon{font-size:3.5rem;margin-bottom:1rem;animation:trainTransitionPulse 1s ease infinite}.train-transition-text{font-size:1.5rem;font-weight:700;color:var(--color-primary, #6366f1);margin:0 0 .4rem}.train-transition-sub{font-size:1rem;color:var(--color-text-light, #64748b);margin:0}@keyframes trainTransitionIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes trainTransitionPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.retry-banner{position:fixed;top:0;left:0;right:0;z-index:900;display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 20px;background:linear-gradient(135deg,#6366f1,#818cf8);color:#fff;box-shadow:0 4px 20px #6366f159;animation:retryBannerIn .4s ease,retryBannerOut .4s ease 1.4s forwards}.retry-banner-emoji{font-size:1.6rem;flex-shrink:0}.retry-banner-text{display:flex;flex-direction:column;gap:2px;text-align:right}.retry-banner-text strong{font-size:1rem;font-weight:700}.retry-banner-text span{font-size:.85rem;opacity:.9}@keyframes retryBannerIn{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes retryBannerOut{0%{transform:translateY(0);opacity:1}to{transform:translateY(-100%);opacity:0}}.retry-card-overlay{position:absolute;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;pointer-events:none;animation:retryOverlayIn .35s ease,retryOverlayOut .35s ease 1.4s forwards}.retry-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:24px 36px;background:#fff;border-radius:16px;box-shadow:0 0 30px 8px #6366f126,0 8px 32px #0000001a;pointer-events:auto;animation:retryCardPop .4s cubic-bezier(.34,1.56,.64,1)}.retry-card-emoji{font-size:2.2rem;line-height:1}.retry-card-main{font-size:1.1rem;font-weight:700;color:var(--color-primary, #6366f1)}.retry-card-sub{font-size:.88rem;color:var(--color-text-light, #64748b)}@keyframes retryCardPop{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}@keyframes retryOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes retryOverlayOut{0%{opacity:1}to{opacity:0}}.retry-round-badge{display:flex;align-items:center;justify-content:center;gap:10px;padding:6px 0;animation:retryBadgeFade .4s ease}.retry-round-label{font-size:.75rem;color:var(--color-text-light, #64748b);white-space:nowrap}.retry-round-dots{display:flex;gap:5px;direction:rtl}.retry-dot{width:10px;height:10px;border-radius:50%;transition:background .3s ease,transform .3s ease,box-shadow .3s ease}.retry-dot.pending{background:#e2e8f0}.retry-dot.correct{background:#22c55e;box-shadow:0 0 6px #22c55e66;transform:scale(1.15)}.retry-dot.wrong{background:#ef4444;box-shadow:0 0 6px #ef444466;transform:scale(1.15)}@keyframes retryBadgeFade{0%{opacity:0}to{opacity:1}}.weakness-reason-box{background:#fefce8;border:1px solid #fde68a;border-radius:10px;padding:.7rem 1rem;margin:.6rem auto 0;max-width:480px;min-height:52px;text-align:right;font-size:.85rem;color:#854d0e}.weakness-reason-label{font-weight:600;display:block;margin-bottom:.25rem}.weakness-reason-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.4rem}.weakness-reason-list li{background:#fdf2c5;border-radius:12px;padding:.15rem .65rem;font-size:.8rem;white-space:nowrap}.unit-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.unit-block{background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:var(--radius-md, 12px);overflow:hidden}.unit-block--unassigned{margin-top:1.5rem;border-style:dashed;opacity:.7}.unit-header-row{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#f8fafc;border-bottom:1px solid var(--color-border, #e2e8f0);flex-wrap:wrap}.unit-name-btn{flex:1;display:flex;align-items:center;gap:.5rem;background:none;border:none;font-size:1.05rem;font-weight:600;color:var(--color-text, #1e293b);cursor:pointer;padding:.3rem .5rem;border-radius:var(--radius-sm, 8px);text-align:right;transition:background .15s}.unit-name-btn:hover{background:#eef2ff}.unit-name-btn--active{color:var(--color-primary, #6366f1)}.unit-expand-icon{font-size:.85rem;color:#94a3b8}.unit-item-count{font-size:.8rem;font-weight:400;color:#94a3b8;margin-right:auto}.unit-name-label{flex:1;font-size:1rem;font-weight:600;color:#94a3b8;padding:.3rem .5rem}.unit-actions{display:flex;gap:.4rem}.unit-edit-inline{flex:1}.unit-items-panel{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.4rem}.unit-item-row{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#f8fafc;border-radius:var(--radius-sm, 8px);border:1px solid #f1f5f9}.unit-item-icon{font-size:1.1rem;flex-shrink:0}.unit-item-title{flex:1;font-size:.95rem;font-weight:500}.unit-add-btn{align-self:flex-start;margin-top:.5rem}.unit-add-items-panel{margin-top:.5rem;padding:.75rem;background:#eff6ff;border-radius:var(--radius-sm, 8px);border:1px dashed #93c5fd}.unit-add-items-panel h4{margin:0 0 .5rem;font-size:.9rem;color:#1e40af}.unit-add-item-row{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;background:#fff;border-radius:var(--radius-sm, 8px);margin-bottom:.3rem}.sp-unit-header{font-size:1.1rem;font-weight:700;color:var(--color-text, #1e293b);padding:.5rem .75rem;margin:0 0 .5rem;border-right:4px solid var(--color-primary, #6366f1);background:linear-gradient(90deg,rgba(99,102,241,.06) 0%,transparent 100%);border-radius:0 var(--radius-sm, 8px) var(--radius-sm, 8px) 0}.tamkeen-unit-header{font-size:.95rem;font-weight:700;color:var(--color-primary, #6366f1);padding:.5rem 0 .25rem;margin-top:.5rem;border-bottom:1px solid #e2e8f0}.stu-header{position:sticky;top:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 16px;background:#ffffffeb;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.08)}.stu-header-right{display:flex;flex-direction:column;gap:1px;min-width:0}.stu-header-title{font-weight:700;font-size:1.05rem;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stu-header-sub{font-size:.78rem;color:var(--color-text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stu-header-back{font-size:.78rem;color:var(--color-primary);text-decoration:none;white-space:nowrap}.stu-header-left{flex-shrink:0;margin-inline-start:12px}.stu-streak-badge{display:inline-flex;flex-direction:column;align-items:center;padding:4px 12px 5px;background:#ffedd5b3;border:1px solid #fed7aa;border-radius:14px;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.stu-streak-pop{animation:streakPop .35s ease}@keyframes streakPop{0%{transform:scale(1)}40%{transform:scale(1.18)}to{transform:scale(1)}}.stu-streak-top{display:flex;align-items:center;gap:3px}.stu-streak-fire{font-size:1rem;line-height:1}.stu-streak-num{font-weight:700;font-size:.95rem;color:#ea580c}.stu-streak-label{font-size:.75rem;color:#c2410c;font-weight:500}.stu-streak-hint{font-size:.6rem;color:#9a3412;opacity:.7;margin-top:1px;white-space:nowrap}.stu-streak-hint.stu-streak-done{color:#15803d;opacity:.85}.btn-block{width:100%}.empty-text{text-align:center;color:#888;padding:32px 0}.settings-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:24px;margin-bottom:20px}.settings-section-title{font-size:1.1rem;font-weight:700;margin-bottom:16px}.settings-option-group{display:flex;flex-direction:column;gap:12px}.settings-radio-label{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:2px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s}.settings-radio-label:has(input:checked){border-color:var(--color-primary);background:#f0f4ff}.settings-radio-label input[type=radio]{width:18px;height:18px;margin-top:3px;cursor:pointer}.settings-radio-label strong{display:block;margin-bottom:2px}.settings-option-desc{font-size:.85rem;color:var(--color-text-muted);margin:0}.settings-saving-badge{font-size:.85rem;color:var(--color-primary);font-weight:600}.stats-month-selector{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;background:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-border);width:fit-content}.stats-month-selector label{font-weight:600;font-size:.9rem;color:var(--color-text-light)}.stats-month-selector select{padding:6px 12px;border-radius:6px;border:1px solid var(--color-border);font-size:.9rem;font-family:inherit;background:#fff;cursor:pointer}.stats-student-list{display:flex;flex-direction:column;gap:2px;position:relative}.stats-list-header{display:flex;align-items:center;justify-content:space-between;padding:8px 18px;margin-bottom:4px}.stats-list-col-name{font-size:.8rem;font-weight:600;color:var(--color-text-light)}.stats-list-col-label{font-size:.8rem;font-weight:600;color:var(--color-text-light);display:flex;align-items:center;gap:6px;min-width:70px;text-align:center;justify-content:center}.stats-list-col-acc{min-width:40px}.stats-list-month-select{padding:2px 5px;border-radius:4px;border:1px solid var(--color-border);font-size:.72rem;font-family:inherit;background:#f8f9fc;color:var(--color-text-light);cursor:pointer}.stats-loading-overlay{position:absolute;inset:0;background:#ffffffb3;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--color-text-light);z-index:2;border-radius:var(--radius-sm)}.stats-student-row{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);text-decoration:none;color:inherit;transition:background .15s,box-shadow .15s;cursor:pointer}.stats-student-row:hover{background:#f8f9fc;box-shadow:var(--shadow)}.stats-student-name{font-weight:600;font-size:.95rem}.stats-student-nums{display:flex;gap:20px;align-items:center}.stats-num-time{font-size:.85rem;color:var(--color-text-light);min-width:70px;text-align:center}.stats-num-seen{font-size:.8rem;color:#888;min-width:70px;text-align:center}.stats-list-col-seen{min-width:70px}.stats-num-ret{font-size:.85rem;font-weight:600;color:#8b5cf6;min-width:55px;text-align:center;position:relative}.stats-list-col-ret{min-width:55px}.stats-ret-hint-btn{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;border:1.5px solid #8b5cf6;background:transparent;color:#8b5cf6;font-size:10px;font-weight:700;cursor:pointer;margin-right:3px;padding:0;line-height:1;vertical-align:middle}.stats-ret-hint-btn:hover{background:#8b5cf6;color:#fff}.stats-ret-popup{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:6px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 16px #0000001f;padding:8px 12px;z-index:100;min-width:160px;white-space:nowrap}.stats-ret-popup-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:4px 0;border-bottom:1px solid #f3f4f6}.stats-ret-popup-row:last-child{border-bottom:none}.stats-ret-popup-name{font-size:.8rem;color:#333;font-weight:500}.stats-ret-popup-val{font-size:.8rem;color:#8b5cf6;font-weight:700}.stats-num-cards{font-size:.85rem;font-weight:600;color:#3b82f6;min-width:50px;text-align:center}.stats-list-col-cards{min-width:50px}.stats-num-acc{font-size:.85rem;font-weight:600;color:var(--color-primary);min-width:40px;text-align:center}.stats-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:28px}.stats-card{display:flex;flex-direction:column;gap:6px;padding:16px 18px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.stats-card-with-filter{gap:8px}.stats-card-top-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.stats-card-month-select{padding:3px 6px;border-radius:5px;border:1px solid var(--color-border);font-size:.75rem;font-family:inherit;background:#f8f9fc;color:var(--color-text-light);cursor:pointer;max-width:120px}.stats-card-label{font-size:.8rem;color:var(--color-text-light);font-weight:500}.stats-card-value{font-size:1.3rem;font-weight:700;color:var(--color-text)}.stats-mastery-value{display:flex;align-items:baseline;gap:3px}.stats-mastery-num{font-size:1.3rem;font-weight:700}.stats-mastery-sep{font-size:1rem;color:var(--color-text-light);font-weight:400}.stats-mastery-total{font-size:1rem;font-weight:500;color:var(--color-text-light)}.stats-card-hint{font-size:.7rem;color:#9ca3af;margin-top:-2px}.stats-retention-breakdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:20px;margin-bottom:20px}.stats-section-title{font-size:1rem;font-weight:700;margin-bottom:16px;color:var(--color-text)}.stats-retention-list{display:flex;flex-direction:column;gap:12px}.stats-retention-row{display:flex;align-items:center;gap:12px}.stats-retention-class{font-size:.9rem;font-weight:600;min-width:100px;text-align:right;color:var(--color-text)}.stats-retention-bar-wrap{flex:1;height:10px;background:#f3f4f6;border-radius:5px;overflow:hidden}.stats-retention-bar{height:100%;background:linear-gradient(90deg,#8b5cf6,#a78bfa);border-radius:5px;transition:width .6s ease}.stats-retention-pct{font-size:.85rem;font-weight:700;color:#8b5cf6;min-width:40px;text-align:center}.stats-chart-wrap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:20px}.stats-chart-title{font-size:1rem;font-weight:700;margin-bottom:12px}.stats-chart-svg{width:100%;max-width:600px;height:auto}.stats-chart-empty{color:var(--color-text-light);font-size:.9rem;padding:20px 0;text-align:center}@media(max-width:600px){.stats-cards-grid{grid-template-columns:repeat(2,1fr)}.stats-student-nums{gap:12px}.stats-chart-svg{max-width:100%}}.j-editor-page{max-width:960px}.j-stats-bar{font-size:.85rem;color:var(--color-text-light);white-space:nowrap}.j-editor-nav{display:flex;gap:4px;margin-bottom:20px;border-bottom:2px solid var(--color-border);padding-bottom:0}.j-tabs{display:flex;gap:4px;margin-bottom:16px}.j-tab{padding:8px 18px;border:none;background:none;font-size:.9rem;font-weight:600;color:var(--color-text-light);cursor:pointer;border-bottom:3px solid transparent;transition:color var(--transition),border-color var(--transition)}.j-tab:hover{color:var(--color-primary)}.j-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.j-settings-section{background:var(--color-surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.j-form-group{margin-bottom:16px}.j-form-group label{display:block;font-weight:600;margin-bottom:6px;font-size:.9rem;color:var(--color-text)}.j-form-group input[type=text],.j-form-group input[type=number],.j-form-group textarea,.j-form-group select{width:100%;padding:10px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;background:var(--color-bg);transition:border-color var(--transition)}.j-form-group input:focus,.j-form-group textarea:focus,.j-form-group select:focus{outline:none;border-color:var(--color-primary)}.j-form-row{display:flex;gap:16px}.j-form-row .j-form-group{flex:1}.j-groups-section{display:flex;flex-direction:column;gap:16px}.j-group-editor{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.j-group-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;cursor:pointer;background:var(--color-primary-light);transition:background var(--transition)}.j-group-header:hover{background:#ddd6fe}.j-group-title-row{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.j-group-number{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--color-primary);color:#fff;font-weight:700;font-size:.85rem;flex-shrink:0}.j-group-name-col{display:flex;flex-direction:column;gap:0;min-width:0}.j-group-name-input{border:1.5px solid transparent!important;background:transparent!important;font-weight:700!important;font-size:.95rem!important;padding:4px 8px!important;border-radius:6px!important;width:200px!important}.j-group-name-input:focus{border-color:var(--color-primary)!important;background:#fff!important}.j-group-desc-input{border:1px solid transparent!important;background:transparent!important;font-size:.78rem!important;color:var(--color-text-light)!important;padding:1px 8px!important;border-radius:4px!important;width:200px!important}.j-group-desc-input:focus{border-color:var(--color-border)!important;background:#fff!important}.j-group-desc-input::placeholder{color:#ccc;font-size:.75rem}.j-group-summary{font-size:.8rem;color:var(--color-text-light);white-space:nowrap}.j-group-actions{display:flex;align-items:center;gap:8px}.j-expand-icon{font-size:.75rem;color:var(--color-text-light)}.j-group-body{padding:20px}.j-add-group-btn{align-self:center}.j-display-modes{display:flex;align-items:center;gap:14px;padding:8px 16px;margin:-8px 0 16px;background:#f8f9fa;border-radius:0 0 8px 8px;border:1px solid #e8e8e8;border-top:1px dashed #e0e0e0;flex-wrap:wrap}.j-display-modes-label{font-size:13px;font-weight:600;color:#555;margin-left:4px}.j-dm-option{display:flex;align-items:center;gap:4px;font-size:13px;color:#333;cursor:pointer;-webkit-user-select:none;user-select:none}.j-dm-option input[type=checkbox],.j-dm-option input[type=radio]{cursor:pointer;accent-color:var(--primary, #1976d2)}.j-dm-separator{color:#ccc;font-size:14px}.j-dm-disabled{opacity:.4;cursor:not-allowed!important}.j-dm-disabled input{cursor:not-allowed!important}.j-merge-mode-options{display:flex;flex-direction:column;gap:6px}.j-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.j-section-header h4{font-size:.95rem;color:var(--color-text)}.j-empty-hint{color:var(--color-text-light);font-size:.85rem;text-align:center;padding:16px;background:var(--color-bg);border-radius:var(--radius-sm)}.j-word-list,.j-card-list{display:flex;flex-direction:column;gap:6px}.j-word-row,.j-card-row{display:flex;align-items:center;gap:8px;background:var(--color-bg);padding:6px 10px;border-radius:var(--radius-sm)}.j-word-index{min-width:24px;text-align:center;font-size:.8rem;color:var(--color-text-light);font-weight:600}.j-word-input{flex:1;padding:8px 10px!important;border:1.5px solid var(--color-border)!important;border-radius:6px!important;font-size:.9rem!important;background:#fff!important}.j-word-input:focus{border-color:var(--color-primary)!important;outline:none}.j-remove-btn{padding:4px 8px!important;font-size:1.1rem!important;line-height:1!important;min-width:auto!important}.j-bulk-import{margin-bottom:12px;display:flex;flex-direction:column;gap:8px}.j-bulk-import textarea{width:100%;padding:10px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-family:inherit;font-size:.9rem;resize:vertical}.j-question-list{display:flex;flex-direction:column;gap:8px}.j-question-item{background:var(--color-bg);border-radius:var(--radius-sm);overflow:hidden}.j-question-header{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;transition:background var(--transition)}.j-question-header:hover{background:var(--color-border)}.j-question-preview{flex:1;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.j-question-body{padding:12px 16px;border-top:1px solid var(--color-border)}.j-question-input{width:100%;padding:10px!important;border:1.5px solid var(--color-border)!important;border-radius:6px!important;font-size:.9rem!important;margin-bottom:10px}.j-options-list{display:flex;flex-direction:column;gap:6px}.j-option-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;background:#fff;border:1.5px solid var(--color-border);transition:border-color var(--transition)}.j-option-correct{border-color:var(--color-success);background:#f0fdf4}.j-option-row input[type=radio]{accent-color:var(--color-success)}.j-option-input{flex:1;padding:6px 8px!important;border:none!important;background:transparent!important;font-size:.9rem!important}.j-unified-item{border:1px solid var(--color-border);border-radius:8px;overflow:hidden;margin-bottom:4px}.j-unified-item .j-word-row{margin-bottom:0;border-radius:0;border:none}.j-options-toggle{white-space:nowrap;font-size:.78rem!important;padding:4px 8px!important}.j-item-options{padding:10px 16px;background:var(--color-bg);border-top:1px solid var(--color-border)}.j-steps-preview h4{font-size:1rem;margin-bottom:16px}.j-preview-stations{display:flex;flex-direction:column;gap:16px}.j-preview-station{background:rgba(var(--color-primary-rgb, 108, 99, 255),.04);border:1.5px solid var(--color-border);border-radius:var(--radius-lg, 16px);padding:16px}.j-preview-station-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.j-preview-station-title{font-size:1.05rem;font-weight:700;color:var(--color-text);cursor:pointer;border-bottom:1px dashed transparent;transition:border-color .15s;padding:2px 0}.j-preview-station-title:hover{border-bottom-color:var(--color-primary, #6c63ff)}.j-preview-station-name-input{font-size:1.05rem;font-weight:700;border:1.5px solid var(--color-primary, #6c63ff);border-radius:var(--radius-sm, 6px);padding:4px 10px;background:var(--color-surface, #fff);outline:none;font-family:inherit;direction:rtl}.j-preview-station-desc{font-size:.8rem;color:var(--color-text-light);margin:-4px 0 6px;cursor:pointer;padding:2px 0;border-bottom:1px dashed transparent;transition:border-color .15s}.j-preview-station-desc:hover{border-bottom-color:var(--color-text-light)}.j-preview-station-desc-placeholder{font-size:.78rem;color:var(--color-text-light);opacity:.5;cursor:pointer;margin:-4px 0 6px;transition:opacity .15s}.j-preview-station-desc-placeholder:hover{opacity:.8}.j-preview-station-desc-input{font-size:.8rem;border:1.5px solid var(--color-primary, #6c63ff);border-radius:var(--radius-sm, 6px);padding:4px 10px;background:var(--color-surface, #fff);outline:none;font-family:inherit;direction:rtl;margin:-4px 0 6px;width:100%}.j-preview-station-count{font-size:.8rem;color:var(--color-text-light)}.j-preview-station-items{display:flex;flex-direction:column;gap:4px}.j-preview-step{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--color-surface);border-radius:var(--radius-sm);border-right:3px solid var(--color-border)}.j-preview-type-read{border-right-color:#3b82f6}.j-preview-type-flashcards{border-right-color:#8b5cf6}.j-preview-type-drills{border-right-color:#f59e0b}.j-preview-type-mixed{border-right-color:#8b5cf6}.j-preview-type-checkpoint{border-right-color:var(--color-success);background:#22c55e0a}.j-preview-merge{background:#fefce8}.j-preview-step-num{min-width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--color-bg);font-weight:700;font-size:.75rem;color:var(--color-text-light)}.j-preview-step-title{font-weight:600;font-size:.9rem;flex:1;display:flex;align-items:center;gap:6px}.j-preview-title-text{cursor:pointer;border-bottom:1px dashed transparent;transition:border-color .15s;padding:2px 0}.j-preview-title-text:hover{border-bottom-color:var(--color-primary, #6c63ff)}.j-preview-custom .j-preview-title-text{color:var(--color-primary, #6c63ff)}.j-preview-reset-btn{background:none;border:none;color:var(--color-text-light);cursor:pointer;font-size:.85rem;padding:0 4px;opacity:.5;transition:opacity .15s,color .15s;line-height:1}.j-preview-reset-btn:hover{opacity:1;color:var(--color-danger, #ef4444)}.j-preview-title-input{flex:1;font-weight:600;font-size:.9rem;border:1.5px solid var(--color-primary, #6c63ff);border-radius:var(--radius-sm, 6px);padding:4px 8px;background:var(--color-surface, #fff);outline:none;font-family:inherit;direction:rtl}.j-group-name-text{font-weight:700;font-size:1rem}.j-step-item{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--color-surface);border-radius:var(--radius-sm);border-right:4px solid var(--color-border)}.j-step-content{display:flex;align-items:center;gap:8px;flex:1}.j-step-label{font-weight:600;font-size:.9rem}.j-student-page{max-width:800px}.j-journey-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.j-journey-card{display:flex;flex-direction:column;background:var(--color-surface);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);text-decoration:none;color:var(--color-text);transition:transform var(--transition),box-shadow var(--transition);border:2px solid transparent}.j-journey-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.j-journey-completed{border-color:var(--color-success)}.j-journey-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.j-journey-title{font-size:1.05rem;font-weight:700}.j-journey-class{font-size:.75rem;background:var(--color-primary-light);color:var(--color-primary);padding:2px 8px;border-radius:12px;font-weight:600}.j-journey-desc{font-size:.85rem;color:var(--color-text-light);margin-bottom:12px;line-height:1.5}.j-journey-card-bottom{margin-top:auto}.j-journey-stats{display:flex;gap:12px;font-size:.8rem;color:var(--color-text-light);margin-bottom:10px}.j-journey-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:600}.j-badge-new{background:var(--color-primary-light);color:var(--color-primary)}.j-badge-done{background:#dcfce7;color:var(--color-success)}.j-journey-cta{display:block;text-align:center;padding:10px 16px;border-radius:var(--radius-sm, 8px);font-size:.95rem;font-weight:700;margin-top:8px;transition:opacity .15s}.j-cta-start{background:var(--color-primary);color:#fff}.j-cta-continue{background:linear-gradient(135deg,#6c63ff,#48c6ef);color:#fff}.j-cta-done{background:#dcfce7;color:var(--color-success)}.j-journey-tamkeen-hint{display:block;font-size:.7rem;color:#b0b0b0;text-align:center;margin-top:4px;font-weight:400;letter-spacing:.02em}.j-progress-bar-container{position:relative;background:var(--color-border);border-radius:12px;height:8px;overflow:hidden}.j-progress-large{height:14px;flex:1}.j-progress-bar{position:absolute;top:0;right:0;height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:12px;transition:width .4s ease}.j-progress-label{position:absolute;left:8px;top:50%;transform:translateY(-50%);font-size:.65rem;font-weight:700;color:var(--color-text)}.j-progress-large .j-progress-label{font-size:.75rem}.j-streak-banner{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#fff7ed,#ffedd5);border:1px solid #fed7aa;border-radius:var(--radius);padding:12px 18px;margin-bottom:16px}.j-streak-fire{font-size:1.5rem}.j-streak-text{font-size:.95rem;color:#9a3412}.j-streak-text strong{font-size:1.15rem}.j-streak-best{margin-inline-start:auto;font-size:.8rem;color:#c2410c;opacity:.7}.j-journey-description{font-size:.95rem;color:var(--color-text-light);margin-bottom:20px;line-height:1.6}.j-overview-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;margin-bottom:16px}.j-overview-progress{position:relative;width:100px;height:100px;display:flex;align-items:center;justify-content:center}.j-overview-ring{position:absolute;inset:0;width:100%;height:100%}.j-overview-ring circle:last-child{transition:stroke-dasharray .6s ease}.j-overview-pct{font-size:1.4rem;font-weight:800;color:var(--color-primary);z-index:1}.j-overview-done .j-overview-ring{display:none}.j-overview-done{background:var(--color-success);border-radius:50%;box-shadow:0 0 0 6px #10b98126,0 4px 14px #10b9814d}.j-overview-check{font-size:2.8rem;font-weight:900;color:#fff;z-index:1;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.15)}.j-overview-current{display:flex;flex-direction:column;gap:4px}.j-overview-label{font-size:.8rem;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.5px}.j-overview-step-name{font-size:1.1rem;font-weight:700;color:var(--color-text)}.j-overview-step-count{font-size:.85rem;color:var(--color-text-light)}.j-overview-continue{width:100%;max-width:320px;padding:16px 28px!important;font-size:1.15rem!important;font-weight:700!important;border-radius:14px!important}.j-overview-completed{display:flex;flex-direction:column;align-items:center;gap:6px}.j-overview-completed-title{font-size:1.15rem;font-weight:700;color:var(--color-success);margin:0}.j-overview-completed-stats{font-size:.85rem;color:#999;margin:0}.j-overview-review{margin-top:6px}.j-overview-card:has(.j-overview-done){background:linear-gradient(170deg,#fefce8,#fff 50%)}.j-toggle-map-btn{display:block;margin:0 auto 16px;background:none;border:none;color:var(--color-text-light);font-size:.9rem;cursor:pointer;padding:8px 16px;border-radius:var(--radius-sm);transition:color .2s,background .2s}.j-toggle-map-btn:hover{color:var(--color-primary);background:var(--color-bg)}.j-journey-progress-header{display:flex;align-items:center;gap:16px;margin-bottom:28px;background:var(--color-surface);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow)}.j-continue-btn{white-space:nowrap;padding:12px 28px!important;font-size:1rem!important}.j-completed-banner{background:#dcfce7;color:var(--color-success);padding:10px 20px;border-radius:var(--radius-sm);font-weight:700;text-align:center;white-space:nowrap}.j-map-title{font-size:1rem;margin-bottom:14px}.j-step-map-list{display:flex;flex-direction:column;gap:4px}.j-step-map{display:flex;flex-direction:column;gap:16px}.j-station-card{background:rgba(var(--color-primary-rgb, 108, 99, 255),.04);border:1.5px solid var(--color-border);border-radius:var(--radius-lg, 16px);padding:16px;transition:border-color .2s}.j-station-done{border-color:var(--color-success);background:#22c55e0a}.j-station-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.j-station-title{font-size:1.05rem;font-weight:700;color:var(--color-text)}.j-station-progress-text{font-size:.85rem;font-weight:600;color:var(--color-text-light);background:var(--color-bg);padding:2px 10px;border-radius:10px}.j-station-progress-done{background:#dcfce7;color:var(--color-success)}.j-station-desc{font-size:.8rem;color:#aaa;font-style:italic;margin:-2px 0 4px;line-height:1.4}.j-station-bar-container{height:4px;background:var(--color-border);border-radius:2px;margin-bottom:12px;overflow:hidden}.j-station-bar{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s}.j-station-done .j-station-bar{background:var(--color-success)}.j-station-items{display:flex;flex-direction:column;gap:4px}.j-map-step{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-surface);border-radius:var(--radius-sm);border-right:4px solid var(--color-border);cursor:pointer;transition:background var(--transition),transform var(--transition)}.j-map-step:hover:not(.j-map-locked){background:var(--color-bg);transform:translate(-2px)}.j-map-done{border-right-color:var(--color-success)}.j-map-current{border-right-color:var(--color-primary);background:var(--color-primary-light)}.j-map-locked{opacity:.5;cursor:not-allowed}.j-map-mix{background:#fefce8}.j-map-checkpoint{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-right-color:#f59e0b}.j-map-checkpoint.j-map-done{border-right-color:#f59e0b}.j-map-step-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.j-map-step-title{font-weight:600;font-size:.9rem}.j-map-step-end-icon{width:40px;text-align:center;flex-shrink:0;font-size:1.1rem;line-height:1}.j-map-step-pending{display:inline-block;width:10px;height:10px;border-radius:50%;border:1.5px solid #a0b4c8;background:transparent;opacity:.6}.j-map-step-score{font-size:.75rem;font-weight:700;white-space:nowrap}.j-map-step-score.score-perfect{color:#16a34a}.j-map-step-score.score-good{color:#65a30d}.j-step-runner{max-width:680px;margin:0 auto;display:flex;flex-direction:column;min-height:100vh}.j-step-header-v2{display:flex;flex-direction:column;gap:2px;margin-bottom:6px}.j-step-h-row1-link{display:flex;align-items:center;gap:8px;text-decoration:none;cursor:pointer;padding:4px 0;border-radius:6px;transition:opacity .15s}.j-step-h-row1-link:hover{opacity:.7}.j-step-h-row1-link:active{opacity:.5}.j-step-back-arrow{font-size:1.1rem;color:var(--color-text-light);line-height:1}.j-step-journey-name{font-size:.88rem;font-weight:600;color:var(--color-text)}.j-step-h-row-progress{font-size:.72rem;color:var(--color-text-light);opacity:.55;font-variant-numeric:tabular-nums;direction:ltr;unicode-bidi:isolate;width:fit-content}.j-step-h-row2{display:flex;align-items:center;gap:8px}.j-step-title{font-weight:700;font-size:1.05rem;color:var(--color-text)}.j-step-badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:12px;background:#f3f0ff;color:var(--color-primary);white-space:nowrap}.j-step-body{background:var(--color-surface);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);min-height:400px;display:flex;flex-direction:column}.j-step-body:has(.j-drills-playing){padding:20px 16px}.j-step-empty{text-align:center;color:var(--color-text-light);padding:40px 0}.j-read-step{display:flex;flex-direction:column;padding-bottom:72px;transition:opacity .3s ease,transform .3s ease}.j-read-step.j-read-exit{opacity:0;transform:translate(-30px)}.j-read-sticky-footer{position:fixed;bottom:0;left:0;right:0;padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));background:#fffffff2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-top:1px solid rgba(0,0,0,.08);display:flex;justify-content:center;z-index:50}.j-read-sticky-footer .j-step-done-btn{margin-top:0;width:100%;max-width:360px}.j-step-title{font-size:1.2rem;margin-bottom:4px}.j-step-subtitle{font-size:.85rem;color:var(--color-text-light);margin-bottom:20px}.j-word-list{display:flex;flex-direction:column;margin-bottom:24px}.j-read-hint{text-align:center;padding:8px 12px;margin-bottom:4px;font-size:.88rem;color:#5a7ec2;background:#eef3fc;border-radius:8px;animation:jHintFade 3s ease forwards}@keyframes jHintFade{0%,70%{opacity:1}to{opacity:0}}.j-word-item{display:flex;flex-direction:row;align-items:first baseline;gap:16px;padding:14px 16px;border-bottom:1px solid rgba(0,0,0,.06);cursor:pointer;transition:background .15s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.j-word-item:last-child{border-bottom:none}.j-word-item:hover{background:#00000006}.j-word-item:active,.j-word-item.j-word-active{background:#5882d21a}.j-word-eng{display:flex;align-items:center;gap:6px;direction:ltr;text-align:left;flex:1;min-width:0}.j-word-term{font-weight:700;font-size:1.05rem;color:var(--color-text)}.j-word-def{color:#555;font-size:.95rem;text-align:right;flex:1;min-width:0}.j-word-speaker{font-size:.85rem;opacity:.35;filter:grayscale(100%);transition:opacity .15s,filter .15s,transform .15s;flex-shrink:0}.j-word-item:hover .j-word-speaker{opacity:.7;filter:grayscale(0%)}.j-word-item:active .j-word-speaker,.j-word-item.j-word-active .j-word-speaker{opacity:1;filter:grayscale(0%);transform:scale(1.15)}.j-read-embed{padding:16px 16px 24px}.j-read-embed .j-step-title,.j-read-embed .j-step-subtitle{text-align:center}.j-step-done-btn{align-self:center;margin-top:auto;padding:12px 36px!important;font-size:1rem!important}.j-step-result{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px 0;flex:1}.j-result-title{font-size:1.4rem;margin-bottom:16px}.j-result-sub-info{font-size:.9rem;color:var(--color-text-light, #64748b);margin:0 0 8px}.j-result-score-circle{width:120px;height:120px;border-radius:50%;background:var(--color-bg);display:flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:var(--shadow)}.j-step-result.j-brief-exit{position:relative;overflow:hidden}.j-result-score-circle.j-brief-glow{animation:briefGlow 1.5s ease-in-out forwards;z-index:2;position:relative}@keyframes briefGlow{0%{box-shadow:0 0 #6366f100;transform:scale(1)}25%{box-shadow:0 0 24px 10px #6366f180;transform:scale(1.1)}55%{box-shadow:0 0 32px 14px #6366f159;transform:scale(1.15)}75%{box-shadow:0 0 60px 30px #6366f133;transform:scale(1.3)}to{box-shadow:0 0 100px 60px #ffffffe6;transform:scale(1.6);opacity:0}}.j-brief-exit .j-result-title{animation:briefFadeUp 1.2s ease forwards}@keyframes briefFadeUp{0%{opacity:1;transform:translateY(0)}60%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.j-brief-flash{position:absolute;inset:0;background:#fff;z-index:3;opacity:0;animation:briefFlash 1.5s ease-in forwards;pointer-events:none}@keyframes briefFlash{0%{opacity:0}65%{opacity:0}to{opacity:1}}.j-score-number{font-size:2rem;font-weight:800}.j-score-pass{color:var(--color-success)}.j-score-mid{color:#f59e0b}.j-score-fail{color:var(--color-danger)}.j-tamkeen-ring-wrap{position:relative;width:130px;height:130px;margin-bottom:14px}.j-tamkeen-ring-wrap .j-score-number{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.j-tamkeen-ring{transform:rotate(-90deg);display:block}.j-tamkeen-ring-fill{transition:stroke-dashoffset 1s ease;animation:ringFillIn 1s ease forwards}@keyframes ringFillIn{0%{stroke-dashoffset:var(--ring-circumference, 383)}}.j-tamkeen-nudge{font-size:.88rem;color:var(--color-text-light, #64748b);margin:0 0 14px}.j-tamkeen-back-link{font-size:.85rem;color:var(--color-text-light, #64748b);text-decoration:none}.j-tamkeen-back-link:hover{color:var(--color-primary, #6366f1)}.j-tamkeen-session-summary{display:flex;flex-direction:column;align-items:center;gap:2px;margin-bottom:20px;opacity:.75}.j-tamkeen-session-correct{font-size:.88rem;font-weight:600;color:var(--color-text, #555)}.j-tamkeen-session-perf{font-size:.8rem;color:var(--color-text-light, #94a3b8)}.j-tamkeen-mastery-section{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:28px}.j-tamkeen-mastery-ring-wrap{position:relative;width:130px;height:130px}.j-tamkeen-mastery-svg{transform:rotate(-90deg);display:block}.j-tamkeen-mastery-ring-fill{transition:stroke-dashoffset 1.6s cubic-bezier(.2,.8,.3,1.15)}.j-tamkeen-mastery-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:row;gap:2px;font-size:2rem;font-weight:800;color:var(--color-text, #1f2937)}.j-mastery-pct-prev{opacity:.35;font-weight:600}.j-mastery-pct-new{animation:masteryScorePop .5s ease}.j-mastery-pct-arrow{color:#22c55e;font-size:1rem;font-weight:900;animation:masteryArrowBounce .8s ease;margin-inline-start:3px;filter:drop-shadow(0 0 4px rgba(34,197,94,.5))}@keyframes masteryScorePop{0%{opacity:.3;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}75%{transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes masteryArrowBounce{0%{opacity:0;transform:translateY(10px) scale(.5)}40%{opacity:1;transform:translateY(-6px) scale(1.3)}70%{transform:translateY(2px) scale(1)}to{opacity:1;transform:translateY(0) scale(1)}}.j-tamkeen-mastery-change{font-size:.88rem;font-weight:500;color:var(--color-text-light, #64748b);margin:0;text-align:center;line-height:1.5}.j-tamkeen-mastery-delta{position:absolute;top:6px;left:-6px;font-size:.78rem;font-weight:700;padding:2px 7px;border-radius:10px;animation:deltaPopIn .4s ease}.j-delta-up{background:#dcfce7;color:#16a34a}.j-delta-down{background:#fef2f2;color:#dc2626}@keyframes deltaPopIn{0%{opacity:0;transform:scale(.5) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.j-tamkeen-result-nudge{font-size:.73rem;color:var(--color-text-light, #94a3b8);margin-top:-4px}.j-mastery-animating .j-tamkeen-mastery-ring-wrap{animation:masteryRingPulse 1.6s ease}@keyframes masteryRingPulse{0%{transform:scale(1)}50%{transform:scale(1.08)}to{transform:scale(1)}}.score-badge{display:inline-flex;align-items:center;gap:5px;background:#f1f5f9;border:1.5px solid #cbd5e1;border-radius:20px;padding:6px 16px;font-size:1.15rem;font-weight:700;color:#334155;direction:ltr;line-height:1}.score-badge--perfect{background:#f0fdf4;border-color:#86efac;color:#166534;border-width:2px}.score-badge__check{font-size:.85em;color:#22c55e}.score-badge__value{font-variant-numeric:tabular-nums}.score-circle{display:flex;flex-direction:column;align-items:center;gap:8px}.score-circle__ring{width:120px;height:120px;border-radius:50%;border:3px solid #16a34a;background:linear-gradient(135deg,#f0fdf4,#fff);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;animation:scoreCircleEntry .4s ease-out,scoreCircleGlow .5s ease .3s both;direction:ltr}.score-circle--perfect .score-circle__ring{border-width:3.5px}.score-circle__check{font-size:.85rem;color:#22c55e;line-height:1;margin-bottom:-2px}.score-circle__value{font-size:1.75rem;font-weight:800;color:#166534;font-variant-numeric:tabular-nums;line-height:1}.score-circle__label{font-size:.82rem;font-weight:600;color:#166534;animation:scoreCircleEntry .4s ease-out .35s both}@keyframes scoreCircleEntry{0%{opacity:0;transform:scale(.8)}70%{opacity:1;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes scoreCircleGlow{0%{box-shadow:0 0 #22c55e00}30%{box-shadow:0 0 25px #22c55e66}to{box-shadow:0 0 #22c55e00}}.score-badge--small{font-size:.78rem;padding:3px 10px;border-radius:14px;gap:3px;font-weight:600}.score-badge--map{font-size:.72rem;padding:2px 8px;border-radius:12px;gap:3px;font-weight:600;border-width:1px}.j-result-nudge{font-size:.82rem;color:#16a34a;font-weight:500;margin:12px 0 4px;text-align:center}.j-result-nudge--retry{color:#64748b}.score-badge-mastery-label{display:block;text-align:center;margin-top:6px;font-size:.78rem;font-weight:600;color:#166534;animation:scoreBadgeBounce .6s ease .2s both}.score-badge-mastery-label:before{content:"⭐ "}.j-mastery-glow .j-tamkeen-mastery-ring-wrap{animation:masteryGlow 1.5s ease}@keyframes masteryGlow{0%{filter:drop-shadow(0 0 0 transparent)}40%{filter:drop-shadow(0 0 12px rgba(34,197,94,.5))}to{filter:drop-shadow(0 0 0 transparent)}}.j-tamkeen-mastery-loading{display:flex;flex-direction:column;align-items:center;gap:8px;margin:20px 0 28px;color:var(--color-text-light, #64748b);font-size:.85rem}.j-tamkeen-result-actions{display:flex;flex-direction:column;gap:10px;align-items:center;margin-top:20px}.j-btn-pulse{animation:btnPulse 2s ease-in-out infinite}@keyframes btnPulse{0%,to{box-shadow:0 0 #6366f166}50%{box-shadow:0 0 0 8px #6366f100}}.j-result-detail{font-size:.95rem;color:var(--color-text-light);margin-bottom:6px}.j-result-threshold{font-size:.85rem;color:var(--color-text-light);margin-bottom:24px}.j-result-toggle{background:none;border:none;color:var(--color-text-light);cursor:pointer;font-size:.8rem;padding:6px 0;margin:4px 0 12px;opacity:.6;transition:opacity .15s;font-family:inherit}.j-result-toggle:hover{opacity:1}.j-result-details{background:#f8f9fa;border-radius:10px;padding:10px 16px;margin-bottom:16px;font-size:.85rem;color:#666;text-align:center}.j-result-details p{margin:4px 0}.j-review-hint{margin:16px 0 8px;text-align:center}.j-review-hint-title{font-size:.95rem;font-weight:700;color:var(--color-primary, #6c63ff);margin:0 0 4px}.j-review-hint-sub{font-size:.82rem;color:var(--color-text-light);margin:0;font-style:italic}.j-checkpoint-step{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:28px 20px 20px;flex:1;position:relative;overflow:hidden;animation:checkpointEnter .5s ease-out}@keyframes checkpointEnter{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.j-confetti-piece{position:absolute;top:-8px;width:8px;height:8px;border-radius:2px;left:var(--x);opacity:0;pointer-events:none;animation:jConfettiFall 1.2s ease-out var(--delay) forwards}@keyframes jConfettiFall{0%{opacity:1;transform:translateY(0) translate(0) rotate(0)}to{opacity:0;transform:translateY(70vh) translate(var(--drift)) rotate(var(--rot))}}.j-checkpoint-icon{font-size:3.5rem;margin-bottom:12px}.j-checkpoint-icon-final{font-size:4.5rem;margin-bottom:16px;animation:finalIconBounce .8s ease-out}@keyframes finalIconBounce{0%{transform:scale(0);opacity:0}50%{transform:scale(1.3);opacity:1}70%{transform:scale(.9)}to{transform:scale(1)}}.j-checkpoint-title{font-size:1.5rem;margin-bottom:10px;color:var(--color-success)}.j-checkpoint-title-final{font-size:1.8rem;background:linear-gradient(135deg,#f59e0b,#ef4444,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:finalTitleIn .6s ease-out .3s both}@keyframes finalTitleIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.j-checkpoint-final{background:linear-gradient(180deg,#fefce8,#fff 40%)}.j-cp-chain{display:flex;align-items:center;justify-content:center;margin-top:6px;margin-bottom:18px}.j-cp-bead{width:14px;height:14px;border-radius:50%;background:#eaecee;flex-shrink:0}.j-cp-bead-done{background:#818cf8;box-shadow:0 0 6px 2px #818cf833}.j-cp-bead-latest{animation:cpBeadPop .22s ease .15s both}@keyframes cpBeadPop{0%{transform:scale(1);box-shadow:0 0 6px 2px #818cf833}50%{transform:scale(1.12);box-shadow:0 0 12px 5px #818cf84d}to{transform:scale(1);box-shadow:0 0 6px 2px #818cf833}}.j-cp-line{width:18px;height:1px;background:#eff0f1;flex-shrink:0}.j-cp-line-done{background:#818cf840}.j-checkpoint-text{font-size:1rem;color:var(--color-text-light);margin-bottom:8px}.j-checkpoint-groups{font-size:.85rem;color:var(--color-text-light);margin-bottom:24px}.j-checkpoint-pre-btn-text{font-size:.82rem;color:var(--color-text-light);opacity:.7;margin-top:2em;margin-bottom:16px}.j-checkpoint-done-btn{align-self:center;width:92%;max-width:400px;height:46px;padding:0!important;font-size:1rem!important;border-radius:var(--radius)!important}.checkpoint-edit-modal{max-width:520px}.checkpoint-edit-body{display:flex;flex-direction:column;gap:16px;padding:16px 0}.checkpoint-edit-field{display:flex;flex-direction:column;gap:6px}.checkpoint-edit-field label{font-size:.85rem;font-weight:600;color:var(--color-text)}.checkpoint-templates{display:flex;gap:8px;flex-wrap:wrap}.checkpoint-type-bar{display:flex;flex-direction:column;gap:10px;padding:12px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px}.checkpoint-type-info{display:flex;align-items:center;gap:10px}.checkpoint-type-badge{font-size:.78rem;font-weight:700;padding:3px 10px;border-radius:20px;color:#fff}.checkpoint-type-start{background:#3b82f6}.checkpoint-type-middle{background:#f59e0b}.checkpoint-type-near_end{background:#f97316}.checkpoint-type-final{background:#10b981}.checkpoint-type-auto-hint{font-size:.78rem;color:var(--color-text-light)}.checkpoint-type-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.checkpoint-type-select{flex:1;min-width:140px;font-size:.82rem!important;padding:5px 8px!important}.checkpoint-icon-grid{display:flex;flex-wrap:wrap;gap:8px}.checkpoint-icon-option{width:44px;height:44px;font-size:1.5rem;border:2px solid var(--color-border);border-radius:10px;background:var(--color-surface);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.checkpoint-icon-option:hover{border-color:var(--color-primary)}.checkpoint-icon-option.active{border-color:var(--color-primary);background:var(--color-primary-light, #f0e6ff);box-shadow:0 0 0 2px #7c3aed33}.checkpoint-edit-preview{border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.checkpoint-edit-preview-label{font-size:.8rem;font-weight:600;padding:6px 14px;background:var(--color-surface);border-bottom:1px solid var(--color-border);color:var(--color-text-light)}.checkpoint-preview-box{padding:24px 16px!important;min-height:auto;flex:none}.j-step-edit-btn{margin-right:auto;padding:2px 8px!important;font-size:.8rem;opacity:.6;transition:opacity .15s}.j-step-item:hover .j-step-edit-btn{opacity:1}@media(max-width:640px){.j-form-row{flex-direction:column}.j-journey-grid{grid-template-columns:1fr}.j-journey-progress-header{flex-direction:column;gap:12px}.j-fc-card{height:220px}.j-fc-front p{font-size:1.3rem}.j-fc-back p{font-size:1.1rem}.j-step-body{padding:20px 16px}.j-step-header-v2{gap:2px}.j-group-summary{display:none}}.j-drills-playing{display:flex;flex-direction:column;align-items:center;width:100%}.j-drills-header{width:100%;text-align:center;margin-bottom:12px}.j-drills-timer{font-size:.95rem;color:var(--color-text-light);font-variant-numeric:tabular-nums}.j-drills-progress{width:100%;margin-bottom:14px;display:flex;flex-direction:column;gap:6px}.j-drills-progress-bar{width:100%;height:8px;background:var(--color-border);border-radius:99px;overflow:hidden}.j-drills-progress-fill{height:100%;background:var(--color-primary);border-radius:99px;transition:width .2s ease}.j-drills-progress-text{font-size:.88rem;font-weight:700;color:var(--color-text);white-space:nowrap;font-variant-numeric:tabular-nums;direction:ltr;unicode-bidi:isolate}.j-drills-card{width:100%;background:var(--color-surface);border-radius:14px;box-shadow:var(--shadow-md);border:1px solid var(--color-border);padding:28px 24px;margin-bottom:20px}@keyframes jCardEnter{0%{opacity:0;transform:translate(-30px) scale(.97)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes jCardExit{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(30px) scale(.97)}}.j-drills-card.j-card-enter{animation:jCardEnter .3s ease forwards}.j-drills-card.j-card-exit{animation:jCardExit .3s ease forwards}@keyframes jShake{0%,to{transform:translate(0)}15%{transform:translate(-6px)}30%{transform:translate(6px)}45%{transform:translate(-4px)}60%{transform:translate(4px)}75%{transform:translate(-2px)}90%{transform:translate(2px)}}.j-drills-card.j-card-shake{animation:jShake .4s ease}.j-drills-q-body{margin-bottom:24px}.j-drills-q-body p{font-size:1.15rem;font-weight:600;line-height:1.6}.j-drills-options{display:flex;flex-direction:column;gap:10px}.j-drills-opt-btn{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;border:2px solid var(--color-border);border-radius:10px;background:var(--color-surface);cursor:pointer;font-size:1rem;text-align:right;transition:all var(--transition);-webkit-tap-highlight-color:transparent;outline:none}.j-drills-opt-btn:hover{border-color:var(--color-border);background:var(--color-surface)}.j-drills-opt-btn:focus,.j-drills-opt-btn:active,.j-drills-opt-btn:focus-visible{outline:none;box-shadow:none;border-color:var(--color-border);background:var(--color-surface)}.j-drills-opt-btn.j-opt-locked{cursor:default;opacity:.7}.j-drills-opt-btn.j-opt-locked:hover{border-color:var(--color-border);background:var(--color-surface)}.j-drills-opt-btn.j-opt-correct{border-color:#16a34a!important;background:#dcfce7!important;opacity:1!important}.j-drills-opt-btn.j-opt-wrong{border-color:#dc2626!important;background:#fee2e2!important;opacity:1!important}.j-drills-continue-btn{display:block;margin:16px auto 0;padding:10px 32px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s}.j-drills-continue-btn:hover{background:var(--color-primary-hover)}.j-drills-continue-btn.j-continue-correct{background:#22c55e}.j-drills-continue-btn.j-continue-correct:hover{background:#16a34a}.j-drills-continue-btn.j-continue-wrong{background:#ef4444}.j-drills-continue-btn.j-continue-wrong:hover{background:#dc2626}.j-drills-round-transition{text-align:center;padding:60px 20px;animation:jRoundFadeIn .3s ease}.j-round-transition-icon{font-size:3rem;margin-bottom:16px;animation:jRoundSpin 1s ease-in-out}.j-round-transition-title{font-size:1.3rem;font-weight:700;color:var(--color-text);margin-bottom:8px}.j-round-transition-count{font-size:1rem;color:var(--color-text-light)}@keyframes jRoundFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes jRoundSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:640px){.j-drills-card{padding:20px 16px}.j-drills-q-body p{font-size:1.1rem}}.j-daily-hero{background:linear-gradient(135deg,#6c63ff,#48c6ef);color:#fff;border-radius:var(--radius-lg, 16px);padding:32px 24px 28px;text-align:center;cursor:pointer;transition:transform .18s,box-shadow .18s;margin-bottom:32px;position:relative;overflow:hidden}.j-daily-hero:before{content:"";position:absolute;top:-40%;right:-20%;width:260px;height:260px;background:#ffffff12;border-radius:50%;pointer-events:none}.j-daily-hero:hover{transform:translateY(-3px);box-shadow:0 10px 30px #6c63ff59}.j-daily-hero-locked{background:linear-gradient(135deg,#a0a0b0,#c4c8d0);cursor:default}.j-daily-hero-locked:hover{transform:none;box-shadow:none}.j-daily-hero-icon{font-size:2.5rem;margin-bottom:8px}.j-daily-hero-title{font-size:1.5rem;font-weight:800;margin:0 0 6px;color:#fff}.j-daily-hero-subtitle{font-size:.95rem;opacity:.9;margin:0 0 12px}.j-daily-hero-stat{display:inline-block;background:#fff3;padding:5px 16px;border-radius:20px;font-size:.9rem;font-weight:600;margin-bottom:16px}.j-daily-hero-btn{display:block;margin:0 auto;background:#fff;color:#6c63ff;border:none;padding:12px 36px;border-radius:var(--radius-sm, 8px);font-size:1.05rem;font-weight:700;cursor:pointer;transition:background .15s,transform .1s}.j-daily-hero-btn:hover{background:#f0eeff;transform:scale(1.03)}.j-mastery-ring-wrap{position:relative;width:80px;height:80px;margin:8px auto 10px}.j-mastery-ring{transform:rotate(-90deg);display:block}.j-mastery-ring-fill{transition:stroke-dashoffset 1s ease}.j-mastery-ring-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:1.15rem;font-weight:800;color:#fff}.j-mastery-detail-toggle{background:none;border:none;color:#ffffffb3;font-size:.75rem;cursor:pointer;padding:2px 8px;margin:2px auto 6px;display:block;transition:color .2s}.j-mastery-detail-toggle:hover{color:#fff}.j-mastery-detail{background:#ffffff21;border-radius:10px;padding:10px 16px;margin:0 auto 10px;max-width:300px;animation:masteryDetailSlide .25s ease}.j-mastery-detail-meaning{font-size:.85rem;margin:0 0 4px;opacity:.95}.j-mastery-detail-stats{font-size:.78rem;margin:0;opacity:.75}.j-mastery-detail-note{font-size:.7rem;margin:6px 0 0;opacity:.6;font-style:italic}.j-mastery-drop-hint{font-size:.82rem;background:#ffffff2e;padding:6px 14px;border-radius:8px;margin:0 auto 8px;cursor:pointer;animation:dropHintFadeIn .5s ease}@keyframes dropHintFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes masteryDetailSlide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.j-journeys-section-title{font-size:1.1rem;font-weight:700;color:var(--color-text, #333);margin:0 0 14px;padding-bottom:8px;border-bottom:2px solid var(--color-border, #e5e7eb)}.j-tamkeen-section{margin-top:28px;margin-bottom:20px}.j-tamkeen-card{background:linear-gradient(135deg,#6c63ff,#48c6ef);color:#fff;border-radius:var(--radius-lg, 16px);padding:24px;cursor:pointer;transition:transform .15s,box-shadow .15s;text-align:center}.j-tamkeen-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6c63ff4d}.j-tamkeen-title{font-size:1.4rem;font-weight:700;margin-bottom:6px}.j-tamkeen-desc{font-size:.95rem;opacity:.9;margin-bottom:14px}.j-tamkeen-btn{display:inline-block;background:#ffffff40;padding:8px 24px;border-radius:var(--radius-sm, 8px);font-weight:600;font-size:.95rem;transition:background .15s}.j-tamkeen-card:hover .j-tamkeen-btn{background:#ffffff59}.j-tamkeen-modal{max-width:500px;max-height:85vh;display:flex;flex-direction:column}.j-tamkeen-modal h3{text-align:center;margin-bottom:4px}.j-tamkeen-modal-desc{text-align:center;color:var(--color-text-light);margin-bottom:16px;font-size:.9rem}.j-tamkeen-scroll-body{flex:1;overflow-y:auto;margin-bottom:16px}.j-tamkeen-source-section{margin-bottom:16px}.j-tamkeen-label{display:block;font-weight:600;margin-bottom:8px;font-size:.95rem}.j-tamkeen-checkboxes{display:flex;flex-direction:column;gap:8px}.j-tamkeen-journey-class{color:var(--color-text-light);font-size:.85rem}.j-tamkeen-count-options{display:flex;gap:8px;flex-wrap:wrap}.j-tamkeen-count-btn{padding:6px 16px;border:2px solid var(--color-border);border-radius:var(--radius-sm, 8px);background:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s}.j-tamkeen-count-btn.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.j-tamkeen-modal-actions{display:flex;flex-direction:column;gap:8px}.j-tamkeen-analyzing{text-align:center;padding:40px 20px}.j-tamkeen-analyzing .spinner{margin:0 auto 16px}.j-weakness-box{margin-top:16px;padding:12px 16px;background:var(--color-bg-soft, #f8f9fa);border-radius:var(--radius-sm, 8px);border-right:4px solid var(--color-primary, #6c63ff)}.j-weakness-label{display:block;font-weight:600;font-size:.85rem;margin-bottom:6px;color:var(--color-text-light)}.j-weakness-list{list-style:none;padding:0;margin:0}.j-weakness-list li{font-size:.9rem;padding:2px 0;color:var(--color-text)}.j-weakness-list li:before{content:"•";margin-left:6px;color:var(--color-primary)}.j-weakness-debug{margin-top:6px;padding-top:6px;border-top:1px dashed #ddd;font-size:.75rem;color:#999;direction:ltr;text-align:left;font-family:monospace;word-break:break-all}.j-deck-picker-modal{max-width:500px;max-height:80vh;overflow-y:auto}.j-deck-picker-list{display:flex;flex-direction:column;gap:6px;max-height:400px;overflow-y:auto}.j-deck-picker-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--color-bg-soft, #f8f9fa);border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;text-align:right;font-size:.95rem}.j-deck-picker-item:hover{background:#edf2f7;border-color:var(--color-primary, #6c63ff)}.j-deck-picker-title{font-weight:600}.j-deck-picker-type{font-size:.8rem;color:#888;background:#eee;padding:2px 8px;border-radius:10px}.j-deck-link-bar{display:flex;align-items:center;gap:12px;padding:8px 0;margin-bottom:8px;border-bottom:1px solid #eee}.j-deck-linked-info{font-size:.85rem;color:#888}.j-deck-linked-badge{font-size:.85rem;margin-right:4px}.j-tamkeen-session{background:#f5f3ff}.j-mode-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;margin-bottom:14px;border-bottom:1px solid var(--color-border, #e2e8f0)}.j-mode-badge{font-size:.78rem;font-weight:700;color:var(--color-primary);background:var(--color-primary-light);padding:4px 14px;border-radius:20px;letter-spacing:.02em}.j-mode-back{font-size:.85rem;color:var(--color-primary);text-decoration:none}.j-mode-back:hover{text-decoration:underline}.j-tamkeen-session .j-mode-header{border-bottom-color:#e9e5f5}.j-tamkeen-session .j-mode-badge{color:#6d28d9;background:#ede9fe}.j-tamkeen-session .j-mode-back{color:#7c3aed}.j-tamkeen-session .j-drills-progress{flex-direction:row;align-items:center;gap:10px}.j-tamkeen-session .j-drills-progress-bar{height:10px;background:#e9e5f5}.j-tamkeen-session .j-drills-progress-fill{background:#8b5cf6}.j-tamkeen-card-area{position:relative}.mini-streak-celebrate>.mcq-question-card,.mini-streak-celebrate>.embed-card-wrapper{animation:ms-shake .15s ease;box-shadow:0 0 18px 5px #4caf5059}@keyframes ms-shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}50%{transform:translate(3px)}75%{transform:translate(-2px)}}.mini-streak-bubble{position:absolute;top:-8px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#43a047,#66bb6a);color:#fff;padding:5px 16px;border-radius:20px;font-size:.82rem;font-weight:600;white-space:nowrap;z-index:10;pointer-events:none;animation:ms-bubble-in .25s ease forwards,ms-bubble-out .3s ease 1.4s forwards;box-shadow:0 3px 10px #4caf504d}@keyframes ms-bubble-in{0%{opacity:0;transform:translate(-50%) translateY(6px) scale(.85)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes ms-bubble-out{0%{opacity:1;transform:translate(-50%) translateY(0) scale(1)}to{opacity:0;transform:translate(-50%) translateY(-6px) scale(.85)}}.mini-confetti{position:absolute;top:8px;left:50%;width:0;height:0;pointer-events:none;z-index:9}.mini-confetti-dot{position:absolute;width:6px;height:6px;border-radius:50%;opacity:0;animation:ms-confetti-burst .8s ease-out forwards}@keyframes ms-confetti-burst{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(var(--mc-tx),var(--mc-ty)) scale(.3)}}
