.calculator-container{display:flex;flex-direction:column;gap:1.5rem}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:1.5rem}.card h2,.card h3{margin-top:0;margin-bottom:1rem;color:var(--text-primary)}.card h4{margin-top:1.5rem;margin-bottom:1rem;color:var(--text-secondary)}.description{color:var(--text-secondary);margin-bottom:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-weight:500}.form-group input[type=number]{width:100%;padding:.75rem;font-size:1rem;border-radius:4px}.form-group small{display:block;margin-top:.5rem;color:var(--text-tertiary);font-size:.875rem}.radio-group{display:flex;flex-direction:column;gap:.75rem}.radio-label{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:all .2s ease}.radio-label:hover{border-color:var(--accent-primary);background:var(--bg-secondary)}.radio-label input[type=radio]{width:1.25rem;height:1.25rem;cursor:pointer}.radio-label span{color:var(--text-primary);font-size:1rem}.checkbox-group{display:flex;flex-direction:column;gap:.75rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:all .2s ease}.checkbox-label:hover{border-color:var(--accent-primary);background:var(--bg-secondary)}.checkbox-label input[type=checkbox]{width:1.25rem;cursor:pointer;margin:0 .5rem 0 0;flex-shrink:0}.checkbox-label span{color:var(--text-primary);font-size:1rem}.button-group{display:flex;gap:1rem;margin-top:1.5rem}.btn{padding:.75rem 1.5rem;font-size:1rem;font-weight:500;border-radius:4px;transition:all .2s ease}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-secondary)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--accent-primary)}.results-card{animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.notification{padding:1rem;border-radius:4px;margin-bottom:1.5rem}.notification.success{background:#42be651a;border:1px solid var(--success)}.notification strong{display:block;margin-bottom:.5rem;color:var(--success)}.notification p{margin:0;color:var(--text-primary)}.casting-steps{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.casting-step{padding:.75rem;background:var(--bg-tertiary);border-radius:4px;border-left:3px solid var(--border);transition:all .2s ease}.casting-step:hover{background:var(--bg-secondary);border-left-color:var(--accent-primary)}.casting-step.setup{border-left-color:var(--accent-primary);background:#0f62fe1a}.casting-step.loop{border-left-color:var(--success)}.loop-header{font-weight:600;color:var(--accent-secondary);margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.step-content{display:flex;gap:.75rem;margin-bottom:.5rem}.step-number{color:var(--text-tertiary);font-weight:600;min-width:2rem}.step-description{color:var(--text-primary);flex:1}.step-stats{display:flex;flex-wrap:wrap;gap:1rem;font-size:.875rem;padding-left:2.75rem}.stat{color:var(--text-secondary);font-weight:500}.stat.mill{color:var(--accent-secondary);font-weight:600}.stat.total-mill{color:var(--success);font-weight:700;font-size:.875rem}.final-summary{padding:1rem;background:var(--bg-tertiary);border-radius:4px;border:2px solid var(--accent-primary)}.final-summary p{margin:.5rem 0;font-size:1.125rem;color:var(--text-primary)}.final-summary strong{color:var(--accent-secondary)}@media(max-width:768px){.card{padding:1rem}.button-group{flex-direction:column}.btn{width:100%}}.step-insertion-zone{position:relative;height:8px;display:flex;align-items:center;justify-content:center;transition:height .2s ease}.step-insertion-zone:hover{height:40px}.btn-insert-storm{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--accent-primary);color:#fff;border:none;border-radius:20px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0f62fe4d;animation:fadeIn .2s ease}.btn-insert-storm:hover{background:var(--accent-secondary);transform:scale(1.05);box-shadow:0 4px 12px #0f62fe66}.btn-insert-storm:active{transform:scale(.98)}.insert-icon{font-size:1.25rem;font-weight:700;line-height:1}.insert-text{font-size:.875rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.casting-step.custom-step{border-left-color:#ff9800;background:#ff98001a;position:relative}.casting-step.custom-step .step-description{font-style:italic;color:#ff9800}.btn-remove-custom{background:#ff3b301a;color:#ff3b30;border:1px solid rgba(255,59,48,.3);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;font-weight:700;line-height:1;transition:all .2s ease;margin-left:auto;flex-shrink:0}.btn-remove-custom:hover{background:#ff3b3033;border-color:#ff3b30;transform:scale(1.1)}.btn-remove-custom:active{transform:scale(.95)}.casting-step.custom-step .step-content{align-items:center}@media(max-width:768px){.step-insertion-zone:hover{height:36px}.btn-insert-storm{padding:.4rem .8rem;font-size:.8rem}.insert-icon{font-size:1rem}.insert-text{font-size:.75rem}}.sandbox-container{display:flex;flex-direction:column;gap:1.5rem}.sandbox-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.mana-source-toggle{display:flex;gap:.5rem;flex-shrink:0}.toggle-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.toggle-btn:hover{background:var(--bg-secondary);border-color:var(--accent-primary)}.toggle-btn.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.toggle-btn.active:hover{background:var(--accent-secondary)}.sandbox-status{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:4px;margin-bottom:1.5rem;border:1px solid var(--border)}.status-item{display:flex;align-items:center;gap:.5rem}.status-item strong{color:var(--text-secondary)}.size-value{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.status-item.input-item{display:flex;align-items:center;gap:.5rem}.size-input{width:80px;padding:.75rem;border:1px solid var(--border);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;text-align:center;transition:all .2s ease}.size-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #0f62fe1a}.size-input:hover{border-color:var(--accent-secondary)}.storm-value{font-size:1.5rem;font-weight:600;color:var(--accent-secondary)}.mana-value{font-size:1.25rem;font-weight:600;color:#4a9eff}.mill-value{font-size:1.25rem;font-weight:600}.mill-value.self-mill{color:var(--warning)}.mill-value.opponent-mill{color:var(--success)}.status-active{color:var(--success);font-weight:600}.status-inactive{color:var(--danger)}.controls{display:flex;flex-direction:column;gap:1rem}.main-buttons-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1rem}.utility-buttons-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.modifiers-section{margin-top:1rem}.modifiers-label{display:block;margin-bottom:.5rem;color:var(--text-secondary)}.modifiers-row{display:flex;gap:.5rem}.btn-with-toggle{position:relative;display:flex;align-items:stretch;width:100%}.btn-with-toggle .btn{flex:1;border-top-right-radius:0;border-bottom-right-radius:0;border-right:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-toggle{padding:.75rem .5rem;font-size:1.25rem;background:var(--bg-tertiary);color:var(--text-tertiary);border:1px solid var(--border);border-top-right-radius:4px;border-bottom-right-radius:4px;cursor:pointer;transition:all .2s ease;width:45px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-toggle:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--accent-primary)}.btn-toggle.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.btn-toggle.active:hover{background:var(--accent-secondary);border-color:var(--accent-secondary)}.btn-tertiary{background:var(--bg-tertiary);color:var(--accent-secondary);border:1px solid var(--accent-primary)}.btn-tertiary:hover:not(:disabled){background:var(--accent-primary);color:#fff}.btn-ghost{background:transparent;color:var(--text-primary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg-tertiary);border-color:var(--accent-primary);color:var(--accent-secondary)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#ba1b23}.reset-button{display:flex;justify-content:flex-end}.event-log-card{animation:slideIn .3s ease}.event-log{max-height:500px;overflow-y:auto;padding:1rem;background:var(--bg-tertiary);border-radius:4px;border:1px solid var(--border)}.empty-log{color:var(--text-tertiary);text-align:center;padding:2rem;margin:0}.event-item{padding:.75rem;margin-bottom:.5rem;border-radius:4px;border-left:3px solid var(--border);background:var(--bg-primary);display:flex;gap:.75rem;align-items:flex-start;animation:fadeIn .2s ease}.event-timestamp{color:var(--text-tertiary);font-size:.875rem;white-space:nowrap}.event-message{color:var(--text-primary);flex:1}.event-breach{border-left-color:var(--accent-primary);background:#0f62fe1a}.event-mana{border-left-color:var(--success);background:#42be651a}.event-freeze{border-left-color:var(--accent-secondary);background:#78a9ff1a}.event-storm{border-left-color:#ee5396;background:#ee53961a}.event-warning{border-left-color:var(--warning);background:#f1c21b1a}.event-reset{border-left-color:var(--text-tertiary);background:var(--bg-secondary)}.event-item:last-child{margin-bottom:0}.event-log::-webkit-scrollbar{width:8px}.event-log::-webkit-scrollbar-track{background:var(--bg-primary);border-radius:4px}.event-log::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.event-log::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}@media(max-width:768px){.sandbox-status{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.button-grid{grid-template-columns:1fr}.reset-button{justify-content:stretch}.reset-button button{width:100%}.event-log{max-height:400px}}@media(max-width:480px){.sandbox-status{grid-template-columns:1fr}}.app{max-width:1200px;margin:0 auto;padding:2rem 1rem}.app-header{text-align:center;margin-bottom:2rem}.app-title{font-size:2.5rem;font-weight:600;margin:0 0 .5rem;color:var(--text-primary)}.app-subtitle{font-size:1.125rem;color:var(--text-secondary);margin:0;display:flex;align-items:center;justify-content:center;gap:.5rem}.bob-link{display:inline-flex;align-items:center;gap:.25rem;color:var(--text-secondary);text-decoration:none;transition:all .2s ease}.bob-link:hover{color:var(--accent-primary);transform:translateY(-1px)}.bob-logo{height:1.5rem;width:auto;vertical-align:middle;display:inline-block;transition:transform .2s ease;border-radius:4px}.bob-link:hover .bob-logo{transform:scale(1.1)}.tab-navigation{display:flex;gap:.5rem;margin-top:1rem;justify-content:center}.tab-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:500;background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-block}.tab-button:hover{background:var(--bg-tertiary);border-color:var(--accent-primary);transform:translateY(-2px)}.tab-button.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.tab-button.active:hover{background:var(--accent-secondary);transform:translateY(-2px)}.tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid var(--border)}.tab{padding:1rem 2rem;background:transparent;color:var(--text-secondary);font-size:1rem;font-weight:500;border-bottom:3px solid transparent;margin-bottom:-2px;text-decoration:none;cursor:pointer;transition:all .2s ease}.tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.tab.active{color:var(--accent-secondary);border-bottom-color:var(--accent-primary)}.app-content{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.app{padding:1rem .5rem}.app-title{font-size:2rem}.app-subtitle{font-size:1rem}.tab{padding:.75rem 1rem;font-size:.875rem}}:root{--bg-primary: #0a0a0a;--bg-secondary: #1a1a1a;--bg-tertiary: #2a2a2a;--text-primary: #f4f4f4;--text-secondary: #c6c6c6;--text-tertiary: #8d8d8d;--accent-primary: #0f62fe;--accent-secondary: #78a9ff;--success: #42be65;--warning: #f1c21b;--danger: #da1e28;--border: #393939;--border-subtle: #262626}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6}#root{min-height:100vh}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all .2s ease}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{font-family:inherit;color:var(--text-primary);background-color:var(--bg-secondary);border:1px solid var(--border);outline:none;transition:all .2s ease}input:focus,select:focus,textarea:focus{border-color:var(--accent-primary)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}
