.morse-tree-container{margin:2rem auto;max-width:600px;width:95vw;background:#181c24;border-radius:1rem;box-shadow:0 2px 16px #000a;padding:1.2rem .5rem;text-align:center;color:#e0e6f0;box-sizing:border-box}.morse-path{margin-bottom:1rem;font-size:1.05rem;color:#b3b9c9;word-break:break-word}.morse-tree-visual{width:100%;min-height:220px;display:flex;justify-content:center;align-items:flex-start;background:none;overflow-x:auto}.morse-tree-visual svg{width:100%;height:auto;max-width:600px;min-width:320px;display:block}.morse-svg-node circle{transition:fill .2s,stroke .2s,filter .2s;filter:drop-shadow(0 2px 8px #0008)}.morse-svg-node.active circle{filter:drop-shadow(0 0 8px #ffd600cc)}.morse-svg-node text{pointer-events:none;font-family:inherit;-webkit-user-select:none;user-select:none;font-size:1rem}.morse-tree-controls{margin-top:1rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.morse-tree-controls button{padding:.4rem 1.2rem;font-size:1rem;border-radius:.5rem;border:none;background:#23283a;color:#ffd600;cursor:pointer;transition:background .2s,color .2s;box-shadow:0 1px 4px #0002;margin-bottom:.5rem}.morse-tree-controls button:hover{background:#ffd600;color:#23283a}@media (max-width: 600px){.morse-tree-container{max-width:100vw;padding:.5rem .1rem}.morse-tree-visual svg{min-width:220px;max-width:100vw}.morse-svg-node text{font-size:.85rem}.morse-tree-controls button{font-size:.95rem;padding:.4rem .7rem}}@media (max-width: 420px){.tabs{gap:.1rem;padding-left:2px;padding-right:2px;box-shadow:0 2px 8px #0002 inset;min-width:0}.tab-button{font-size:.89rem;padding:.5rem .4rem;min-width:60px;max-width:120px;border-radius:.5rem .5rem 0 0;margin-right:1px}}body{font-family:Arial,Helvetica,sans-serif;margin:0;padding:2rem;background:#0f0f0f;color:#e0e0e0}.app{max-width:720px;min-width:300px;min-width:18.75rem;margin:0 auto}.tabs-nav{position:relative;display:flex;align-items:center;min-height:48px}.hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;background:none;border:none;cursor:pointer;margin-right:.5rem;z-index:20}.hamburger-bar{width:28px;height:4px;background:#aaa;margin:3px 0;border-radius:2px;transition:background .2s}.tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:1px solid #333;overflow-x:auto;flex-wrap:nowrap;scrollbar-width:thin;scrollbar-color:#333 #181c24}.tabs::-webkit-scrollbar{height:6px}.tabs::-webkit-scrollbar-thumb{background:#333;border-radius:3px}@media (max-width: 550px),(max-width: 34.375rem){.app{min-width:300px;min-width:18.75rem}.tabs-nav{flex-direction:row;min-height:44px}.hamburger{display:flex}.tabs{position:absolute;top:100%;left:0;right:0;background:#181c24;flex-direction:column;gap:0;border-bottom:none;border-radius:0 0 1rem 1rem;box-shadow:0 4px 16px #0006;z-index:10;margin-bottom:0;display:none}.tabs.open{display:flex}.tab-button{width:100%;text-align:left;padding:1rem 1.5rem;border-radius:0;border-bottom:1px solid #222;font-size:1.1rem}}.tab-button{padding:.75rem 1.2rem;font-size:1rem;border:none;background:transparent;color:#aaa;cursor:pointer;border-bottom:3px solid transparent;transition:color .2s,border-color .2s;white-space:nowrap;flex-shrink:0}.tab-button:hover{color:#e0e0e0}.tab-button.active{color:#fff;border-bottom-color:#0078d4}.container input[type=range]{width:100%}.container{max-width:720px;margin:0 auto;background:#1a1a1a;padding:1.5rem;border-radius:8px;box-shadow:0 6px 18px #00000080;border:1px solid #333}h1{margin:0 0 1rem}.form{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.form input{min-width:0;flex:1 1 120px}.form button{flex:0 0 auto;max-width:100%;word-break:break-word}@media (max-width: 600px){.tabs{gap:.2rem}.tab-button{font-size:.97rem;padding:.6rem .7rem}.form{flex-direction:column;gap:.4rem}.form button{width:100%;margin-top:.2rem}.morse-tree-container{max-width:100vw;padding:.5rem .1rem}.morse-tree-visual svg{min-width:220px;max-width:100vw}.morse-svg-node text{font-size:.85rem}.morse-tree-controls button{font-size:.95rem;padding:.4rem .7rem}}input{flex:1;padding:.5rem .75rem;font-size:1rem;border:1px solid #444;border-radius:6px;background:#2a2a2a;color:#e0e0e0}button{padding:.5rem .9rem;font-size:1rem;border:none;background:#0078d4;color:#fff;border-radius:6px;cursor:pointer}button:hover:not(:disabled){background:#1084e8}button:disabled{opacity:.4;cursor:default}.light{width:48px;height:48px;border-radius:50%;background:#333;box-shadow:0 2px 6px #0000004d;position:relative;overflow:hidden;transition:box-shadow .12s ease}.light:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ffd54d;opacity:0;border-radius:inherit;transform:scale(.94);transition:opacity .2s linear,transform .2s linear;will-change:opacity,transform;pointer-events:none}.light.on:after{opacity:1;transform:scale(1)}.light.on{box-shadow:0 6px 30px #ffc54f73}
