@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--bg-primary:#0a0b10;--bg-secondary:#121420;--bg-tertiary:#1a1d30;--border-color:#ffffff14;--border-glow:#6366f133;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--color-primary:#6366f1;--color-primary-glow:#6366f159;--color-secondary:#10b981;--color-secondary-glow:#10b98159;--color-accent:#f59e0b;--color-accent-glow:#f59e0b59;--color-danger:#ef4444;--glass-bg:#121420b3;--glass-border:#ffffff0f;--glass-shadow:#0000004d;--radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce:all .5s cubic-bezier(.175, .885, .32, 1.275)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;background-image:radial-gradient(at 0 0,#6366f126 0,#0000 50%),radial-gradient(at 100% 100%,#10b9811a 0,#0000 50%);min-height:100vh;line-height:1.5;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;color:var(--text-primary);font-weight:700}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:0 8px 32px 0 var(--glass-shadow);border-radius:var(--radius-md);transition:var(--transition-smooth);padding:24px}.glass-card:hover{border-color:#ffffff1f;box-shadow:0 12px 40px #0006}button{font-family:var(--font-sans);cursor:pointer;transition:var(--transition-smooth);border:none;outline:none;font-weight:600}header{border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:100;background:#0a0b10cc;justify-content:space-between;align-items:center;padding:20px 40px;display:flex;position:sticky;top:0}.logo-container{align-items:center;gap:12px;display:flex}.logo-icon{background:linear-gradient(135deg, var(--color-primary), #4f46e5);border-radius:var(--radius-sm);width:40px;height:40px;box-shadow:0 0 15px var(--color-primary-glow);justify-content:center;align-items:center;font-size:20px;font-weight:800;display:flex}.logo-text h1{background:linear-gradient(135deg, var(--text-primary), var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:20px}.logo-text p{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:11px}.nav-tabs{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);gap:4px;padding:6px;display:flex}.nav-tab{border-radius:calc(var(--radius-md) - 6px);color:var(--text-secondary);background:0 0;align-items:center;gap:8px;padding:10px 20px;font-size:14px;display:flex}.nav-tab:hover{color:var(--text-primary);background:#ffffff08}.nav-tab.active{color:#fff;background:var(--color-primary);box-shadow:0 4px 12px var(--color-primary-glow)}main{flex-direction:column;flex:1;gap:30px;width:100%;max-width:1200px;margin:0 auto;padding:40px 20px;display:flex}footer{text-align:center;border-top:1px solid var(--border-color);color:var(--text-muted);padding:24px;font-size:14px}.btn{border-radius:var(--radius-md);justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;text-decoration:none;display:inline-flex}.btn-sm{width:40px;min-width:40px;height:40px;padding:0;font-size:18px}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 4px 14px var(--color-primary-glow)}.btn-primary:hover{box-shadow:0 6px 20px var(--color-primary-glow);background:#4f46e5;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:#ffffff0d;transform:translateY(-2px)}.btn-secondary:active{transform:translateY(0)}.btn-success{background:var(--color-secondary);color:#fff;box-shadow:0 4px 14px var(--color-secondary-glow)}.btn-success:hover{box-shadow:0 6px 20px var(--color-secondary-glow);background:#059669;transform:translateY(-2px)}@keyframes pulseGlow{0%,to{box-shadow:0 0 15px var(--color-primary-glow)}50%{box-shadow:0 0 25px #6366f199}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.grid-2{grid-template-columns:1fr 1fr;gap:30px;display:grid}@media (width<=900px){.grid-2{grid-template-columns:1fr}header{grid-template-rows:auto auto;grid-template-columns:1fr auto;align-items:center;gap:16px;padding:16px 20px;display:grid}.logo-container{grid-area:1/1;justify-content:flex-start}.theme-toggle-btn{grid-area:1/2;justify-self:end}.nav-tabs{grid-area:2/1/auto/span 2;justify-content:space-between;gap:4px;width:100%;padding:4px;display:flex}.nav-tab{flex:1;justify-content:center;gap:4px;padding:8px 4px;font-size:13px}.hide-mobile{display:none}main{gap:16px;padding:16px 12px}}body.light-mode{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--border-color:#0f172a14;--border-glow:#6366f11f;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#64748b;--glass-bg:#ffffffd9;--glass-border:#0f172a0f;--glass-shadow:#0f172a0a;--color-primary-glow:#6366f126;--color-secondary-glow:#10b98126;--finger-inactive-start:#cbd5e1;--finger-inactive-end:#94a3b8;--bead-inactive-start:#cbd5e1;--bead-inactive-end:#94a3b8;background-image:radial-gradient(at 0 0,#6366f10f 0,#0000 50%),radial-gradient(at 100% 100%,#10b9810a 0,#0000 50%)}body.light-mode header{background:#fffc;border-bottom:1px solid #0f172a14}body.light-mode .btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}body.light-mode .btn-secondary:hover{background:#0000000a}body.light-mode .nav-tab.active,body.light-mode .toggle-btn.active{color:var(--color-primary);box-shadow:none;background:#6366f11f}body.light-mode .level-card.active{border-color:var(--color-primary);color:var(--color-primary);box-shadow:none;background:#6366f11f}.theme-toggle-btn{background:var(--bg-secondary);width:40px;height:40px;color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:var(--transition-smooth);justify-content:center;align-items:center;font-size:18px;display:flex;box-shadow:0 2px 8px #0000001a}.theme-toggle-btn:hover{background:var(--bg-tertiary);border-color:var(--text-secondary);transform:translateY(-1px)}.theme-toggle-btn:active{transform:translateY(0)}body.light-mode .feedback-alert.correct{color:#065f46;background:#10b9811f;border-color:#10b9814d}body.light-mode .feedback-alert.incorrect{color:#991b1b;background:#ef44441f;border-color:#ef44444d}body.light-mode .keypad-btn:hover:not(:disabled){background:#0000000a}body.light-mode .nav-tab:hover{background:#00000008}body.light-mode .toggle-btn:hover{color:var(--text-primary)}@media (width<=900px) and (orientation:landscape){header.practice-mode-header{justify-content:space-between;align-items:center;gap:8px;height:46px;padding:4px 12px;display:flex}header.practice-mode-header .logo-container,header.practice-mode-header .nav-tabs{display:none!important}header.practice-mode-header .theme-toggle-btn{width:32px;min-width:32px;height:32px;margin-left:auto;font-size:14px}header.practice-mode-header .header-practice-controls{flex:1;justify-content:center;align-items:center;display:flex;overflow:hidden}}.soroban-container{flex-direction:column;align-items:center;width:100%;max-width:680px;margin:0 auto;display:flex}.soroban-controls{justify-content:space-between;align-items:center;width:100%;margin-bottom:16px;display:flex}.soroban-display-value{color:var(--text-secondary);font-size:18px;font-weight:600}.highlight-text{color:var(--color-primary);text-shadow:0 0 10px var(--color-primary-glow);margin-left:8px;font-size:24px;font-weight:800}.soroban-frame-outer{aspect-ratio:440/260;background:var(--bg-secondary);border-radius:var(--radius-md);width:100%;padding:4px;position:relative;overflow:hidden;box-shadow:inset 0 2px 8px #000c,0 8px 30px #00000080}.soroban-svg{width:100%;height:100%;display:block}.soroban-bead{transform-origin:50%;filter:drop-shadow(0 2px 3px #00000080);transition:transform .25s cubic-bezier(.25,.46,.45,.94),fill .25s}.soroban-bead.dragging{transition:none!important}.soroban-bead:hover{filter:brightness(1.2)drop-shadow(0 2px 5px #6366f14d)}.soroban-bead.active{filter:drop-shadow(0 0 4px #6366f166)}.soroban-bead:active{opacity:.95}.soroban-labels{width:100%;margin-top:10px;padding:12px 25px;display:flex}.soroban-label-col{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.label-letter{color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-size:12px;font-weight:700}.digit-value{color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);width:28px;height:28px;transition:var(--transition-smooth);border-radius:50%;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.fingermath-container{flex-direction:column;align-items:center;width:100%;max-width:680px;margin:0 auto;display:flex}.fingermath-header{justify-content:space-between;align-items:center;width:100%;margin-bottom:20px;display:flex}.fingermath-total{color:var(--text-secondary);font-size:18px;font-weight:600}.highlight-text-emerald{color:var(--color-secondary);text-shadow:0 0 10px var(--color-secondary-glow);margin-left:8px;font-size:28px;font-weight:800}.hands-row{justify-content:space-between;align-items:stretch;gap:20px;width:100%;display:flex}.hands-separator{background:var(--border-color);align-self:stretch;width:2px}.fingermath-hand-card{border:1px solid var(--border-color);border-radius:var(--radius-md);background:#ffffff05;flex-direction:column;flex:1;align-items:center;min-width:200px;padding:16px;display:flex}.hand-title{color:var(--text-secondary);text-align:center;margin-bottom:12px;font-size:14px;font-weight:600}.hand-svg-container{aspect-ratio:220/280;width:100%;max-width:220px;position:relative}.hand-svg{width:100%;height:100%;display:block;overflow:visible}.hand-finger{transition:transform .3s cubic-bezier(.175,.885,.32,1.15)}.hand-finger rect{transition:fill .25s,stroke .25s}.hand-finger:hover rect{filter:brightness(1.2)}.hand-finger.active rect{filter:drop-shadow(0 0 5px #10b98166)}.finger-labels-container{box-sizing:border-box;pointer-events:none;justify-content:space-between;width:100%;padding:0 4px;display:flex;position:absolute;top:-8px;left:0}.finger-badge{background:var(--bg-tertiary);color:var(--text-muted);border:1.5px solid var(--border-color);width:20px;height:20px;transition:var(--transition-smooth);border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:flex;box-shadow:0 2px 4px #0000004d}.finger-badge.active{background:var(--color-secondary);color:#fff;box-shadow:0 0 8px var(--color-secondary-glow);border-color:#34d399}.thumb-badge{color:var(--color-accent);background:#f59e0b1a;border-color:#f59e0b4d}.thumb-badge.active{background:var(--color-accent);color:#fff;box-shadow:0 0 8px var(--color-accent-glow);border-color:#fbbf24}.hand-value-display{color:var(--text-secondary);text-align:center;margin-top:14px;font-size:13px}.hand-digit{color:var(--text-primary);font-size:16px;font-weight:800}.hand-contribution{color:var(--text-muted);font-size:11px}@media (width<=600px){.hands-row{flex-direction:column;align-items:center;gap:16px}.hands-separator{width:100%;height:1px}}.practice-view{flex-direction:column;align-items:center;gap:12px;width:100%;display:flex}.practice-config{flex-direction:column;align-items:center;gap:8px;width:100%;display:flex}.config-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;display:flex}.config-group{align-items:center;gap:12px;display:flex}.group-label{color:var(--text-secondary);font-size:14px;font-weight:600}.toggle-btn-group{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:3px;display:flex}.toggle-btn{border-radius:calc(var(--radius-md) - 4px);color:var(--text-secondary);transition:var(--transition-smooth);background:0 0;padding:6px 12px;font-size:14px}.toggle-btn:hover{color:var(--text-primary)}.toggle-btn.active{color:#fff;background:var(--color-primary);box-shadow:0 2px 8px var(--color-primary-glow)}.score-badge{color:var(--text-primary);border-radius:var(--radius-md);background:#f59e0b1a;border:1px solid #f59e0b33;padding:8px 16px;font-size:15px;font-weight:700;box-shadow:0 0 10px #f59e0b0d}.score-count{color:var(--color-accent)}.score-row{justify-content:center;width:100%;margin-top:2px;display:flex}.level-cards-container{flex-direction:column;gap:12px;width:100%;display:flex}.level-cards-grid{scrollbar-width:none;-ms-overflow-style:none;flex-wrap:nowrap;justify-content:safe center;gap:6px;width:100%;padding-bottom:4px;display:flex;overflow-x:auto}.level-cards-grid::-webkit-scrollbar{display:none}.level-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);flex-shrink:0;padding:8px 14px;font-size:14px;font-weight:600}.level-card:hover{border-color:var(--text-secondary);color:var(--text-primary)}.level-card.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 4px 12px var(--color-primary-glow)}.practice-workspace.unified-workspace{justify-content:center;width:100%;max-width:680px;margin:0 auto;display:flex}.question-panel{flex-direction:column;gap:24px;width:100%;display:flex}.panel-title{color:var(--text-secondary);border-bottom:1px solid var(--border-color);padding-bottom:8px;font-size:18px;font-weight:700}.question-prompt-box{border:1px dashed var(--border-color);border-radius:var(--radius-md);text-align:center;background:#ffffff03;justify-content:center;align-items:center;min-height:120px;padding:24px;display:flex}.prompt-text{color:var(--text-secondary);font-size:15px}.write-prompt{flex-direction:column;align-items:center;gap:6px;display:flex}.prompt-instruction{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:14px}.target-number-glow{color:var(--text-primary);text-shadow:0 0 20px var(--color-primary-glow), 0 0 40px #6366f133;font-size:48px;font-weight:800;line-height:1}.input-container{flex-direction:column;align-items:center;gap:16px;display:flex}.read-input{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);text-align:center;width:100%;max-width:200px;color:var(--text-primary);font-size:32px;font-weight:800;font-family:var(--font-sans);transition:var(--transition-smooth);outline:none;padding:12px}.read-input:focus{border-color:var(--color-primary);box-shadow:0 0 15px var(--color-primary-glow)}.custom-keypad{grid-template-columns:repeat(3,1fr);gap:8px;width:100%;max-width:280px;display:grid}.keypad-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-md);transition:var(--transition-smooth);padding:12px;font-size:16px;font-weight:700}.keypad-btn:hover:not(:disabled){border-color:var(--text-secondary);background:#ffffff0d}.keypad-btn:active:not(:disabled){transform:scale(.95)}.keypad-btn.danger{color:var(--color-danger);background:#ef444414}.keypad-btn.danger:hover:not(:disabled){background:var(--color-danger);color:#fff}.keypad-btn.warning{color:var(--color-accent);background:#f59e0b14}.keypad-btn.warning:hover:not(:disabled){background:var(--color-accent);color:#fff}.feedback-alert{border-radius:var(--radius-md);text-align:center;padding:16px;animation:.3s cubic-bezier(.175,.885,.32,1.275) slideIn}.feedback-alert.correct{color:#a7f3d0;background:#10b98114;border:1px solid #10b98133}.feedback-alert.incorrect{color:#fca5a5;background:#ef444414;border:1px solid #ef444433}.feedback-header{margin-bottom:4px;font-size:15px;font-weight:700}.feedback-message{font-size:13px;line-height:1.4}.w-full{width:100%}.action-buttons{width:100%;margin-top:auto}.instrument-viewport{justify-content:center;align-items:center;width:100%;min-height:auto;padding:10px 0;display:flex}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=900px) and (orientation:landscape){.practice-config.landscape-appbar{flex-flow:row!important;justify-content:flex-start!important;align-items:center!important;gap:8px!important;width:100%!important;padding:0!important}.practice-config.landscape-appbar .config-row{flex-flow:row!important;gap:6px!important;width:auto!important}.practice-config.landscape-appbar .level-cards-container{flex-grow:1!important;width:auto!important;max-width:420px!important}.practice-config.landscape-appbar .level-cards-grid{justify-content:flex-start!important;gap:4px!important;padding-bottom:0!important}.practice-config.landscape-appbar .score-row{width:auto!important;margin-top:0!important}.practice-config.landscape-appbar .score-badge{border-radius:var(--radius-sm)!important;white-space:nowrap!important;padding:6px 10px!important;font-size:13px!important}.practice-config.landscape-appbar .toggle-btn-group{border-radius:var(--radius-sm)!important;padding:2px!important}.practice-config.landscape-appbar .toggle-btn{border-radius:calc(var(--radius-sm) - 2px)!important;padding:5px 8px!important;font-size:13px!important}.practice-config.landscape-appbar .level-card{border-radius:var(--radius-sm)!important;padding:6px 10px!important;font-size:13px!important}.hide-landscape-label{display:none!important}}.exploration-view{flex-direction:column;gap:30px;width:100%;display:flex}.intro-card{text-align:left;flex-direction:column;gap:12px;display:flex}.intro-card h2{color:var(--text-primary);margin-bottom:4px;font-size:24px}.intro-text{color:var(--text-secondary);font-size:15px;line-height:1.6}.tip-box{background:var(--color-primary-glow);color:#c7d2fe;border-radius:var(--radius-md);border:1px solid #6366f133;padding:12px 16px;font-size:14px}.tip-box.success{background:var(--color-secondary-glow);color:#a7f3d0;border-color:#10b98133}.interactive-container{justify-content:center;width:100%;display:flex}.tutorial-instructions{text-align:left}.tutorial-instructions h3{color:var(--text-secondary);border-bottom:1px solid var(--border-color);margin-bottom:16px;padding-bottom:6px;font-size:18px}.instructions-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;display:grid}.instruction-step{border-radius:var(--radius-md);border:1px solid var(--border-color);background:#ffffff03;align-items:flex-start;gap:14px;padding:14px;display:flex}.step-num{background:var(--color-primary);color:#fff;width:28px;height:28px;box-shadow:0 0 8px var(--color-primary-glow);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.instruction-step p{color:var(--text-secondary);font-size:13.5px;line-height:1.4}@media (width<=768px){.instructions-grid{grid-template-columns:1fr}}
