.App{position:relative;width:100%;height:100dvh;display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden;padding:max(12px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) max(12px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left));background:radial-gradient(circle at center,#161616,#101010 55%,#070707 80%,#040404)}.App.App--top{overflow-y:auto}.controls{position:fixed;top:max(env(safe-area-inset-top),12px);left:50%;right:auto;transform:translate(-50%);transition:all .28s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;gap:.7rem;padding:.75rem 1.25rem;border-radius:1rem;background:#111111f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;box-shadow:0 8px 24px #0009,0 0 0 1px #ffffff14,0 4px 12px #0000004d;z-index:10;will-change:transform;-moz-user-select:none;user-select:none;-webkit-user-select:none}.controls *{box-sizing:border-box}.controls--docked-right,.controls--docked-left{top:50%;left:auto;transform:translateY(-50%);flex-direction:column;align-items:center}.controls--docked-right{right:max(env(safe-area-inset-right),12px)}.controls--docked-left{left:max(env(safe-area-inset-left),12px)}#controls-content{display:flex;flex-direction:column;gap:.6rem;transition:opacity .25s ease,transform .25s ease}.controls--docked-right #controls-content,.controls--docked-left #controls-content{display:grid;grid-template-columns:auto auto;-moz-column-gap:.9rem;column-gap:.9rem;align-items:center}.controls-content--hidden{display:none!important}#controls-content:not(.controls-content--hidden){animation:fadeIn .25s ease}.column--settings{display:flex;flex-direction:column;gap:.5rem}.column--settings .row{display:flex;gap:.5rem;align-items:center}.controls--docked-right .column--settings .row,.controls--docked-left .column--settings .row{flex-direction:column}.controls--docked-right .column--settings select,.controls--docked-left .column--settings select{width:100%}.controls-row-subgroup{display:flex;gap:.5rem;align-items:center}.controls--docked-right .controls-row-subgroup,.controls--docked-left .controls-row-subgroup{width:100%}.controls-button{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#fff;padding:0;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0003;width:35px;height:35px;flex-shrink:0}.controls-button:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.controls-button:active{transform:translateY(0);background:#ffffff1a}.column--scale{display:flex;flex-direction:column;align-items:center;gap:.4rem}.controls--docked-right .column--scale{padding-left:.75rem;border-left:1px solid rgba(255,255,255,.08)}.controls--docked-left .column--scale{order:1;padding-right:.75rem;border-right:1px solid rgba(255,255,255,.08)}.controls--docked-left .column--settings{order:2}.scale-display{display:flex;align-items:center;gap:.3rem;-moz-user-select:text;user-select:text;-webkit-user-select:text}.controls--top .scale-display{flex-direction:row;gap:.8rem}.controls--docked-right .scale-display,.controls--docked-left .scale-display{flex-direction:column}.scale-title{font-size:.9rem;font-weight:600;letter-spacing:.01em;color:#fff}.scale-notes{display:flex;align-items:center;-moz-user-select:text;user-select:text;-webkit-user-select:text}.scale-notes--top{flex-direction:row;gap:.5rem;flex-wrap:wrap}.scale-notes--docked-right,.scale-notes--docked-left{flex-direction:column;gap:.25rem}.scale-note{font-size:.88rem;color:#ffffffd9;letter-spacing:.02em}.controls-actions{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%}.controls-toggle{background:transparent;border:none;color:#888;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.35rem .5rem;border-radius:.375rem;transition:all .2s ease;font-size:.9rem;-webkit-user-select:none;-moz-user-select:none;user-select:none}.controls-toggle:hover{color:#fff;background:#ffffff1f}.controls-toggle:active{transform:scale(.97);background:#ffffff14}.controls-toggle:focus-visible{outline:2px solid rgba(255,255,255,.4);outline-offset:2px}.controls-toggle svg{transition:transform .2s ease}.controls-toggle:hover svg{transform:translateY(1px)}.side-toggle:hover svg{transform:translate(2px)!important}.controls--docked-right .side-toggle:hover svg{transform:translate(-2px)!important}.controls--collapsed .controls-toggle:hover svg{transform:translateY(-1px)}.controls--collapsed{padding:.5rem .9rem}.controls--docked-right.controls--collapsed,.controls--docked-left.controls--collapsed{top:50%;transform:translateY(-50%)}.controls--docked-right.controls--collapsed{right:max(env(safe-area-inset-right),12px);left:auto}.controls--docked-left.controls--collapsed{left:max(env(safe-area-inset-left),12px);right:auto}.collapsed-summary{display:flex;align-items:center;gap:.5rem}.summary-key{font-size:.9rem;font-weight:500;color:#fff;white-space:nowrap}select{background:#1e1e1ecc;color:#fff;border:1px solid rgba(255,255,255,.12);border-radius:.5rem;padding:.5rem .7rem;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;outline:none}select:hover{background:#282828e6;border-color:#fff3}select:focus{background:#2d2d2df2;border-color:#ffffff4d;box-shadow:0 0 0 3px #ffffff14}select:active{transform:scale(.99)}.controls *:focus-visible{outline:2px solid rgba(255,255,255,.4);outline-offset:2px;border-radius:.25rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 640px){.controls{padding:.65rem 1rem;border-radius:.875rem}.controls--collapsed{padding:.45rem .75rem}select{font-size:.9rem;padding:.45rem .6rem}.scale-title{font-size:.85rem}.scale-note{font-size:.82rem}}.compass-container{flex:1;position:relative;display:grid;place-items:center;transition:transform .18s ease}.compass-wrapper{position:relative;width:min(55vmin,92vw,92dvh);height:min(55vmin,92vw,92dvh);padding-inline:clamp(14px,2.5vmin,26px);padding-block:clamp(16px,3.25vmin,28px);display:grid;place-items:center;box-sizing:border-box;margin-inline:auto;border-radius:50%}.compass{width:100%;max-width:600px;height:auto;display:block;pointer-events:none;z-index:1}.note{position:absolute;top:50%;right:50%;bottom:50%;left:50%;transform-origin:center;width:clamp(40px,6vmin,64px);height:clamp(40px,6vmin,64px);display:grid;place-items:center;border-radius:50%;background:#ffffff1f;border:1px solid rgba(255,255,255,.28);color:#fffffff5;-webkit-backdrop-filter:blur(6px) saturate(120%);backdrop-filter:blur(6px) saturate(120%);font-weight:600;font-size:clamp(.85rem,1.8vmin,1.1rem);line-height:1;text-shadow:0 1px 2px rgba(0,0,0,.6);box-shadow:inset 0 1px #ffffff2e,0 4px 14px #00000073;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:2;transition:background .12s ease,box-shadow .12s ease}.color-popup__overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000}.color-popup{background:#1e1e1e;border:1px solid #333;border-radius:12px;padding:0;width:95%;max-width:540px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 40px #0006;color:#fff;animation:popupFadeIn .3s ease-out}@keyframes popupFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.color-popup__title{margin:0;padding:24px 24px 20px;font-size:1.25rem;font-weight:600;background:#1e1e1e;border-bottom:1px solid #333}.color-popup__body{flex:1;overflow-y:auto;padding:24px}.color-popup__body>*:last-child{margin-bottom:0}.color-popup__main{display:flex;gap:20px;margin-bottom:24px;align-items:stretch}.color-popup__preview{flex:0 0 180px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#0003;padding:16px;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.color-popup__hint{margin:0;font-size:.7rem;color:#888;text-align:center;font-style:italic}.color-popup__grid{flex:1;display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.color-popup__row{display:flex;align-items:center;justify-content:space-between;background:#2a2a2a;padding:8px 10px;border-radius:8px;border:1px solid transparent;transition:border-color .2s}.color-popup__row:focus-within{border-color:#007aff}.color-popup__row label{font-size:.8rem;color:#ccc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:4px}.color-popup__row input[type=color]{-moz-appearance:none;appearance:none;-webkit-appearance:none;border:none;width:28px;height:28px;cursor:pointer;background:none;padding:0}.color-popup__row input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-popup__row input[type=color]::-webkit-color-swatch{border:1px solid #444;border-radius:4px}.color-popup__utilities{margin-bottom:24px}.color-popup__toggle-row{display:flex;align-items:center;justify-content:space-between;background:#ffffff0d;padding:12px 16px;border-radius:10px;cursor:pointer;transition:background .2s;border:1px solid rgba(255,255,255,.1)}.color-popup__toggle-row:hover{background:#ffffff14;border-color:#fff3}.color-popup__toggle-label{font-size:.9rem;font-weight:500;color:#eee}.color-popup__toggle{width:44px;height:24px;background:#444;border-radius:12px;position:relative;transition:background .3s cubic-bezier(.4,0,.2,1)}.color-popup__toggle.active{background:#007aff}.color-popup__toggle-handle{width:18px;height:18px;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.color-popup__toggle.active .color-popup__toggle-handle{transform:translate(20px)}.color-popup__subtitle{font-size:.9rem;font-weight:500;margin:0 0 12px;color:#aaa;text-transform:uppercase;letter-spacing:.05em}.color-popup__themes{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.color-popup__theme-button{background:#2a2a2a;border:1px solid #444;color:#fff;padding:12px 8px;border-radius:8px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;min-width:90px}.color-popup__theme-button:hover{background:#3a3a3a;border-color:#666;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.color-popup__theme-button:active{transform:translateY(0)}.color-popup__theme-button svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transition:transform .2s ease}.color-popup__theme-button:hover svg{transform:scale(1.1)}.color-popup__actions{display:flex;justify-content:flex-end;gap:12px;border-top:1px solid #333;padding:20px 24px 24px;background:#1e1e1e}.color-popup__button{background:#2a2a2a;border:1px solid #444;color:#fff;padding:8px 20px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.color-popup__button:hover{background:#3a3a3a}.color-popup__button--primary{background:#007aff;border-color:#007aff}.color-popup__button--primary:hover{background:#0063cc}@media (max-width: 540px){.color-popup{padding:0;width:100%;height:100%;max-height:100dvh;border-radius:0;border:none;display:flex;flex-direction:column}.color-popup__title{text-align:center;font-size:1.1rem;padding:16px;margin:0}.color-popup__body{padding:16px}.color-popup__main{flex-direction:column;gap:16px;margin-bottom:16px}.color-popup__preview{flex:0 0 auto;width:100%;box-sizing:border-box;padding:12px}.color-popup__grid{grid-template-columns:1fr;gap:8px}.color-popup__theme-button{min-width:calc(33.33% - 6px);padding:8px 4px}.color-popup__actions{margin-top:auto;padding:16px 16px calc(16px + env(safe-area-inset-bottom,0px))}.color-popup__button{flex:1;padding:12px}}html,body{margin:0;padding:0;width:100%;height:100dvh;overflow:hidden;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#fff;background-color:#101010;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;height:100%}a{color:inherit;text-decoration:none}button,select,input{font:inherit}*{box-sizing:border-box}
