*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{color:#222;background:#fff;width:100%;height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}body{display:flex}#sidebar{z-index:10;background:#fafafa;border-right:1px solid #ddd;flex-direction:column;width:220px;min-width:220px;height:100vh;transition:all .3s;display:flex;overflow-y:auto}#legend{border-bottom:1px solid #ddd;flex-direction:column;flex-shrink:0;justify-content:center;height:260px;min-height:260px;padding:14px 12px 12px;display:flex;overflow-y:auto}#legend h3{text-transform:uppercase;letter-spacing:1px;color:#888;margin-bottom:10px;font-size:11px}.legend-item{color:#444;align-items:center;gap:8px;margin-bottom:10px;font-size:12px;font-weight:500;display:flex}.legend-line{border:none;flex-shrink:0;width:36px;height:0}.legend-line.neutralization{border-top:2.5px solid #9d4edd}.legend-line.alchemy{border-top:1.5px dotted #aaa}.legend-line.generation{border-top:2px dashed #c22}.legend-arrow{color:inherit;font-size:12px}.panel-header{border-bottom:1px solid #eee;align-items:baseline;gap:6px;margin-bottom:12px;padding-bottom:8px;display:flex}.panel-stem{color:#333;font-family:serif;font-size:22px}.panel-abbr{color:#555;letter-spacing:1px;font-size:13px;font-weight:700}.conn-type-label{text-transform:uppercase;letter-spacing:1px;color:#999;align-items:center;gap:7px;margin:10px 0 5px;font-size:10px;display:flex}.conn-type-line{flex-shrink:0;width:28px;height:0;display:inline-block}.neut-line{border-top:2.5px solid #9d4edd}.alch-line{border-top:1.5px dotted #aaa}.conn-btn{cursor:pointer;background:#fff;border:1.5px solid #ddd;border-radius:6px;align-items:center;gap:10px;width:100%;margin-bottom:5px;padding:8px 10px;font-family:sans-serif;font-size:13px;transition:background .15s,border-color .15s;display:flex}.conn-btn:hover{background:#f5f5f5}.neut-btn{border-color:#d8b4fe}.neut-btn:hover{background:#faf5ff}.neut-btn.selected{cursor:default;opacity:.85;background:#ede9fe;border-color:#9d4edd}.alch-btn{border-color:#ddd}.alch-btn:hover{background:#f9f9f9}.alch-btn.selected{cursor:default;opacity:.85;background:#f3f3f3;border-color:#aaa}.conn-preview{flex-shrink:0;width:36px;height:0;display:inline-block}.neut-preview{border-top:2.5px solid #9d4edd}.alch-preview{border-top:1.5px dashed #aaa}.conn-label{color:#444;font-size:12px}#icon-list{flex-direction:column;flex:1;gap:4px;padding:10px 12px;display:flex;overflow-y:auto}.icon-row{gap:6px;display:flex}.elem-group{align-items:center;gap:6px;display:flex}.stem-col{flex-direction:column;gap:4px;display:flex}.icon-btn{cursor:pointer;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:22px;transition:all .15s;display:flex}.icon-stem{color:#222;background:#fff;border:2px solid #333;font-family:serif}.icon-stem:hover{background:#f0f0f0}.icon-stem.active{background:#ede9fe;border-color:#9d4edd}.icon-element{color:#fff;border:2px solid #0000;font-family:serif;font-weight:700}.icon-element:hover{opacity:.8}.icon-element.active{border-color:#333;box-shadow:0 0 0 2px #00000026}#diagram-container{flex:1;justify-content:center;align-items:center;min-width:0;padding:16px;display:flex}#diagram-container svg{width:100%;height:100%}#diagram-container text{-webkit-user-select:none;user-select:none;pointer-events:none}#reset-btn{color:#333;cursor:pointer;z-index:20;background:#fff;border:2px solid #333;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:background .2s,transform .2s;display:flex;position:fixed;top:24px;right:24px;box-shadow:0 2px 8px #0000001f}#reset-btn:hover{background:#f0f0f0;transform:scale(1.08)}#legend-toggle{display:none}@media (width<=1200px){body{flex-direction:column;overflow:hidden}#sidebar{background:#fafafa;border-top:1px solid #ccc;border-right:none;flex-direction:column;order:2;width:100%;min-width:100%;height:auto;max-height:50vh;overflow:visible}#legend{opacity:0;border-bottom:1px solid #ddd;height:auto;min-height:0;max-height:0;padding:0 16px;transition:max-height .35s,opacity .25s,padding .35s;overflow:hidden}#legend.legend-open{opacity:1;max-height:300px;padding:10px 16px}#legend h3{margin-bottom:8px;font-size:12px}.legend-item{margin-bottom:8px;font-size:13px}#legend-toggle{color:#555;text-transform:uppercase;letter-spacing:1px;cursor:pointer;background:#f0f0f0;border:none;border-bottom:1px solid #e0e0e0;order:-1;justify-content:center;align-items:center;gap:6px;width:100%;padding:6px 12px;font-family:Inter,sans-serif;font-size:12px;transition:background .2s;display:flex}#legend-toggle:hover{background:#e8e8e8}#legend-toggle .toggle-arrow{font-size:10px;transition:transform .3s;display:inline-block}#legend-toggle.open .toggle-arrow{transform:rotate(180deg)}.panel-header{margin-bottom:8px;padding-bottom:6px}.panel-stem{font-size:24px}.panel-abbr{font-size:14px}.conn-btn{border-radius:8px;padding:10px 12px;font-size:14px}.conn-label{font-size:13px}#icon-list{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#ccc transparent;flex-flow:wrap;flex:none;justify-content:center;align-items:center;gap:8px;padding:10px 12px;overflow:auto hidden}#icon-list::-webkit-scrollbar{height:4px}#icon-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.elem-group{flex-direction:column;flex-shrink:0;align-items:center;gap:4px}.stem-col{flex-direction:row;gap:3px}.icon-btn{border-radius:8px;width:44px;height:44px;font-size:22px}#diagram-container{flex:1 1 0;order:1;min-height:0;padding:8px}#reset-btn{width:46px;height:46px;top:12px;right:12px}#reset-btn svg{width:24px;height:24px}}@media (width<=768px){#icon-list{justify-content:center;gap:6px;padding:8px}.icon-btn{border-radius:6px;width:40px;height:40px;font-size:20px}.elem-group{gap:3px}.stem-col{gap:2px}#diagram-container{padding:4px}#reset-btn{width:42px;height:42px;top:8px;right:8px}#reset-btn svg{width:22px;height:22px}.panel-stem{font-size:22px}.panel-abbr{font-size:13px}.conn-btn{padding:8px 10px;font-size:13px}}@media (width<=480px){#icon-list{gap:5px;padding:6px}.icon-btn{border-radius:5px;width:36px;height:36px;font-size:18px}.elem-group,.stem-col{gap:2px}#reset-btn{width:38px;height:38px;top:6px;right:6px}#reset-btn svg{width:20px;height:20px}.panel-stem{font-size:20px}.conn-btn{padding:6px 8px;font-size:12px}#legend h3{font-size:11px}.legend-item{font-size:12px}}
