:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--primary-color: #81D4FA;--primary-hover: #4FC3F7;--background-color: #f5f7fa;--surface-color: #ffffff;--text-color: #333333;--text-secondary: #666666;--border-color: #e0e0e0;--accent-staircase: #A9A9A9;--accent-type-a: #039BE5;--accent-type-b: #29B6F6;--accent-type-c: #4FC3F7;--accent-type-d: #81D4FA;--surface-secondary: #f8f9fa;--surface-highlight: #e7f5ff;--surface-hover: #e9ecef;--text-muted: #888888;color-scheme:light;color:var(--text-color);background-color:var(--background-color);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:var(--background-color);touch-action:none}h1,h2,h3,h4,h5,h6{font-weight:600;color:var(--text-color);margin-top:0}button{border-radius:6px;border:1px solid transparent;padding:.6em 1.2em;font-size:.9em;font-weight:500;font-family:inherit;background-color:var(--primary-color);color:#fff;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}button:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 6px #00000026}button:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}input{padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;font-family:inherit;font-size:.9em;color:var(--text-color);background:var(--surface-color);transition:border-color .2s}input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #81d4fa33}label{font-size:.85em;font-weight:500;color:var(--text-secondary);margin-bottom:4px;display:block}body.dark{--primary-color: #4FC3F7;--primary-hover: #81D4FA;--background-color: #121212;--surface-color: #1E1E1E;--text-color: #E0E0E0;--text-secondary: #B0B0B0;--border-color: #333333;--accent-staircase: #424242;--accent-type-a: #014377;--accent-type-b: #02598c;--accent-type-c: #026ca3;--accent-type-d: #027ebc;--surface-secondary: #252525;--surface-highlight: #1a3b5c;--surface-hover: #333333;--text-muted: #999999}.precision-total{margin-top:12px;text-align:right;font-size:1em;color:var(--text-primary)}.block-picker-overlay{position:fixed;inset:0;background:#00000080;z-index:2000;display:flex;justify-content:center;align-items:center}.block-picker-menu{background:var(--surface-primary, white);width:350px;max-height:80vh;border-radius:8px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 4px 12px #0003;color:var(--text-primary)}.block-picker-header{padding:12px;border-bottom:1px solid var(--border-color, #eee);display:flex;justify-content:space-between;align-items:center;font-weight:600}.close-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px}.close-btn:hover{color:var(--text-primary)}.block-picker-content{overflow-y:auto;padding:8px}.picker-category{margin-bottom:4px}.category-header{display:flex;align-items:center;gap:6px;padding:8px;cursor:pointer;font-weight:500;border-radius:4px;-webkit-user-select:none;user-select:none;background:var(--surface-secondary, #eee)}.category-header:hover{background:var(--surface-hover, #ddd)}.category-blocks{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:4px 8px 8px 12px}.picker-block-item{display:flex;align-items:center;gap:8px;border:1px solid var(--border-color, #eee);background:var(--surface-secondary, #f9f9f9);padding:8px;border-radius:4px;cursor:pointer;text-align:left;transition:all .2s}.picker-block-item:hover{background:var(--surface-hover);border-color:var(--primary-color, #4dabf7);transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.block-symbol{width:28px;height:28px;flex-shrink:0;display:flex;justify-content:center;align-items:center;border-radius:4px;font-size:.85em;font-weight:700;color:#333;border:1px solid rgba(0,0,0,.1)}.block-name{font-size:.85em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.virtual-joystick{position:relative;-webkit-user-select:none;user-select:none;touch-action:none}.joystick-outer{position:relative;border-radius:50%;background:var(--surface-secondary, rgba(240, 240, 240, .5));border:1px solid var(--border-color, #ddd);box-shadow:inset 0 0 15px #0000000d,0 2px 8px #00000014;display:flex;align-items:center;justify-content:center;transition:border-color .2s ease,box-shadow .2s ease}.virtual-joystick.active .joystick-outer{border-color:var(--primary-color, #4a90d9);box-shadow:inset 0 0 15px #0000000d,0 2px 12px #4a90d933}.crosshair{position:absolute;background:var(--border-color, rgba(0, 0, 0, .1))}.crosshair.horizontal{width:50%;height:1px;left:25%;top:50%}.crosshair.vertical{width:1px;height:50%;left:50%;top:25%}.direction-label{position:absolute;font-size:.6rem;font-weight:600;color:var(--text-muted, rgba(0, 0, 0, .35));pointer-events:none;letter-spacing:.02em}.direction-label.top{top:8px;left:50%;transform:translate(-50%)}.direction-label.bottom{bottom:8px;left:50%;transform:translate(-50%)}.direction-label.left{left:8px;top:50%;transform:translateY(-50%)}.direction-label.right{right:8px;top:50%;transform:translateY(-50%)}.joystick-inner{position:absolute;border-radius:50%;cursor:grab;transition:box-shadow .15s ease;background:linear-gradient(145deg,var(--primary-color, #4a90d9) 0%,color-mix(in srgb,var(--primary-color, #4a90d9) 80%,#000) 100%);border:2px solid rgba(255,255,255,.25);box-shadow:0 2px 8px #0003,inset 0 1px 2px #fff3}.joystick-inner:hover{box-shadow:0 3px 12px #4a90d966,inset 0 1px 2px #ffffff4d}.virtual-joystick.active .joystick-inner{cursor:grabbing;box-shadow:0 4px 16px #4a90d980,inset 0 1px 2px #ffffff4d}.inner-highlight{position:absolute;top:12%;left:15%;width:35%;height:25%;border-radius:50%;background:linear-gradient(135deg,#fff6,#fff0)}.virtual-joystick.dark .joystick-outer{background:var(--surface-secondary, rgba(40, 40, 45, .6));border-color:var(--border-color, #444)}.virtual-joystick.dark .crosshair{background:#ffffff1a}.virtual-joystick.dark .direction-label{color:#ffffff4d}.virtual-joystick.dark .joystick-inner{background:linear-gradient(145deg,#5a9fe9,#3a7bc8)}.virtual-joystick.dark.active .joystick-outer{border-color:#5aa0e680;box-shadow:inset 0 0 15px #0003,0 2px 12px #5aa0e640}.virtual-joystick.dark.active .joystick-inner{box-shadow:0 4px 20px #5aa0e680,inset 0 1px 2px #fff3}.environment-panel{padding:16px;display:flex;flex-direction:column;gap:16px}.environment-panel h3{margin:0 0 8px;font-size:1.1rem;font-weight:600;color:var(--text-primary, #333)}.environment-panel h4{margin:0 0 8px;font-size:.85rem;font-weight:500;color:var(--text-secondary, #666)}.file-dropzone{position:relative;border:2px dashed var(--border-color, #ccc);border-radius:12px;padding:32px 16px;text-align:center;transition:all .3s ease;background:linear-gradient(135deg,#ffffff1a,#ffffff0d);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer}.file-dropzone:hover{border-color:var(--primary-color, #4a90d9);background:linear-gradient(135deg,#4a90d91a,#4a90d90d)}.file-dropzone.dragging{border-color:var(--primary-color, #4a90d9);background:linear-gradient(135deg,#4a90d933,#4a90d91a);transform:scale(1.02)}.file-dropzone.uploading{pointer-events:none;opacity:.7}.file-dropzone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:8px}.dropzone-icon{font-size:2.5rem;line-height:1}.dropzone-content p{margin:0;font-size:.9rem;color:var(--text-secondary, #666)}.dropzone-formats{font-size:.75rem;color:var(--text-tertiary, #999)}.upload-spinner{width:24px;height:24px;border:3px solid var(--border-color, #ccc);border-top-color:var(--primary-color, #4a90d9);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.file-info{background:linear-gradient(135deg,#ffffff26,#ffffff14);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color, rgba(255, 255, 255, .2));border-radius:12px;padding:12px 16px}.file-header{display:flex;align-items:center;gap:12px}.file-icon{font-size:1.5rem;line-height:1}.file-details{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.file-name{font-size:.9rem;font-weight:500;color:var(--text-primary, #333);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-type{font-size:.75rem;color:var(--text-tertiary, #999)}.btn-clear{width:28px;height:28px;padding:0;border:none;border-radius:50%;background:#ff64641a;color:#ff6464;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-size:.9rem}.btn-clear:hover{background:#ff646433;transform:scale(1.1)}.error-message{padding:8px 12px;background:#ff64641a;border:1px solid rgba(255,100,100,.3);border-radius:8px;color:#ff6464;font-size:.85rem}.transform-controls{display:flex;flex-direction:column;gap:16px}.control-section{display:flex;flex-direction:column;gap:8px}.control-row{display:flex;align-items:center;gap:8px}.control-row label{width:20px;font-size:.85rem;font-weight:500;color:var(--text-secondary, #666)}.control-row input[type=number]{flex:1;min-width:0;padding:6px 10px;border:1px solid var(--border-color, #ddd);border-radius:6px;font-size:.85rem;background:var(--input-bg, #fff);color:var(--text-primary, #333)}.control-row input[type=number]:focus{outline:none;border-color:var(--primary-color, #4a90d9);box-shadow:0 0 0 2px #4a90d933}.control-row input[type=range]{flex:1;height:8px;-webkit-appearance:none;appearance:none;background:linear-gradient(90deg,var(--primary-color, #4a90d9) 0%,var(--border-color, #ddd) 100%);border-radius:4px;cursor:pointer;border:none}.control-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:24px;background:var(--slider-thumb, #555);border-radius:4px;cursor:pointer;box-shadow:0 2px 4px #0003;border:1px solid rgba(255,255,255,.1);transition:background .2s ease,transform .2s ease;margin-top:0}.control-row input[type=range]::-webkit-slider-thumb:hover{background:var(--slider-thumb-hover, #333);transform:scale(1.05)}.control-row input[type=range]::-moz-range-thumb{width:16px;height:24px;background:var(--slider-thumb, #555);border:none;border-radius:4px;cursor:pointer;box-shadow:0 2px 4px #0003}.environment-panel.dark{--slider-thumb: #888;--slider-thumb-hover: #aaa;--border-color: #444}.control-row button{width:32px;height:32px;padding:0;border:1px solid var(--border-color, #ddd);border-radius:6px;background:var(--button-bg, #f5f5f5);color:var(--text-primary, #333);font-size:1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.control-row button:hover{background:var(--primary-color, #4a90d9);color:#fff;border-color:var(--primary-color, #4a90d9)}.control-row span{min-width:40px;font-size:.85rem;color:var(--text-secondary, #666);text-align:right}.control-actions{display:flex;gap:8px;margin-top:8px}.btn-toggle,.btn-reset{flex:1;padding:10px 12px;border:1px solid var(--border-color, #ddd);border-radius:8px;background:var(--button-bg, #f5f5f5);color:var(--text-primary, #333);font-size:.85rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px}.btn-toggle:hover,.btn-reset:hover{background:var(--hover-bg, #e8e8e8)}.btn-toggle.active{background:var(--primary-color, #4a90d9);color:#fff;border-color:var(--primary-color, #4a90d9)}.environment-panel.dark{--text-primary: #eee;--text-secondary: #aaa;--text-tertiary: #888;--border-color: #444;--input-bg: #2a2a2a;--button-bg: #333;--hover-bg: #444}.environment-panel.dark .file-dropzone,.environment-panel.dark .file-info{background:linear-gradient(135deg,#32323280,#1e1e1e80)}.joystick-section{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color, rgba(255, 255, 255, .1))}.joystick-hint{font-size:.75rem;color:var(--text-tertiary, #888);text-align:center}.App{display:flex;flex-direction:row!important;height:100vh;width:100vw;overflow:hidden}.controls-panel{width:500px;min-width:500px;background-color:var(--surface-color);border-right:1px solid var(--border-color);padding:0;display:flex;flex-direction:row;box-shadow:2px 0 10px #00000005;z-index:10;height:100vh;overflow:hidden}.controls-content{flex:1;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:0}.controls-header{padding:24px 24px 16px;flex-shrink:0}.controls-scroll-area{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 24px;display:flex;flex-direction:column;gap:20px}.controls-footer{padding:16px 24px 24px;border-top:1px solid var(--border-color);background-color:var(--surface-color);flex-shrink:0;display:flex;flex-direction:column;gap:20px}.controls-tabs{width:50px;min-width:50px;background-color:var(--surface-secondary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;padding-top:16px;gap:16px;flex-shrink:0;z-index:20}.tab-button{width:36px;height:36px;border-radius:6px;border:1px solid transparent;background:transparent;color:var(--text-muted);display:flex;justify-content:center;align-items:center;cursor:pointer;transition:all .2s}.tab-button:hover{background:var(--surface-hover);color:var(--primary-color)}.tab-button.active{background:var(--surface-highlight);color:var(--primary-color);border-color:var(--primary-color)}.controls-panel h2{font-size:1.2em;margin-bottom:16px;color:var(--text-color);border-bottom:2px solid var(--primary-color);padding-bottom:8px;display:inline-block}.control-group{display:flex;flex-direction:column;gap:8px;background:var(--surface-secondary);padding:12px;border-radius:6px;border:1px solid var(--border-color)}.control-group h3{font-size:.9em;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:8px}.stats-panel{margin-top:auto;background:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;padding:16px;box-shadow:0 2px 8px #0000000d}.stats-item{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.9em}.stats-item:last-child{margin-bottom:0}.stats-label{color:var(--text-secondary)}.stats-value{font-weight:600;color:var(--text-color)}.viewer-container{flex:1;position:relative;background-color:var(--background-color)}.flex-row{display:flex;gap:10px;align-items:center}.full-width{width:100%}.rate-limit-overlay{position:fixed;top:20px;right:20px;background-color:#f44;color:#fff;padding:16px 24px;border-radius:8px;box-shadow:0 4px 12px #0003;z-index:1000;display:flex;flex-direction:column;align-items:center;gap:8px;animation:slideIn .3s ease-out}.rate-limit-title{font-weight:700;font-size:1.1em}.rate-limit-timer{font-size:.9em;opacity:.9}@keyframes slideIn{0%{transform:translate(120%)}to{transform:translate(0)}}.rate-limit-warning{background-color:#fc0;color:#333}.sequence-editor{margin-bottom:12px}.sequence-editor-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.sequence-editor-label{font-size:.85em;color:var(--text-secondary)}.sequence-mode-toggle{background:transparent;border:none;padding:2px 6px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;gap:4px;font-size:.8em;margin-left:auto}.sequence-mode-toggle:hover{color:var(--primary-color)}.sequence-mode-toggle-label{font-size:.85em}.sequence-text-input{width:100%;box-sizing:border-box;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:.9em;background:var(--surface-secondary)}.sequence-cards{display:flex;flex-wrap:wrap;gap:4px;min-height:40px;padding:6px;background:var(--surface-secondary);border-radius:6px;border:1px dashed var(--border-color)}.block-card{position:relative;cursor:grab;touch-action:none}.block-card:active{cursor:grabbing}.block-card-content{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:4px;border:1px solid rgba(0,0,0,.12);cursor:pointer;transition:transform .15s,box-shadow .15s}.block-card-content:hover{transform:scale(1.08);box-shadow:0 2px 6px #00000026}.block-card-type{font-weight:600;font-size:.85em;display:flex;align-items:center;justify-content:center}.block-card-remove{position:absolute;top:-4px;right:-4px;width:14px;height:14px;border-radius:50%;background:#dc3545;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;z-index:1}.block-card:hover .block-card-remove{opacity:1}.sequence-add-btn{width:28px;height:28px;border-radius:4px;border:1px dashed var(--border-color);background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,color .15s}.sequence-add-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.sequence-editor-total{text-align:right;font-size:.9em;color:var(--text-secondary);margin-top:6px;font-weight:500}.precision-builder{display:flex;flex-direction:column;gap:12px}.precision-section{background:var(--surface-secondary);border-radius:8px;padding:12px;border:1px solid var(--border-color)}.precision-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.precision-section-title{font-weight:600;color:var(--text-primary)}.precision-section-row{display:flex;align-items:center;margin-bottom:12px;font-size:.9em}.precision-section-length{margin-left:auto;color:var(--text-secondary);font-weight:500}.precision-symmetry-controls{display:flex;font-size:.85em;color:var(--text-secondary);margin-bottom:8px}.precision-symmetry-controls label{display:flex;align-items:center;gap:4px;cursor:pointer}.precision-warning{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#fff3cd;color:#856404;border-radius:4px;font-size:.85em;margin-bottom:10px}.precision-mirror-preview{display:flex;align-items:center;gap:8px;font-size:.85em;color:var(--text-secondary);padding:8px;background:#00000008;border-radius:4px;margin-top:8px}.precision-mirror-label{flex-shrink:0}.precision-mirror-types{display:flex;gap:4px;flex-wrap:wrap}.precision-mirror-type{background:var(--surface-primary, #fff);padding:2px 8px;border-radius:4px;font-weight:500}.tile-container{position:fixed;bottom:20px;left:520px;z-index:1000;display:flex;flex-direction:row;gap:20px;align-items:stretch;pointer-events:none}@media(max-width:1200px){.tile-container{flex-direction:column-reverse;align-items:stretch}}.tile-card{pointer-events:auto;background:var(--surface-color);border-radius:8px;box-shadow:0 4px 12px #00000026;border:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden;transition:all .2s ease-out}.tile-container .tile-card{flex:0 0 auto;width:400px;max-width:90vw}.tile-matrix-item .tile-card{width:100%!important;height:100%!important;min-width:0!important;max-width:none!important;flex:1}.apartment-stats-layout{display:flex;flex-direction:row;align-items:center;gap:24px;padding-bottom:8px;justify-content:center}.apartment-chart-section{flex-shrink:0}.apartment-legend-section{display:flex;flex-direction:column;gap:6px;flex:1}.icon-btn{width:32px;height:32px;border-radius:4px;border:none;background:transparent;color:var(--text-color);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0;flex-shrink:0}.icon-btn svg{stroke-width:2.5px}.icon-btn:hover:not(:disabled){background:#0000000d;color:var(--primary-color)}.icon-btn:disabled{opacity:.3;cursor:not-allowed}.tile-matrix-item{width:100%;height:100%;min-height:200px}
