*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background-color:#f5f5f5}.App{min-height:100vh}.floor-planner{display:flex;flex-direction:column;height:100vh}.toolbar{background-color:#fff;padding:20px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.toolbar h1{font-size:24px;color:#333}.button-group{display:flex;gap:10px;flex-wrap:wrap}.button-group button{padding:10px 20px;border:2px solid #ddd;background-color:#fff;color:#333;cursor:pointer;font-size:14px;font-weight:500;border-radius:6px;transition:all .2s}.button-group button:hover{background-color:#f0f0f0;border-color:#06c}.button-group button.active{background-color:#06c;color:#fff;border-color:#06c}.button-group button.export-btn{background-color:#28a745;color:#fff;border-color:#28a745}.button-group button.export-btn:hover{background-color:#218838;border-color:#1e7e34}.config{background-color:#f8f8f8;padding:10px 15px;border-radius:6px;font-size:14px;color:#666;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.config label{font-weight:500;color:#333}.config input[type=number]{padding:5px 10px;border:2px solid #ddd;border-radius:4px;font-size:14px;width:70px;background-color:#fff}.config input[type=number]:focus{outline:none;border-color:#06c}.config .separator{color:#ccc;margin:0 5px}.canvas-container{flex:1;display:flex;justify-content:center;align-items:center;padding:20px;overflow:auto;background-color:#fafafa}.floor-canvas{border:2px solid #ddd;background-color:#fff;cursor:crosshair;box-shadow:0 4px 6px #0000001a}.instructions{background-color:#fff;padding:15px 20px;text-align:center;border-top:1px solid #ddd;color:#666;font-size:14px}.instructions p{margin:0;font-weight:500}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-overlay-transparent{position:fixed;top:0;left:0;right:0;bottom:0;background-color:transparent;z-index:1000}.modal-content{background-color:#fff;padding:30px;border-radius:12px;box-shadow:0 10px 25px #0003;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.wall-config-compact{background-color:#fff;padding:12px;border-radius:8px;box-shadow:0 4px 12px #0000004d;width:180px;display:flex;flex-direction:column;gap:8px}.compact-input{display:flex;align-items:center;gap:8px}.compact-input .label{font-size:11px;color:#333;font-weight:500;white-space:nowrap;flex:0 0 auto}.compact-input input{flex:1;padding:6px 8px;border:2px solid #ddd;border-radius:4px;font-size:14px}.compact-input input:focus{outline:none;border-color:#06c}.modal-content h2{margin-bottom:20px;color:#333;font-size:24px}.modal-content h3{margin:20px 0 15px;color:#555;font-size:16px}.door-width-section{display:flex;align-items:center;gap:15px;margin-bottom:20px;padding:15px;background-color:#f8f8f8;border-radius:8px}.door-width-section label{font-weight:500;color:#333}.door-width-section input{padding:8px 12px;border:2px solid #ddd;border-radius:6px;font-size:16px;width:100px}.door-width-section input:focus{outline:none;border-color:#06c}.width-display{font-weight:600;color:#06c;font-size:18px}.door-direction-section{margin-bottom:25px}.direction-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.direction-btn{padding:20px;border:2px solid #ddd;background-color:#fff;cursor:pointer;border-radius:8px;transition:all .2s;text-align:center}.direction-btn:hover{border-color:#06c;background-color:#f0f7ff}.direction-btn.selected{border-color:#06c;background-color:#06c;color:#fff}.direction-icon{font-size:48px;margin-bottom:10px}.direction-name{font-weight:600;font-size:14px;margin-bottom:5px}.direction-desc{font-size:12px;opacity:.8}.direction-btn.selected .direction-desc{opacity:1}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:25px;padding-top:20px;border-top:1px solid #eee}.modal-actions button{padding:10px 25px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel{background-color:#f0f0f0;color:#333}.btn-cancel:hover{background-color:#e0e0e0}.btn-submit{background-color:#06c;color:#fff}.btn-submit:hover{background-color:#0052a3}.btn-submit:disabled{background-color:#ccc;cursor:not-allowed}@media (max-width: 768px){.toolbar{flex-direction:column;align-items:flex-start}.button-group{width:100%}.button-group button{flex:1}.direction-buttons{grid-template-columns:1fr}.canvas-container{padding:10px}.floor-canvas{max-width:100%;height:auto}}.room-name-modal{max-width:500px}.room-info{background-color:#f8f8f8;padding:15px;border-radius:8px;margin-bottom:20px}.room-info p{margin:0;color:#555;font-size:14px}.input-section{margin-bottom:25px}.input-section input[type=text]{width:100%;padding:12px;border:2px solid #ddd;border-radius:6px;font-size:16px;transition:border-color .2s}.input-section input[type=text]:focus{outline:none;border-color:#06c}.input-section input[type=text]::placeholder{color:#999}.compass{position:absolute;top:90px;right:20px;width:60px;height:60px;cursor:pointer;z-index:100;transition:transform .2s;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.compass:hover{transform:scale(1.1)}.compass-circle{width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,#fff 0%,#f5f5f5 100%);box-shadow:0 2px 8px #00000026,inset 0 1px #fffc;border:2px solid #ddd;position:relative;display:flex;align-items:center;justify-content:center}.compass-needle{position:relative;width:100%;height:100%;transition:transform .3s ease}.needle-north{position:absolute;top:8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:20px solid #ff4444;font-size:10px;font-weight:700;color:#000;display:flex;align-items:center;justify-content:center;padding-top:2px}.mode-toggle{padding:6px 12px;border:2px solid #0066cc;background-color:#fff;color:#06c;cursor:pointer;font-size:13px;font-weight:600;border-radius:6px;transition:all .2s}.mode-toggle:hover{background-color:#f0f7ff}.mode-toggle.active{background-color:#06c;color:#fff}.input-suffix{margin-left:5px;color:#666;font-weight:500}.help-text{display:block;font-size:12px;color:#999;font-weight:400;margin-top:4px}.offset-visual{margin:20px 0;padding:15px;background-color:#f8f8f8;border-radius:6px}.offset-indicator{position:relative;width:100%}.offset-bar{position:relative;height:40px;background:linear-gradient(to right,#ff6b6b,#ffd93d,#6bcf7f);border-radius:20px;display:flex;align-items:center;justify-content:space-between;padding:0 10px}.offset-min,.offset-max{font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.offset-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:4px;height:50px;background-color:#333;border-radius:2px;box-shadow:0 2px 4px #0000004d}.offset-value{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;padding:4px 8px;background-color:#333;color:#fff;font-size:12px;font-weight:700;border-radius:4px;white-space:nowrap}.offset-value:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid #333}.input-section{margin-bottom:20px}.input-section label{display:block;margin-bottom:8px;font-weight:500;color:#333;font-size:14px}.input-section input[type=number]{padding:8px 12px;border:2px solid #ddd;border-radius:6px;font-size:16px;margin-right:10px}.input-section input[type=number]:focus{outline:none;border-color:#06c}.save-design-modal{max-width:500px}.load-design-modal{max-width:700px}.error-text{color:#f44;font-size:12px;margin-top:5px}.no-designs-text{text-align:center;color:#999;padding:40px 20px;font-style:italic}.designs-list{max-height:400px;overflow-y:auto;margin:20px 0;border:1px solid #ddd;border-radius:8px}.design-item{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:1px solid #eee;cursor:pointer;transition:background-color .2s}.design-item:last-child{border-bottom:none}.design-item:hover{background-color:#f8f8f8}.design-item.selected{background-color:#e6f2ff;border-left:4px solid #0066cc}.design-info{flex:1}.design-name{font-weight:600;font-size:16px;color:#333;margin-bottom:5px}.design-meta{font-size:12px;color:#999;margin-bottom:5px}.design-stats{font-size:12px;color:#666}.btn-delete{width:32px;height:32px;border:none;background-color:#f44;color:#fff;border-radius:50%;font-size:24px;line-height:1;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;padding:0}.btn-delete:hover{background-color:#c00}
