.force-canvas-container{flex:1;min-height:400px;border:1px solid var(--border-color);border-radius:8px;overflow:hidden;background:#fff}.force-canvas{width:100%;height:100%;display:block;touch-action:none;cursor:crosshair}.phase-indicator{display:flex;align-items:center;gap:0;padding:.75rem 0}.phase-step{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.phase-step-circle{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;border:2px solid var(--border-color);background:var(--card-bg);color:var(--text-secondary);transition:all .3s}.phase-step-label{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;transition:color .3s}.phase-step-connector{width:24px;height:2px;background:var(--border-color);margin:0 .3rem;flex-shrink:0}.phase-step--active .phase-step-circle{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.phase-step--active .phase-step-label{color:var(--primary-color);font-weight:600}.phase-step--done .phase-step-circle{border-color:var(--success-color);background:var(--success-color);color:#fff}.phase-step--done .phase-step-label{color:var(--success-color)}.phase-step--skipped .phase-step-circle{border-color:var(--border-color);background:var(--bg-color);color:var(--text-secondary);opacity:.6}.phase-step--skipped .phase-step-label{color:var(--text-secondary);opacity:.6;font-style:italic}@media (max-width: 600px){.phase-step-label{display:none}.phase-step-connector{width:16px}}.instruction-panel{background:var(--card-bg);border:1px solid var(--border-color);border-left:4px solid var(--primary-color);border-radius:6px;padding:.75rem 1rem;min-height:4.5rem}.instruction-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.instruction-text{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.instruction-panel--special{background:#fffaf0;border-color:var(--accent-color)}.info-panel{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.info-panel-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.info-table{width:100%;border-collapse:collapse;font-size:.85rem}.info-table th{text-align:left;padding:.3rem .5rem;border-bottom:1px solid var(--border-color);color:var(--text-secondary);font-weight:500;font-size:.8rem}.info-table td{padding:.4rem .5rem;border-bottom:1px solid #f0f0f0}.info-label{font-weight:600}.info-value{font-variant-numeric:tabular-nums}.info-row--empty .info-value{color:var(--text-secondary)}.feedback-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.feedback-box{background:#fff;border-radius:12px;padding:2rem;max-width:400px;width:90%;text-align:center;box-shadow:0 8px 32px #00000026}.feedback-box--success{border-top:4px solid var(--success-color)}.feedback-box--error{border-top:4px solid var(--error-color)}.feedback-icon{font-size:2.5rem;margin-bottom:.5rem}.feedback-box--success .feedback-icon{color:var(--success-color)}.feedback-box--error .feedback-icon{color:var(--error-color)}.feedback-message{font-size:1.1rem;color:var(--text-primary);margin-bottom:.75rem}.feedback-details{list-style:none;padding:0;margin-bottom:.75rem}.feedback-details li{font-size:.9rem;color:var(--text-secondary);padding:.25rem 0}.feedback-hint{font-size:.85rem;color:var(--text-secondary);margin-bottom:1rem;font-style:italic}.ka-app{min-height:100vh;background:var(--bg-color)}.ka-header{padding:1.25rem 1.5rem;background:var(--card-bg);border-bottom:1px solid var(--border-color)}.ka-title{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.ka-subtitle{font-size:.9rem;color:var(--text-secondary);margin-top:.15rem}.ka-layout{display:grid;grid-template-columns:1fr 280px;gap:1rem;padding:1rem 1.5rem;max-width:1400px;margin:0 auto;height:calc(100vh - 90px)}.ka-main{display:flex;flex-direction:column;gap:.75rem;min-height:0}.ka-sidebar{display:flex;flex-direction:column;gap:1rem}.ka-buttons{display:flex;flex-direction:column;gap:.5rem}.ka-buttons .btn{width:100%;text-align:center}.ka-scale-info{font-size:.8rem;color:var(--text-secondary);text-align:center;padding:.5rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px}.ka-scale-label{margin-right:.3rem}@media (max-width: 900px){.ka-layout{grid-template-columns:1fr;height:auto;padding:.75rem}.ka-main{min-height:60vh}.ka-sidebar{flex-direction:row;flex-wrap:wrap;gap:.75rem}.ka-sidebar>*{flex:1;min-width:200px}.ka-buttons{flex-direction:row;flex-wrap:wrap}.ka-buttons .btn{flex:1;min-width:120px}}@media (pointer: coarse){.ka-buttons .btn{min-height:48px;font-size:1rem}}.app{min-height:100vh}:root{--primary-color: #2c5282;--primary-light: #4299e1;--accent-color: #ed8936;--success-color: #48bb78;--error-color: #f56565;--bg-color: #f7fafc;--card-bg: #ffffff;--text-primary: #2d3748;--text-secondary: #718096;--border-color: #e2e8f0;--font-family: "Segoe UI", system-ui, -apple-system, sans-serif;--force1-color: #3182ce;--force2-color: #e53e3e;--resultant-color: #38a169;--copy-opacity: .5}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-primary);line-height:1.6}.formula{font-family:Times New Roman,serif;font-style:italic;background:#f0f4f8;padding:.5rem 1rem;border-radius:4px;display:inline-block}.formula sub{font-size:.75em}.btn{padding:.6rem 1.2rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-light)}.btn-secondary{background:var(--card-bg);color:var(--primary-color);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-color)}.btn-success{background:var(--success-color);color:#fff}.btn-success:hover:not(:disabled){background:#38a169}@media (pointer: coarse){.btn,button{min-height:44px;min-width:44px;padding:.8rem 1.5rem}input[type=text],input[type=number]{min-height:44px;font-size:1.1rem}}
