@font-face{font-family:trashcons;font-style:normal;font-weight:400;src:url(/fonts/trashcons.woff) format("woff")}@font-face{font-family:GortonPerfected;font-style:normal;font-weight:400;src:url(/fonts/GortonPerfectedVF.woff) format("woff");font-display:swap}.gorton-perfected{font-family:GortonPerfected,sans-serif;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@font-face{font-family:trashcons;font-style:normal;font-weight:400;src:url(/fonts/trashcons.woff) format("woff")}.trashcons{font-family:trashcons;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.icon-left:before{content:""}.icon-right:before{content:""}.icon-down:before{content:""}.icon-up:before{content:""}.icon-mult:before{content:""}.icon-minus:before{content:""}.icon-plus:before{content:""}.icon-div:before{content:""}.icon-lower:before{content:""}.icon-raise:before{content:""}.icon-fn:before{content:""}.icon-shift:before{content:""}.icon-delete:before{content:""}.icon-backspace:before{content:""}.icon-enter:before{content:""}.icon-esc:before{content:""}.icon-tab:before{content:""}.icon-menu:before{content:""}.icon-sys:before{content:""}.icon-alt:before{content:""}.icon-ctrl:before{content:""}.icon-home:before{content:""}.icon-end:before{content:""}.icon-pgup:before{content:""}.icon-pgdn:before{content:""}.icon-capslock:before{content:""}.icon-numlock:before{content:""}.icon-scrllock:before{content:""}.icon-prntscrn:before{content:""}.icon-pause:before{content:""}.icon-insert:before{content:""}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{background-color:#2c3e50;color:#fff;padding:1rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 4px #0000001a}.app-header h1{font-size:1.5rem;font-weight:600}.header-left{display:flex;align-items:center;gap:2rem}.header-right{display:flex;align-items:center;gap:1rem}.header-info{font-size:.9rem;opacity:.8}.github-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:6px;background-color:#ffffff1a;color:#fff;text-decoration:none;transition:background-color .2s ease}.github-button:hover{background-color:#fff3}.layout-counter{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;background-color:#ffffff1a;color:#fff;font-size:.9rem;font-weight:500}.layout-counter svg{opacity:.8}.layout-counter-number{font-weight:600}.layout-counter-label{opacity:.8;font-size:.85rem}.app-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.toolbar{background-color:#fff;border-bottom:1px solid #ddd;padding:.5rem;display:flex;gap:.5rem;align-items:center}.editor-container{flex:1;display:flex;overflow:hidden}.sidebar{background-color:#fff;border-right:1px solid #ddd;width:300px;overflow-y:auto;padding:1rem;transition:width .3s ease}.sidebar-right{border-right:none;border-left:1px solid #ddd}.canvas-container{flex:1;background-color:#fafafa;overflow:auto;position:relative}.placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#999;font-size:1.2rem}.placeholder p{margin:.5rem 0}.properties-panel{height:100%;overflow-y:auto}.properties-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.properties-panel h3{margin:0;font-size:1.1rem;color:#2c3e50}.collapse-button{background:none;border:none;padding:.25rem;cursor:pointer;color:#666;transition:color .2s;border-radius:4px}.collapse-button:hover{background-color:#f0f0f0;color:#333}.sidebar.collapsed{width:40px;padding:.5rem}.properties-panel.collapsed{display:flex;justify-content:center;align-items:flex-start;height:100%}.expand-button{background:none;border:none;padding:.5rem;cursor:pointer;color:#666;transition:all .2s;border-radius:4px}.expand-button:hover{background-color:#f0f0f0;color:#333}.property-section{margin-bottom:1rem;border-bottom:1px solid #eee;padding-bottom:1rem}.section-header{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem 0;font-weight:600;color:#2c3e50;-webkit-user-select:none;user-select:none}.section-header:hover{color:#3498db}.section-content{margin-top:.5rem}.property-row{margin-bottom:.75rem}.property-row label{display:block;font-size:.85rem;color:#666;margin-bottom:.25rem}.property-row input[type=text],.property-row input[type=number],.property-row input[type=color],.property-row textarea,.property-row select{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.property-row input[type=color]{height:36px;cursor:pointer}.property-row textarea{resize:vertical;min-height:60px}.property-row-dual{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.property-field label{display:block;font-size:.85rem;color:#666;margin-bottom:.25rem}.property-field input{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.checkbox-row{display:flex;align-items:center}.checkbox-row label{display:flex;align-items:center;gap:.5rem;cursor:pointer;margin-bottom:0}.checkbox-row input[type=checkbox]{width:auto}.no-selection{text-align:center;padding:2rem 1rem;color:#999}.no-selection p{margin:.5rem 0}.hint{font-size:.85rem;color:#999;font-style:italic}.selection-info{background-color:#ecf0f1;padding:.5rem;border-radius:4px;font-size:.9rem;margin-bottom:1rem;text-align:center}.legends-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.legend-help{margin-top:10px;padding:8px;background:#f8f9fa;border-radius:4px;font-size:12px}.legend-help .help-text{margin:0;color:#6c757d}.legend-help code{background:#e9ecef;padding:2px 4px;border-radius:3px;font-size:11px;font-family:monospace}.legend-field{position:relative}.legend-field input{padding:.4rem;border:1px solid #ddd;border-radius:4px;font-size:.85rem;width:100%}.icon-dropdown{margin-top:4px;display:flex;align-items:center;gap:4px}.icon-dropdown label{font-size:.75rem;color:#666}.icon-dropdown select{flex:1;padding:4px;border:1px solid #ddd;border-radius:3px;font-size:.75rem;background-color:#fff}.advanced-legends{display:flex;flex-direction:column;gap:.5rem}.advanced-legend-row{display:grid;grid-template-columns:30px 60px 1fr;gap:.5rem;align-items:center}.legend-index{font-size:.85rem;color:#666;text-align:right}.advanced-legend-row input[type=color]{height:30px;padding:2px}.advanced-legend-row input[type=number]{padding:.4rem;border:1px solid #ddd;border-radius:4px;font-size:.85rem}.toolbar-container{background-color:#fff;border-bottom:1px solid #ddd}.toolbar{display:flex;align-items:center;gap:.5rem;padding:.5rem}.color-menu-buttons{display:flex;gap:.25rem}.color-menu-btn{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem;font-size:.85rem;font-weight:500}.color-menu-expanded{width:100%;background:#fff;border-top:1px solid #eee}.color-menu-header{padding:.5rem 1rem;border-bottom:1px solid #eee}.color-menu-header h4{margin:0 0 .25rem;font-size:1rem;color:#2c3e50}.color-menu-hint{font-size:.75rem;color:#666;margin:0}.color-name{font-weight:600;color:#333}.color-menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:4px;padding:1rem;max-height:200px;overflow-y:auto}.color-menu-item{width:40px;height:40px;border-radius:4px;cursor:pointer;transition:all .2s;border:2px solid transparent;position:relative}.color-menu-item:hover{transform:scale(1.1);border-color:#333;box-shadow:0 2px 8px #0003;z-index:10}.color-tooltip{background:#000000e6;color:#fff;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:600;pointer-events:none;z-index:1001;white-space:nowrap;box-shadow:0 2px 4px #0003}.toolbar-group{display:flex;gap:.25rem}.toolbar-btn{padding:.5rem;border:1px solid transparent;background:none;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;color:#666;transition:all .2s}.toolbar-btn:hover:not(:disabled){background-color:#f0f0f0;color:#333}.toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.toolbar-btn.active{background-color:#3498db;color:#fff}.toolbar-btn.active:hover{background-color:#2980b9}.toolbar-separator{width:1px;height:24px;background-color:#ddd}.toolbar-spacer{flex:1}.toolbar-info{font-size:.85rem;color:#666;padding:0 1rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid #ddd;background-color:#fff;cursor:pointer;border-radius:4px;font-size:.9rem;transition:all .2s}.btn:hover:not(:disabled){background-color:#f0f0f0}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:.5rem 1rem;font-size:.85rem}.btn-primary{background-color:#3498db;color:#fff;border-color:#3498db}.btn-primary:hover:not(:disabled){background-color:#2980b9}.btn-highlight{animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #3498db66}70%{box-shadow:0 0 0 10px #3498db00}to{box-shadow:0 0 #3498db00}}.raw-data-editor{height:100%;display:flex;flex-direction:column}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.editor-header h3{margin:0;font-size:1.1rem;color:#2c3e50}.editor-actions{display:flex;gap:.5rem}.editor-content{flex:1;display:flex;flex-direction:column;min-height:0}.editor-content textarea{flex:1;width:100%;padding:1rem;border:1px solid #ddd;border-radius:4px;font-family:Consolas,Monaco,Courier New,monospace;font-size:.85rem;resize:none;background-color:#f8f8f8}.editor-footer{margin-top:.5rem}.alert{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:4px;margin-bottom:1rem;font-size:.9rem}.alert-error{background-color:#fee;color:#c33;border:1px solid #fcc}.alert-success{background-color:#efe;color:#3c3;border:1px solid #cfc}.preset-layouts{height:100%;display:flex;flex-direction:column}.preset-layouts h3{margin:0 0 1rem;font-size:1.1rem;color:#2c3e50}.preset-list{display:flex;flex-direction:column;gap:.5rem}.preset-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border:1px solid #ddd;background-color:#fff;cursor:pointer;border-radius:4px;transition:all .2s;text-align:left;width:100%}.preset-item:hover{background-color:#f0f0f0;border-color:#3498db}.preset-info{margin-top:auto;padding-top:1rem}.tabs{display:flex;border-bottom:1px solid #ddd;margin-bottom:1rem}.tab{padding:.75rem 1rem;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:.9rem;color:#666;transition:all .2s}.tab:hover{color:#333}.tab.active{color:#3498db;border-bottom-color:#3498db}.tab-content{height:calc(100% - 3rem)}.tabbed-sidebar{height:100%;display:flex;flex-direction:column}.export-menu-container{position:relative}.export-menu{position:absolute;top:100%;right:0;margin-top:.25rem;background-color:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 8px #0000001a;min-width:160px;z-index:100}.export-menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;border:none;background:none;cursor:pointer;text-align:left;transition:background-color .2s}.export-menu-item:hover{background-color:#f0f0f0}.export-menu-item:first-child{border-radius:4px 4px 0 0}.export-menu-item:last-child{border-radius:0 0 4px 4px}.color-picker{margin-bottom:1rem}.color-picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.color-picker-header label{font-size:.85rem;color:#666;margin-right:.5rem}.color-picker-current{display:flex;align-items:center;gap:.5rem}.color-picker-current input[type=color]{width:40px;height:30px;border:1px solid #ddd;border-radius:4px;cursor:pointer;padding:0;-webkit-appearance:none;appearance:none}.property-row .color-picker-current input[type=color]{padding:0;border:none;width:40px;height:30px}.color-picker-current input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-picker-current input[type=color]::-webkit-color-swatch{border:1px solid #ddd;border-radius:4px}.color-picker-current span{font-family:monospace;font-size:.85rem;color:#666}.color-info{display:flex;flex-direction:column;gap:.25rem;margin-right:1rem}.color-hex{font-family:monospace;font-size:.85rem;color:#666}.color-name{font-size:.75rem;color:#999;font-style:italic}.color-picker-search{margin-bottom:.75rem}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:.75rem;color:#999;pointer-events:none;z-index:1}.search-input{width:100%;padding:.5rem .75rem .5rem 2.5rem!important;border:1px solid #ddd;border-radius:4px;font-size:.85rem;transition:border-color .2s;text-indent:0}.search-input:focus{outline:none;border-color:#3498db}.search-input::placeholder{color:#999}.color-swatches{border:1px solid #eee;border-radius:4px;max-height:300px;overflow-y:auto}.color-swatch-group{border-bottom:1px solid #eee}.color-swatch-group:last-child{border-bottom:none}.swatch-header{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer;font-size:.85rem;font-weight:600;-webkit-user-select:none;user-select:none}.swatch-header:hover{background-color:#f5f5f5}.swatch-colors{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:.5rem;padding:.5rem;background-color:#fafafa}.swatch-color{display:flex;flex-direction:column;align-items:center;gap:.25rem;cursor:pointer;padding:.25rem;border-radius:4px}.swatch-color:hover{background-color:#eee}.swatch-color-box{width:40px;height:30px;border:1px solid #ddd;border-radius:4px}.swatch-color-name{font-size:.7rem;text-align:center;color:#666}.character-picker-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.character-picker{background-color:#fff;border-radius:8px;box-shadow:0 4px 16px #0003;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column}.character-picker-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #ddd}.character-picker-header h3{margin:0;font-size:1.2rem}.close-btn{padding:.5rem;background:none;border:none;cursor:pointer;border-radius:4px;color:#666}.close-btn:hover{background-color:#f0f0f0}.character-sets{display:flex;gap:.5rem;padding:1rem;flex-wrap:wrap;border-bottom:1px solid #eee}.character-set-btn{padding:.5rem 1rem;background:none;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.character-set-btn:hover{background-color:#f0f0f0}.character-set-btn.active{background-color:#3498db;color:#fff;border-color:#3498db}.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:.5rem;padding:1rem;overflow-y:auto;flex:1}.character-btn{padding:.75rem;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:1.2rem;text-align:center;transition:all .2s}.character-btn:hover{background-color:#f0f0f0;border-color:#3498db}.legends-controls{margin-bottom:.75rem}.legends-controls .btn{display:inline-flex;align-items:center;gap:.5rem}.menu-bar{background-color:#f8f8f8;border-bottom:1px solid #ddd;display:flex;align-items:center;padding:0 .5rem;height:32px;position:relative}.menu-item{position:relative;padding:.25rem 1rem;cursor:pointer;display:flex;align-items:center;gap:.25rem;font-size:.9rem;color:#333;border-radius:4px;-webkit-user-select:none;user-select:none}.menu-item:hover{background-color:#e0e0e0}.menu-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background-color:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 8px #0000001a;min-width:180px;z-index:1000;padding:.25rem}.menu-dropdown-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.5rem 1rem;text-align:left;background:none;border:none;cursor:pointer;font-size:.9rem;color:#333;border-radius:3px;transition:background-color .2s}.menu-dropdown-item:hover{background-color:#f0f0f0}.menu-dropdown-separator{height:1px;background-color:#e0e0e0;margin:.25rem .5rem}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background-color:#fff;border-radius:8px;box-shadow:0 4px 16px #0003;max-width:90vw;max-height:90vh;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #ddd}.modal-header h2{margin:0;font-size:1.25rem;color:#2c3e50}.modal-body{flex:1;padding:1.5rem;overflow-y:auto;min-height:0}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #ddd}.raw-data-modal{width:800px;height:600px}.raw-data-modal .modal-body{display:flex;flex-direction:column;gap:1rem}.raw-data-modal .import-options{display:flex;align-items:center;gap:1rem;padding:.5rem;background:#f5f5f5;border-radius:4px}.raw-data-modal .import-options label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#666}.raw-data-modal .import-options select{padding:.25rem .5rem;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:.875rem}.raw-data-modal textarea{flex:1;width:100%;padding:1rem;border:1px solid #ddd;border-radius:4px;font-family:Consolas,Monaco,Courier New,monospace;font-size:.85rem;resize:none;background-color:#f8f8f8}.add-key-menu-container{position:relative}.add-key-menu{position:absolute;top:100%;left:0;margin-top:.25rem;background-color:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 8px #0000001a;min-width:180px;z-index:100;max-height:400px;overflow-y:auto}.add-key-category{border-bottom:1px solid #eee}.add-key-category:last-child{border-bottom:none}.add-key-category-header{padding:.5rem .75rem;font-size:.8rem;font-weight:600;color:#666;background-color:#f8f8f8}.add-key-menu-item{display:block;width:100%;padding:.5rem 1rem;text-align:left;background:none;border:none;cursor:pointer;font-size:.9rem;color:#333;transition:background-color .2s}.add-key-menu-item:hover{background-color:#f0f0f0}.add-key-quantity{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid #e0e0e0}.add-key-quantity label{font-size:.9rem;font-weight:500;color:#666}.quantity-input{width:60px;padding:.25rem .5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;text-align:center}.quantity-input:focus{outline:none;border-color:#3498db}.quantity-badge{font-size:.85rem;color:#666;font-weight:500}.login-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background-color:#5865f2;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.login-button:hover{background-color:#4752c4}.user-menu{position:relative}.user-menu-button{display:flex;align-items:center;gap:8px;padding:4px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;transition:all .2s;color:#fff}.user-menu-button:hover{background-color:#fff3;border-color:#ffffff4d}.user-avatar{width:24px;height:24px;border-radius:50%}.user-name{font-size:14px;font-weight:500}.user-dropdown{position:absolute;top:100%;right:0;margin-top:8px;min-width:200px;background:#fff;border:1px solid #dee2e6;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:1000;color:#333}.user-dropdown-info{display:flex;align-items:center;gap:8px;padding:12px 16px;font-size:14px;color:#6c757d}.user-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 16px;background:none;border:none;text-align:left;font-size:14px;cursor:pointer;transition:background-color .2s}.user-dropdown-item:hover{background-color:#f8f9fa}.user-dropdown-item.logout{color:#dc3545}.user-dropdown-item.logout:hover{background-color:#dc3545;color:#fff}.dropdown-separator{height:1px;background-color:#e0e0e0;margin:4px 0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite;display:inline-block}.my-layouts-page,.import-gists-page{min-height:100vh;background-color:#f5f5f5;padding:2rem}.import-header{display:flex;align-items:center;gap:2rem;margin-bottom:2rem}.import-header h1{font-size:2rem;font-weight:600;margin:0}.github-connect-container{display:flex;justify-content:center;align-items:center;min-height:50vh}.github-connect-box{background:#fff;border-radius:12px;padding:3rem;text-align:center;max-width:500px;box-shadow:0 4px 6px #0000001a}.github-connect-box svg{margin-bottom:1.5rem;opacity:.8}.github-connect-box h2{margin-bottom:1rem;font-size:1.5rem}.github-connect-box p{color:#666;margin-bottom:1rem;line-height:1.6}.privacy-note{font-size:.875rem;color:#999}.btn-large{padding:12px 24px!important;font-size:1rem!important}.import-controls{background:#fff;border-radius:8px;padding:1rem;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000001a}.selection-info{font-weight:500;color:#666}.control-buttons{display:flex;gap:.5rem}.gist-list{display:flex;flex-direction:column;gap:.5rem}.gist-item{background:#fff;border-radius:8px;padding:1rem;display:flex;gap:1rem;align-items:flex-start;transition:all .2s ease;border:2px solid transparent}.gist-item:hover{box-shadow:0 2px 4px #0000001a}.gist-item.selected{border-color:#3498db;background-color:#f0f8ff}.gist-item.has-error{opacity:.7}.gist-checkbox{padding-top:.25rem}.gist-info{flex:1}.gist-name{font-weight:600;font-size:1.1rem;margin-bottom:.5rem}.name-editor{display:flex;gap:.5rem;align-items:center}.name-editor input{flex:1;padding:.25rem .5rem;border:1px solid #ddd;border-radius:4px;font-size:1.1rem;font-weight:600}.name-display{display:flex;align-items:center;gap:.5rem}.btn-icon{padding:.25rem!important;opacity:0;transition:opacity .2s ease}.gist-item:hover .btn-icon{opacity:1}.gist-meta{display:flex;gap:1rem;font-size:.875rem;color:#666}.gist-meta .filename{font-family:monospace;background-color:#f0f0f0;padding:.125rem .5rem;border-radius:4px}.gist-meta .key-count{font-weight:500;color:#27ae60}.gist-error{display:flex;align-items:center;gap:.5rem;color:#e74c3c;font-size:.875rem;margin-top:.5rem}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;max-width:500px;margin:0 auto}.empty-state svg{margin-bottom:1.5rem;opacity:.5}.empty-state h2{margin-bottom:1rem;color:#333}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem;color:#666}.layouts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.layouts-header h1{font-size:2rem;color:#2c3e50;margin:0}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.empty-state h2{margin:0 0 1rem;color:#2c3e50}.empty-state p{color:#666;margin-bottom:2rem}.layouts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(450px,1fr));gap:1.5rem}.layout-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;transition:box-shadow .2s}.layout-card:hover{box-shadow:0 4px 8px #00000026}.layout-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.layout-card-header h3{margin:0;font-size:1.25rem;color:#2c3e50}.layout-visibility{color:#666}.layout-description{color:#666;margin-bottom:1rem;font-size:.9rem;line-height:1.5}.layout-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.layout-tags .tag{padding:.25rem .5rem;background:#e0e0e0;border-radius:4px;font-size:.8rem;color:#666}.layout-meta{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem;font-size:.8rem;color:#999}.layout-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid #eee;flex-wrap:wrap}.layout-actions .btn{display:flex;align-items:center;gap:.25rem;flex:0 0 auto;min-width:100px;justify-content:center}.public-layout-page{min-height:100vh;background-color:#f5f5f5;padding:2rem}.public-layout-header{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;gap:2rem}.layout-info h1{margin:0 0 .5rem;font-size:2rem;color:#2c3e50}.layout-author{color:#666;font-size:.9rem;margin-bottom:1rem}.public-layout-header .layout-actions{display:flex;gap:1rem;flex-shrink:0}.public-layout-header .layout-actions .btn{display:flex;align-items:center}.layout-preview{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a}.preview-info{text-align:center;color:#666}.preview-info p{margin:.5rem 0}.error-container{text-align:center;padding:4rem 2rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.error-container h2{color:#dc3545;margin-bottom:1rem}.error-container p{color:#666;margin-bottom:2rem}.user-settings{width:90%;max-width:600px}.settings-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #eee}.settings-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.settings-section h3{font-size:1.1rem;margin-bottom:1rem;color:#2c3e50}.setting-item{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.setting-info{flex:1}.setting-info label{font-weight:600;display:block;margin-bottom:.25rem}.setting-description{font-size:.875rem;color:#666;margin:0}.toggle-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;transition:all .2s}.toggle-button:hover{border-color:#3498db}.toggle-button.active{background:#2c3e50;color:#fff;border-color:#2c3e50}.danger-zone h3{color:#dc3545}.btn-danger{background:#dc3545;color:#fff;border-color:#dc3545}.btn-danger:hover{background:#c82333;border-color:#bd2130}.delete-confirm{margin-top:1rem;padding:1rem;background:#f8f9fa;border-radius:4px}.alert-danger{display:flex;gap:1rem;padding:1rem;background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin-bottom:1rem}.alert-danger ul{margin:.5rem 0 .5rem 1.5rem;padding:0}.alert-danger p{margin:.5rem 0 0}.delete-actions{display:flex;gap:.5rem;margin-top:1rem}.dark-mode,.dark-mode body{background-color:#1a1a1a;color:#e0e0e0}.dark-mode .app-header{background-color:#0d0d0d;border-bottom:1px solid #333}.dark-mode .github-button{background-color:#ffffff0d}.dark-mode .github-button:hover{background-color:#ffffff1a}.dark-mode .layout-counter{background-color:#ffffff0d}.dark-mode .menu-bar{background-color:#2a2a2a;border-bottom:1px solid #333}.dark-mode .toolbar-container{background-color:#2a2a2a;border-bottom:none}.dark-mode .toolbar{background-color:transparent;border-bottom:none}.dark-mode .properties-panel,.dark-mode .sidebar{background-color:#2a2a2a;border-right:1px solid #333}.dark-mode .sidebar-right{border-left:1px solid #333}.dark-mode .canvas-container{background-color:#1a1a1a}.dark-mode .modal-content{background-color:#2a2a2a;color:#e0e0e0}.dark-mode .form-input,.dark-mode .form-select,.dark-mode .form-textarea{background-color:#1a1a1a;color:#e0e0e0;border-color:#444}.dark-mode .btn{background-color:#3a3a3a;color:#e0e0e0;border-color:#444}.dark-mode .btn:hover{background-color:#4a4a4a;border-color:#555}.dark-mode .btn-primary{background-color:#2980b9;border-color:#2980b9}.dark-mode .btn-primary:hover{background-color:#3498db;border-color:#3498db}.dark-mode .settings-section{border-bottom-color:#444}.dark-mode .toggle-button{background-color:#3a3a3a;border-color:#444;color:#e0e0e0}.dark-mode .toggle-button:hover{border-color:#3498db}.dark-mode .delete-confirm{background-color:#3a3a3a}.dark-mode .user-menu-button{color:#e0e0e0;background:#ffffff1a;border-color:#fff3}.dark-mode .user-menu-button:hover{background-color:#ffffff26;border-color:#ffffff4d}.dark-mode .user-dropdown{background-color:#2a2a2a;border-color:#444}.dark-mode .user-dropdown-info,.dark-mode .user-dropdown-item{color:#e0e0e0}.dark-mode .user-dropdown-item:hover{background-color:#3a3a3a;color:#fff}.dark-mode .user-dropdown-item.logout{color:#ff6b6b}.dark-mode .user-dropdown-item.logout:hover{background-color:#dc3545;color:#fff}.dark-mode .dropdown-separator{background-color:#444}.dark-mode .menu-item{color:#e0e0e0}.dark-mode .menu-item:hover{background-color:#3a3a3a;color:#fff}.dark-mode .menu-dropdown{background-color:#2a2a2a;border-color:#444;box-shadow:0 2px 8px #0000004d}.dark-mode .menu-dropdown-item{color:#e0e0e0}.dark-mode .menu-dropdown-item:hover{background-color:#3a3a3a}.dark-mode .menu-dropdown-separator{background-color:#444}.dark-mode .toolbar-btn{color:#e0e0e0}.dark-mode .toolbar-btn:hover:not(:disabled){background-color:#3a3a3a;color:#fff}.dark-mode .toolbar-btn:disabled{color:#666;opacity:.5}.dark-mode .toolbar-btn.active{background-color:#3498db;color:#fff}.dark-mode .toolbar-separator{background-color:#444}.dark-mode .toolbar-info{color:#b0b0b0}.dark-mode .color-menu-expanded{background:#2a2a2a;border-top-color:#444}.dark-mode .color-menu-header{border-bottom-color:#444}.dark-mode .color-menu-header h4{color:#e0e0e0}.dark-mode .color-menu-hint{color:#b0b0b0}.dark-mode .color-name{color:#e0e0e0}.dark-mode .color-menu-item:hover{border-color:#e0e0e0}.dark-mode .color-tooltip{background:#fffffff2;color:#1a1a1a}.dark-mode .section-header{color:#e0e0e0}.dark-mode .section-header:hover{color:#3498db}.dark-mode .property-section{border-bottom-color:#444}.dark-mode .properties-panel h3{color:#e0e0e0}.dark-mode .collapse-button{color:#aaa}.dark-mode .collapse-button:hover{background-color:#333;color:#e0e0e0}.dark-mode .expand-button{color:#aaa}.dark-mode .expand-button:hover{background-color:#333;color:#e0e0e0}.dark-mode .export-menu{background-color:#2a2a2a;border-color:#444;box-shadow:0 2px 8px #0000004d}.dark-mode .export-menu-item{color:#e0e0e0}.dark-mode .export-menu-item:hover{background-color:#3a3a3a}.dark-mode .add-key-menu{background-color:#2a2a2a;border-color:#444;box-shadow:0 2px 8px #0000004d}.dark-mode .add-key-category{border-bottom-color:#444}.dark-mode .add-key-category-header{background-color:#333;color:#b0b0b0}.dark-mode .add-key-menu-item{color:#e0e0e0}.dark-mode .add-key-menu-item:hover{background-color:#3a3a3a}.dark-mode .add-key-quantity{border-bottom-color:#444}.dark-mode .add-key-quantity label{color:#999}.dark-mode .quantity-input{background-color:#1a1a1a;color:#e0e0e0;border-color:#444}.dark-mode .quantity-input:focus{border-color:#3498db}.dark-mode .quantity-badge{color:#999}.dark-mode .property-row input[type=text],.dark-mode .property-row input[type=number],.dark-mode .property-row select,.dark-mode .property-row textarea{background-color:#1a1a1a;color:#e0e0e0;border-color:#444}.dark-mode .property-row label{color:#b0b0b0}.dark-mode .hint,.dark-mode .no-selection{color:#999}.dark-mode .selection-info{color:#b0b0b0;background-color:#1a1a1a}.dark-mode .legend-field input,.dark-mode .property-field input,.dark-mode .advanced-legend-row input[type=number]{background-color:#1a1a1a;color:#e0e0e0;border-color:#444}.dark-mode .property-row input[type=color],.dark-mode .advanced-legend-row input[type=color]{background-color:#1a1a1a;border-color:#444}.dark-mode .icon-dropdown select,.dark-mode .raw-data-modal textarea,.dark-mode .raw-data-modal .import-options select{background-color:#1a1a1a;color:#e0e0e0;border-color:#444}.dark-mode .color-picker-current input[type=color]{background-color:#1a1a1a;border-color:#444}.dark-mode .color-hex{color:#b0b0b0}.dark-mode .color-name{color:#888}.dark-mode .editor-content textarea,.dark-mode input[type=text],.dark-mode input[type=number],.dark-mode input[type=email],.dark-mode input[type=password],.dark-mode select,.dark-mode textarea{background-color:#1a1a1a;color:#e0e0e0;border-color:#444}.dark-mode input[type=text]:focus,.dark-mode input[type=number]:focus,.dark-mode input[type=email]:focus,.dark-mode input[type=password]:focus,.dark-mode select:focus,.dark-mode textarea:focus{border-color:#3498db;outline:none}.dark-mode .my-layouts-page{background-color:#1a1a1a;color:#e0e0e0}.dark-mode .layouts-header h1{color:#e0e0e0}.dark-mode .layout-card{background-color:#2a2a2a;box-shadow:0 2px 4px #0000004d}.dark-mode .layout-card:hover{box-shadow:0 4px 8px #0006}.dark-mode .layout-card-header h3{color:#e0e0e0}html.dark-mode body{background-color:#1a1a1a}.dark-mode .import-gists-page{background-color:#1a1a1a;color:#e0e0e0}.dark-mode .github-connect-box{background-color:#2a2a2a;color:#e0e0e0}.dark-mode .github-connect-box h2{color:#e0e0e0}.dark-mode .github-connect-box p{color:#bbb}.dark-mode .import-controls{background-color:#2a2a2a;box-shadow:0 1px 3px #0000004d}.dark-mode .gist-item{background-color:#2a2a2a;color:#e0e0e0}.dark-mode .gist-item:hover{box-shadow:0 2px 4px #0000004d}.dark-mode .gist-item.selected{background-color:#1e3a5f;border-color:#4a90e2}.dark-mode .gist-meta .filename{background-color:#333;color:#e0e0e0}.dark-mode .name-editor input{background-color:#333;border-color:#444;color:#e0e0e0}.dark-mode .empty-state{background-color:#2a2a2a;color:#e0e0e0}.dark-mode .empty-state p{color:#bbb}.dark-mode .layout-visibility,.dark-mode .layout-description{color:#b0b0b0}.dark-mode .layout-tags .tag{background-color:#3a3a3a;color:#b0b0b0}.dark-mode .layout-meta{color:#999}.dark-mode .layout-actions{border-top-color:#444}.dark-mode .empty-state{background-color:#2a2a2a;box-shadow:0 2px 4px #0000004d}.dark-mode .empty-state h2{color:#e0e0e0}.dark-mode .empty-state p{color:#b0b0b0}.dark-mode .loading-container{color:#e0e0e0}.dark-mode .alert-error{background-color:#3a1515;color:#ff6b6b;border-color:#5a2020}.legend-size-selector{margin-top:4px;display:flex;align-items:center;gap:4px}.legend-size-selector label{font-size:.75rem;color:#666}.legend-size-selector input{flex:1;width:60px;padding:4px;border:1px solid #ddd;border-radius:3px;font-size:.75rem;background-color:#fff}.dark-mode .legend-size-selector label{color:#aaa}.dark-mode .legend-size-selector input{background-color:#1a1a1a;color:#e0e0e0;border-color:#444}.btn svg{flex-shrink:0}.dark-mode .gist-list{background-color:transparent}.dark-mode .gist-item.selected{background-color:#333;border-color:#3498db}.dark-mode .gist-meta{color:#999}.dark-mode .name-editor input{background-color:#1a1a1a;color:#e0e0e0;border-color:#444}.dark-mode .gist-error{color:#ff6b6b;background-color:#ff6b6b1a}.dark-mode .import-header,.dark-mode .gist-name,.dark-mode .name-display{color:#e0e0e0}.dark-mode .gist-meta .date{color:#888}.dark-mode .gist-meta .key-count{color:#4ade80}.dark-mode .control-buttons .btn:not(.btn-primary){background-color:#2a2a2a;border-color:#444;color:#e0e0e0}.dark-mode .control-buttons .btn:not(.btn-primary):hover:not(:disabled){background-color:#333;border-color:#555}.dark-mode .gist-checkbox input[type=checkbox]{accent-color:#3498db}
