@import "https://fonts.googleapis.com/css2?family=Jura:wght@300..700&display=swap";html,body,#root{width:100%;height:100%;margin:0;overflow:hidden}:root{--ui-font:"Jura", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, Roboto, Helvetica, Arial, sans-serif;--bg-colour:#f7f7f4;--grid-colour:#ef89021a;--text-colour:#1b2430;--topbar-bg:#ffffffa6;--topbar-border:#00000014;--button-bg:#0000000d;--button-border:#0000001f;--button-text:#1b2430;--pill-success-bg:#58d48724;--pill-success-border:#58d48752}[data-theme=dark]{--bg-colour:#071426;--grid-colour:#ef89022e;--text-colour:#f5f7fb;--topbar-bg:#05080fa6;--topbar-border:#ffffff14;--button-bg:#ffffff0f;--button-border:#ffffff24;--button-text:#f5f7fb}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--ui-font);background:var(--bg-colour);color:var(--text-colour);overflow:hidden}button,input{font:inherit}.app-shell{flex-direction:column;width:100vw;height:100vh;display:flex}.canvas-wrap{background-color:var(--bg-colour);background-image:linear-gradient(var(--grid-colour) 1px, transparent 1px), linear-gradient(90deg, var(--grid-colour) 1px, transparent 1px);cursor:grab;background-size:18px 18px;flex:1;position:relative;overflow:hidden}.canvas-wrap:active{cursor:grabbing}.hex-canvas{transform-origin:0 0;position:relative}.hex-node-wrap{width:220px;height:220px;position:absolute;transform:translate(-50%,-50%)}.hex-node{clip-path:polygon(25% 6.7%,75% 6.7%,100% 50%,75% 93.3%,25% 93.3%,0% 50%);letter-spacing:.03em;border:none;justify-content:center;align-items:center;width:220px;height:220px;font-weight:700;transition:transform .18s,box-shadow .18s,filter .18s;display:flex;position:absolute;inset:0;box-shadow:0 14px 28px #00000042,inset 0 0 0 1px #ffffff14}.hex-node:hover{filter:brightness(1.03);transform:scale(1.02)}.hex-label-stack{flex-direction:column;align-items:center;gap:8px;display:flex}.hex-code-wrapper{justify-content:center;align-items:center;display:flex;position:relative}.hex-code-display{text-transform:lowercase;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);letter-spacing:.05em;background:#0000002e;border-radius:999px;padding:.36rem .65rem;font-size:.92rem;transition:background .2s}.hex-code-wrapper:hover .hex-code-display{background:#0000004d}.hidden-colour-picker{opacity:0;cursor:pointer;border:none;width:100%;height:100%;padding:0;position:absolute;inset:0}.hex-actions{gap:10px;display:flex}.hex-icon{opacity:.85;cursor:pointer;width:16px;height:16px;transition:transform .15s,opacity .15s}.hex-icon:hover{opacity:1;transform:scale(1.18)}.add-node-group{z-index:15;background:#ebedf3f5;border-radius:999px;flex-direction:column;align-items:center;display:flex;position:absolute;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 4px 10px #0000002e}[data-theme=dark] .add-node-group{background:#141a26f5;box-shadow:0 4px 10px #0006}.add-node-btn{color:#596274;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:32px;height:26px;font-size:1.1rem;font-weight:700;transition:background .15s,color .15s;display:flex}[data-theme=dark] .add-node-btn{color:#a4b0c6}.add-node-btn:hover{color:#1b2430;background:#00000014}[data-theme=dark] .add-node-btn:hover{color:#f5f7fb;background:#ffffff1a}.add-node-btn.minus{font-size:1.2rem;line-height:1}.add-node-divider{background:#0000001a;width:16px;height:1px}[data-theme=dark] .add-node-divider{background:#ffffff1a}.remove-node-btn{cursor:pointer;opacity:.6;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:opacity .15s,transform .15s;display:flex;position:absolute;bottom:24px;left:50%;transform:translate(-50%)}.remove-node-btn:hover{opacity:1;transform:translate(-50%)scale(1.18)}.remove-node-btn svg{width:18px;height:18px}.app-body{flex:1;display:flex;position:relative;overflow:hidden}.floating-logo{z-index:20;pointer-events:none;opacity:.35;transition:opacity .2s;position:absolute;top:32px;right:36px}[data-theme=dark] .floating-logo{opacity:.2}.floating-logo h1{letter-spacing:-.02em;color:var(--text-colour);margin:0;font-size:2.2rem}.toast-container{z-index:30;pointer-events:none;position:absolute;bottom:32px;left:50%;transform:translate(-50%)}.copied-toast{background:var(--text-colour);color:var(--bg-colour);letter-spacing:.05em;border-radius:999px;padding:.75rem 1.5rem;font-weight:700;animation:.3s cubic-bezier(.25,1,.5,1) slideUp;display:inline-block;box-shadow:0 8px 24px #0000002e}@keyframes slideUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.canvas-controls{z-index:20;gap:14px;display:flex;position:absolute;bottom:32px;right:36px}.icon-button{background:var(--topbar-bg);border:1px solid var(--topbar-border);width:52px;height:52px;color:var(--text-colour);cursor:pointer;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:14px;justify-content:center;align-items:center;transition:transform .2s,background .2s,box-shadow .2s;display:flex;box-shadow:0 4px 14px #0000000f}[data-theme=dark] .icon-button{box-shadow:0 4px 14px #0000004d}.icon-button:hover{background:var(--button-bg);transform:translateY(-2px);box-shadow:0 6px 18px #0000001a}.icon-button svg{opacity:.85;width:24px;height:24px}.settings-drawer{background:var(--topbar-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-right:1px solid var(--topbar-border);z-index:25;width:320px;transition:transform .4s cubic-bezier(.25,1,.5,1);display:flex;position:absolute;top:0;bottom:0;left:0;transform:translate(-100%)}.settings-drawer.open{transform:translate(0)}.drawer-inner{flex-direction:column;flex:1;display:flex}.drawer-tabs{border-bottom:1px solid var(--topbar-border);display:flex}.tab-btn{color:var(--text-colour);opacity:.5;cursor:pointer;letter-spacing:.03em;background:0 0;border:none;flex:1;padding:1.4rem 1rem;font-weight:700;transition:opacity .2s,background .2s}.tab-btn:hover{background:var(--button-bg);opacity:.8}.tab-btn.active{opacity:1;border-bottom:2px solid var(--text-colour)}.drawer-content{padding:2rem 1.5rem;overflow-y:auto}.drawer-content h2{letter-spacing:.02em;margin:0 0 .5rem;font-size:1.3rem}.drawer-subtext{opacity:.7;margin:0 0 2rem;font-size:.9rem;line-height:1.5}.drawer-controls-placeholder{border:1px dashed var(--topbar-border);text-align:center;opacity:.6;background:#00000008;border-radius:8px;padding:1.5rem;font-size:.85rem}[data-theme=dark] .drawer-controls-placeholder{background:#ffffff08}.drawer-tab{background:var(--topbar-bg);border:1px solid var(--topbar-border);cursor:pointer;width:42px;height:52px;color:var(--text-colour);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-left:none;border-radius:0 12px 12px 0;justify-content:center;align-items:center;transition:background .2s,width .2s;display:flex;position:absolute;top:2rem;right:-42px;box-shadow:4px 4px 10px #0000000d}.drawer-tab:focus{outline:none}[data-theme=dark] .drawer-tab{box-shadow:4px 4px 10px #0000004d}.drawer-tab:hover{width:48px;right:-48px}.drawer-tab svg{opacity:.8;width:20px;height:20px;transition:transform .4s cubic-bezier(.25,1,.5,1)}.settings-drawer.open .drawer-tab svg{transform:rotate(180deg)}.control-hint{opacity:.6;margin:0;font-size:.8rem}.control-group{flex-direction:column;gap:.5rem;margin-bottom:1.5rem;display:flex}.control-label{font-size:.95rem;font-weight:700}.control-select{border:1px solid var(--topbar-border);background:var(--bg-colour);color:var(--text-colour);cursor:pointer;border-radius:8px;padding:.65rem;font-family:inherit;font-size:.95rem}.drawer-section-divider{background:var(--topbar-border);height:1px;margin:2rem 0}.colour-picker-wrap{border:1px solid var(--topbar-border);background:var(--bg-colour);letter-spacing:.05em;text-transform:uppercase;border-radius:8px;align-items:center;gap:1rem;padding:.5rem;font-size:.95rem;font-weight:700;display:flex}.colour-picker-wrap input[type=color]{cursor:pointer;border:none;border-radius:4px;width:32px;height:32px;padding:0}.primary-button{background:var(--text-colour);width:100%;color:var(--bg-colour);cursor:pointer;border:none;border-radius:8px;padding:.85rem;font-family:inherit;font-size:1rem;font-weight:700;transition:transform .2s,opacity .2s}.primary-button:hover{opacity:.9;transform:translateY(-2px)}
