@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;600;800&family=Nunito:wght@600;800;900&display=swap";:root{--primary:#ff6b6b;--primary-dark:#e24a4a;--secondary:#4ecdc4;--accent:#ffe66d;--background:#1a1a2e;--card-bg:#ffffff1a;--text-main:#f7fff7;--text-muted:#f7fff7b3;--success:#2ecc71;--error:#e74c3c}*{box-sizing:border-box;margin:0;padding:0;font-family:Outfit,sans-serif}body{color:var(--text-main);background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;overflow-x:hidden}#root{width:100%;max-width:800px;margin:0 auto;padding:2rem}h1,h2,h3,h4,h5,h6{letter-spacing:1px;font-family:Nunito,sans-serif}.glass-panel{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);border:1px solid #fff3;border-radius:24px;padding:2.5rem;animation:.5s ease-out forwards slideUp;box-shadow:0 8px 32px #0000004d}.title{text-align:center;background:linear-gradient(45deg, var(--primary), var(--accent));-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 4px #0000004d);-webkit-background-clip:text;margin-bottom:2rem;font-size:3.5rem;font-weight:900}.btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:16px;justify-content:center;align-items:center;gap:.5rem;padding:1rem 2rem;font-family:Nunito,sans-serif;font-size:1.5rem;font-weight:800;transition:all .2s cubic-bezier(.175,.885,.32,1.275);display:inline-flex;box-shadow:0 4px 15px #ff6b6b66}.btn:hover{background:var(--primary-dark);transform:translateY(-4px)scale(1.05);box-shadow:0 8px 25px #ff6b6b99}.btn:active{transform:translateY(2px)scale(.95)}.btn-secondary{background:var(--secondary);box-shadow:0 4px 15px #4ecdc466}.btn-secondary:hover{background:#3eb5ad;box-shadow:0 8px 25px #4ecdc499}.input-group{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.input-field{color:#1a1a2e;text-align:center;background:#ffffffe6;border:4px solid #0000;border-radius:16px;outline:none;width:100%;padding:1.2rem;font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:600;transition:all .3s}.input-field:focus{border-color:var(--secondary);transform:scale(1.02);box-shadow:0 0 20px #4ecdc466}.input-field.error{border-color:var(--error);animation:.4s cubic-bezier(.36,.07,.19,.97) both shake}.input-field.success{border-color:var(--success)}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-col{flex-direction:column;gap:1.5rem;display:flex}.speaker-btn{background:var(--accent);color:#1a1a2e;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:2.5rem;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;box-shadow:0 4px 15px #ffe66d66}.speaker-btn:hover{transform:scale(1.15)rotate(10deg);box-shadow:0 8px 25px #ffe66d99}.speaker-btn.playing{animation:1s infinite pulse}.word-list{max-height:300px;padding-right:10px;list-style:none;overflow-y:auto}.word-list::-webkit-scrollbar{width:8px}.word-list::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.word-list::-webkit-scrollbar-thumb{background:var(--secondary);border-radius:4px}.word-item{background:#ffffff26;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:.8rem;padding:1rem;transition:transform .2s;display:flex}.word-item:hover{background:#ffffff40;transform:translate(5px)}.word-item .word-text{font-size:1.2rem;font-weight:600}.word-item .word-stats{color:var(--accent);font-size:.9rem}.delete-btn{color:var(--error);border:1px solid var(--error);cursor:pointer;background:0 0;border-radius:8px;padding:.4rem .8rem;transition:all .2s}.delete-btn:hover{background:var(--error);color:#fff}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{10%,90%{transform:translate(-1px)}20%,80%{transform:translate(2px)}30%,50%,70%{transform:translate(-4px)}40%,60%{transform:translate(4px)}}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #ffe66db3}70%{transform:scale(1.1);box-shadow:0 0 0 15px #ffe66d00}to{transform:scale(1);box-shadow:0 0 #ffe66d00}}@keyframes popIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes bounceYay{0%{opacity:0;transform:scale(.5)translateY(0)}50%{opacity:1;transform:scale(1.2)translateY(-20px)}75%{transform:scale(.9)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.feedback-msg{text-align:center;min-height:2.5rem;font-family:Nunito,sans-serif;font-size:1.5rem;font-weight:800;animation:.3s cubic-bezier(.175,.885,.32,1.275) forwards popIn}.feedback-msg.yay{animation:.6s cubic-bezier(.175,.885,.32,1.275) forwards bounceYay}.feedback-success{color:var(--success)}.feedback-error{color:var(--error)}.nav-bar{justify-content:space-between;margin-bottom:2rem;display:flex}.nav-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:8px;padding:.5rem 1rem;font-family:Nunito,sans-serif;font-weight:600;transition:all .2s}.nav-btn:hover{background:#fff3}.admin-theme{--admin-bg:#0f172a;--admin-panel:#1e293b;--admin-text:#f8fafc;--admin-muted:#94a3b8;--admin-border:#334155;--admin-accent:#38bdf8;--admin-success:#34d399;--admin-error:#f87171;--admin-radius:6px;background-color:var(--admin-bg);color:var(--admin-text);min-height:calc(100vh - 80px);padding:2rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.admin-theme .admin-container{max-width:100%;margin:0 auto}.admin-theme .admin-panel{background-color:var(--admin-panel);border:1px solid var(--admin-border);border-radius:var(--admin-radius);padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.admin-theme .admin-header{border-bottom:1px solid var(--admin-border);justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.admin-theme .admin-title{color:var(--admin-text);align-items:center;gap:.75rem;margin:0;font-size:1.75rem;font-weight:600;display:flex}.admin-theme .admin-btn{background-color:var(--admin-accent);color:#0f172a;border-radius:var(--admin-radius);cursor:pointer;border:none;align-items:center;gap:.5rem;padding:.5rem 1rem;font-weight:500;transition:opacity .2s;display:inline-flex}.admin-theme .admin-btn:hover{opacity:.9}.admin-theme .admin-btn-secondary{color:var(--admin-text);border:1px solid var(--admin-border);background-color:#0000}.admin-theme .admin-btn-secondary:hover{background-color:#ffffff0d}.admin-theme .admin-btn-danger{color:var(--admin-error);background-color:#0000;border:1px solid #f871714d}.admin-theme .admin-btn-danger:hover{background-color:#f871711a}.admin-theme .admin-input{border:1px solid var(--admin-border);color:var(--admin-text);border-radius:var(--admin-radius);background-color:#0f172a;width:100%;padding:.5rem .75rem}.admin-theme .admin-input:focus{border-color:var(--admin-accent);outline:none}.admin-theme .admin-table-container{border:1px solid var(--admin-border);border-radius:var(--admin-radius);overflow-x:auto}.admin-theme .admin-table{border-collapse:collapse;text-align:left;width:100%}.admin-theme .admin-table th{color:var(--admin-muted);text-transform:uppercase;border-bottom:1px solid var(--admin-border);cursor:pointer;-webkit-user-select:none;user-select:none;background-color:#0f172a;padding:.75rem 1rem;font-size:.875rem;font-weight:600}.admin-theme .admin-table th:hover{color:var(--admin-text)}.admin-theme .admin-table td{border-bottom:1px solid var(--admin-border);color:var(--admin-text);padding:1rem}.admin-theme .admin-table tr:last-child td{border-bottom:none}.admin-theme .admin-table tr:hover td{background-color:#ffffff05}html[dir=rtl] .admin-theme .admin-table{text-align:right}body:has(.admin-theme) #root{width:95%;max-width:1440px;padding:1.5rem}.skill-map-outer{background:linear-gradient(#0f1c30 0%,#0a1220 50%,#050910 100%);border:1px solid #ffffff14;border-radius:20px;width:100%;position:relative;overflow:hidden;box-shadow:0 10px 40px #0009}.skill-map-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:20;background:#0003;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex;position:relative}.skill-map-title-bar{color:#fff;align-items:center;gap:.5rem;font-family:Nunito,sans-serif;font-size:1.1rem;font-weight:800;display:flex}.skill-map-container{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;width:100%;min-height:520px;max-height:650px;padding:2rem 0;position:relative;overflow:hidden auto}.skill-map-container::-webkit-scrollbar{width:6px}.skill-map-container::-webkit-scrollbar-track{background:0 0}.skill-map-container::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.skill-map-container::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.skill-map-grid{pointer-events:none;z-index:1;background-image:radial-gradient(#ffffff09 1.5px,#0000 1.5px);background-size:32px 32px;width:100%;height:100%;position:absolute;top:0;left:0}.skill-map-pathway{pointer-events:none;z-index:3;width:100%;height:100%;position:absolute;top:0;left:0}.map-path-line{stroke:#ffdb58;stroke-width:6px;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:10 14;fill:none;filter:drop-shadow(0 2px 6px #ffdb584d)}.map-path-line-unlocked{stroke:#38bdf8;filter:drop-shadow(0 2px 8px #38bdf866)}.map-node{cursor:pointer;z-index:10;-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;width:58px;height:58px;font-family:Nunito,sans-serif;font-weight:900;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;position:absolute;transform:translate(-50%,-50%)}.map-node.locked{color:#475569;cursor:not-allowed;opacity:.8;background:#182030;border:4px solid #334155;box-shadow:0 4px 8px #0006}.map-node.active{background:var(--subject-color,#38bdf8);color:#fff;box-shadow:0 0 20px var(--subject-color,#38bdf8), 0 6px 12px #0006;border:4px solid #fff;animation:2.5s ease-in-out infinite activeNodePulse}.map-node.mastered{color:#1e1b4b;background:#facc15;border:4px solid #fff;box-shadow:0 0 16px #facc1573,0 5px 10px #00000059}.map-node:not(.locked):hover{z-index:15;box-shadow:0 0 25px var(--subject-color,#38bdf8), 0 10px 20px #00000080;transform:translate(-50%,-50%)scale(1.18)rotate(6deg)!important}.map-node.mastered:hover{box-shadow:0 0 25px #facc15b3,0 10px 20px #00000080}.map-node.focused{outline:4px solid var(--subject-color,#38bdf8);outline-offset:4px;z-index:15;animation:1.5s ease-in-out infinite focusedNodePulse;transform:translate(-50%,-50%)scale(1.18)!important}@keyframes focusedNodePulse{0%,to{outline-color:var(--subject-color,#38bdf8);box-shadow:0 0 18px var(--subject-color,#38bdf8)}50%{box-shadow:0 0 28px var(--subject-color,#38bdf8);outline-color:#fff}}.map-node-inner{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.map-node-text{text-shadow:0 1px 2px #0000004d;font-size:1.15rem}@keyframes activeNodePulse{0%,to{box-shadow:0 0 15px var(--subject-color,#38bdf8), 0 6px 12px #0006}50%{box-shadow:0 0 28px var(--subject-color,#38bdf8), 0 4px 6px #0003}}.map-avatar{pointer-events:none;z-index:25;justify-content:center;align-items:center;width:54px;height:54px;font-size:2.55rem;transition:left .7s cubic-bezier(.25,1,.5,1),top .7s cubic-bezier(.25,1,.5,1);animation:1.4s ease-in-out infinite avatarBounce;display:flex;position:absolute;transform:translate(32px,-50%)}@keyframes avatarBounce{0%,to{transform:translate(32px,-50%)translateY(0)scaleY(1)}50%{transform:translate(32px,-50%)translateY(-10px)scaleY(.95)}60%{transform:translate(32px,-50%)translateY(-10px)scaleY(1.02)}}.map-scenery{-webkit-user-select:none;user-select:none;pointer-events:none;z-index:2;position:absolute}.scenery-cloud{opacity:.18;font-size:2rem;animation:7s ease-in-out infinite floatCloud}.scenery-tree{opacity:.35;font-size:1.5rem}.scenery-castle{opacity:.12;font-size:2.8rem}@keyframes floatCloud{0%,to{transform:translate(0)translateY(0)}50%{transform:translate(12px)translateY(-4px)}}.map-level-modal{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;background:#0d172ae6;border:1px solid #ffffff1f;border-radius:18px;padding:1.25rem 1.5rem;animation:.4s cubic-bezier(.16,1,.3,1) modalSlideUp;position:absolute;bottom:16px;left:16px;right:16px;box-shadow:0 10px 40px #000000b3,inset 0 1px 1px #ffffff1a}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(110%)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.modal-level-tag{text-transform:uppercase;letter-spacing:2px;color:var(--subject-color,#38bdf8);font-size:.8rem;font-weight:800}.modal-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.2rem;transition:color .2s;display:flex}.modal-close-btn:hover{color:#fff;background:#ffffff14}.modal-title{color:#fff;text-align:left;margin:0 0 .4rem;font-family:Nunito,sans-serif;font-size:1.15rem;font-weight:800}.modal-subject-info{color:var(--text-muted);text-align:left;align-items:center;gap:.4rem;margin-bottom:.75rem;font-size:.8rem;display:flex}.modal-mastery-section{align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.modal-mastery-bar{background:#ffffff14;border-radius:4px;flex:1;height:8px;overflow:hidden}.modal-mastery-fill{background:linear-gradient(90deg,#38bdf8,#2ecc71);border-radius:4px;height:100%}.modal-mastery-pct{color:#2ecc71;text-align:right;min-width:35px;font-size:.85rem;font-weight:800}.modal-play-btn{color:#111b2c;cursor:pointer;background:linear-gradient(135deg,#ffe66d,#facc15);border:none;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.9rem;font-size:1.1rem;font-weight:800;transition:all .2s;animation:2s ease-in-out infinite playBtnPulse;display:flex;box-shadow:0 0 15px #facc1559}.modal-play-btn:hover{background:linear-gradient(135deg,#fff,#ffe66d);transform:translateY(-2px);box-shadow:0 0 25px #facc1599}.modal-play-btn:active{transform:translateY(0)}@keyframes playBtnPulse{0%,to{box-shadow:0 0 15px #facc1559}50%{box-shadow:0 0 24px #facc1599}}.skill-progress-overview{margin-bottom:1.5rem}.skill-progress-bar-bg{background:#ffffff1a;border-radius:5px;height:10px;margin-bottom:.5rem;overflow:hidden}.skill-progress-bar-fill{background:linear-gradient(90deg,#4ecdc4,#2ecc71);border-radius:5px;height:100%;transition:width .6s}.skill-progress-stats{flex-wrap:wrap;justify-content:space-between;gap:.5rem;display:flex}.skill-stat{color:var(--text-muted);align-items:center;gap:.3rem;font-size:.8rem;font-weight:600;display:flex}.skill-stat-mastered{color:#2ecc71}.skill-stat-active{color:#38bdf8}.skill-stat-locked{color:#ffffff4d}.skill-tree{flex-direction:column;gap:.75rem;display:flex}.skill-subject{background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;overflow:hidden}.skill-subject-header{cursor:pointer;width:100%;color:var(--text-main);background:0 0;border:none;justify-content:space-between;align-items:center;padding:1rem 1.25rem;transition:background .2s;display:flex}.skill-subject-header:hover{background:#ffffff0d}.skill-subject-info{align-items:center;gap:.75rem;display:flex}.skill-subject-icon{border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.3rem;display:flex}.skill-subject-name{font-family:Nunito,sans-serif;font-size:1.1rem;font-weight:800}.skill-subject-pct{color:var(--text-muted);font-size:.8rem}.skill-subject-expand{color:var(--text-muted);align-items:center;gap:.75rem;display:flex}.skill-mini-bar{background:#ffffff1a;border-radius:2px;width:60px;height:4px;overflow:hidden}.skill-mini-bar-fill{border-radius:2px;height:100%;transition:width .5s}.skill-subject-body{padding:0 1.25rem 1rem;animation:.3s skillSlideDown}@keyframes skillSlideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:2000px}}.skill-strand{margin-bottom:.75rem}.skill-strand-label{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);border-bottom:1px solid #ffffff0f;margin-bottom:.5rem;padding-bottom:.25rem;font-size:.75rem}.skill-module{margin-bottom:.5rem;margin-left:.5rem}.skill-module-name{color:var(--text-main);margin-bottom:.25rem;font-size:.9rem;font-weight:700}.skill-competency{margin-bottom:.35rem;margin-left:.75rem}.skill-competency-name{color:var(--text-muted);margin-bottom:.2rem;font-size:.8rem;font-weight:600}.skill-micros{flex-direction:column;gap:.3rem;margin-left:.5rem;display:flex}.skill-micro{border-radius:8px;align-items:center;gap:.5rem;padding:.4rem .6rem;transition:all .2s;display:flex}.skill-micro-mastered{color:#2ecc71;background:#2ecc7114}.skill-micro-active{color:#38bdf8;background:#38bdf814;animation:3s infinite microPulse}.skill-micro-locked{color:#fff3;opacity:.5}@keyframes microPulse{0%,to{box-shadow:0 0 #38bdf800}50%{box-shadow:0 0 0 3px #38bdf826}}.skill-micro-info{flex:1;min-width:0}.skill-micro-name{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;display:block;overflow:hidden}.skill-micro-bar{background:#ffffff1a;border-radius:2px;height:3px;margin-top:2px;overflow:hidden}.skill-micro-bar-fill{background:currentColor;border-radius:2px;height:100%;transition:width .4s}.skill-micro-pct{text-align:right;min-width:30px;font-size:.75rem;font-weight:700}.ds-container{max-width:600px;margin:0 auto}.ds-loading{text-align:center;color:var(--text-muted);padding:3rem}.ds-loading-icon{color:var(--accent);margin-bottom:1rem;animation:1.5s infinite dsSpinPulse}@keyframes dsSpinPulse{0%{opacity:1;transform:scale(1)rotate(0)}50%{opacity:.7;transform:scale(1.2)rotate(180deg)}to{opacity:1;transform:scale(1)rotate(360deg)}}.ds-celebration{text-align:center;padding:2rem 0}.ds-celebrate-icon{margin-bottom:1rem;animation:1s ease-out dsCelebrate}@keyframes dsCelebrate{0%{opacity:0;transform:scale(0)rotate(-180deg)}60%{opacity:1;transform:scale(1.3)rotate(10deg)}to{transform:scale(1)rotate(0)}}.ds-xp-badge{color:var(--accent);background:linear-gradient(135deg,#ffe66d33,#ff6b6b33);border:1px solid #ffe66d4d;border-radius:12px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem 1.5rem;font-family:Nunito,sans-serif;font-size:1.5rem;font-weight:800;display:inline-flex}.ds-progress-bar{background:#ffffff1a;border-radius:3px;height:6px;margin-bottom:1.5rem;overflow:hidden}.ds-progress-fill{background:linear-gradient(90deg,#4ecdc4,#2ecc71);border-radius:3px;height:100%;transition:width .5s}.ds-activities{flex-direction:column;gap:.6rem;display:flex}.ds-activity{cursor:pointer;border-radius:12px;align-items:center;gap:.75rem;padding:.85rem 1rem;transition:all .2s;display:flex}.ds-activity-pending{background:#ffffff0d;border:1px solid #ffffff1a}.ds-activity-pending:hover{background:#ffffff1a;transform:translate(4px);box-shadow:0 2px 12px #0003}.ds-activity-done{cursor:default;opacity:.7;background:#2ecc710f;border:1px solid #2ecc7126}.ds-activity-num{color:#1a1a2e;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:800;display:flex}.ds-activity-info{flex:1;min-width:0}.ds-activity-type{text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:700}.ds-activity-name{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.ds-activity-action{flex-shrink:0;align-items:center;display:flex}.ds-activity-score{color:#2ecc71;font-size:.9rem;font-weight:800}
