.dashboard{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary);overflow:hidden}.dash-header{display:flex;align-items:center;justify-content:space-between;padding:20px 40px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.dash-brand{display:flex;align-items:center;gap:16px}.dash-logo{font-size:32px;font-weight:900;color:var(--gold);letter-spacing:.08em;line-height:1}.dash-brand-text{display:flex;flex-direction:column}.dash-brand-name{font-size:18px;font-weight:600;color:var(--text-primary);line-height:1.2}.dash-brand-sub{font-size:11px;color:var(--text-dim);letter-spacing:.03em}.dash-new-btn{font-size:14px;padding:10px 20px}.dash-content{flex:1;overflow-y:auto;padding:32px 40px}.dash-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:20px}.dash-error{display:flex;align-items:center;background:#e055551a;border:1px solid rgba(224,85,85,.3);border-radius:6px;padding:12px 16px;font-size:13px;color:var(--danger);margin-bottom:24px;gap:8px}.dash-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center;gap:16px}.dash-empty-icon{font-size:48px;opacity:.4}.dash-empty p{font-size:14px;color:var(--text-secondary);max-width:300px}.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.dash-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:all .15s}.dash-card:hover{border-color:var(--border-light);box-shadow:0 4px 16px #0000004d}.dash-card-new{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;cursor:pointer;border-style:dashed;border-color:var(--border-light);background:transparent;min-height:180px;gap:12px}.dash-card-new:hover{border-color:var(--gold-dim);background:#c9a84c0a}.dash-card-new-icon{font-size:32px;color:var(--text-dim);line-height:1}.dash-card-new:hover .dash-card-new-icon{color:var(--gold)}.dash-card-new-label{font-size:13px;font-weight:500;color:var(--text-secondary)}.dash-card-new:hover .dash-card-new-label{color:var(--gold)}.dash-card-project{display:flex;flex-direction:column;cursor:default}.dash-card-thumb{height:120px;background:#e8e8e3;overflow:hidden;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.dash-card-thumb img{width:100%;height:100%;object-fit:cover}.dash-card-thumb-placeholder{display:flex;align-items:center;justify-content:center;font-size:32px;opacity:.3;width:100%;height:100%}.dash-card-body{padding:12px 14px 8px;flex:1;cursor:pointer}.dash-card-name{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:3px}.dash-card-client{font-size:11px;color:var(--gold-dim);margin-bottom:2px}.dash-card-date{font-size:10px;color:var(--text-dim);font-family:var(--font-mono)}.dash-card-actions{display:flex;align-items:center;gap:6px;padding:8px 12px 10px;border-top:1px solid var(--border)}.header{height:var(--header-height);background:var(--bg-primary);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 12px;flex-shrink:0;z-index:100;gap:12px}.header-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.header-back{font-size:12px;color:var(--text-dim);padding:4px 8px;border-radius:4px;white-space:nowrap}.header-back:hover{color:var(--text-secondary);background:var(--bg-tertiary)}.header-logo{display:flex;flex-direction:column;line-height:1;flex-shrink:0}.header-logo-text{font-size:16px;font-weight:700;color:var(--gold);letter-spacing:.05em}.header-logo-sub{font-size:9px;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase}.header-divider{width:1px;height:28px;background:var(--border);flex-shrink:0}.header-project-name{font-size:14px;font-weight:600;color:var(--text-primary);background:transparent;padding:4px 6px;border-radius:4px;cursor:text;display:flex;align-items:center;gap:6px;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-project-name:hover{background:var(--bg-tertiary)}.header-dirty{color:var(--gold);font-size:10px}.header-project-name-input{background:var(--bg-tertiary);border:1px solid var(--gold);border-radius:4px;color:var(--text-primary);padding:4px 8px;font-size:14px;font-weight:600;font-family:var(--font-ui);min-width:200px}.header-client{font-size:12px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.header-export-wrap{position:relative}.header-export-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:199}.header-export-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;padding:4px;min-width:220px;z-index:200;box-shadow:0 8px 24px #00000080}.header-export-menu button{display:block;width:100%;text-align:left;padding:8px 12px;font-size:13px;color:var(--text-primary);border-radius:4px;cursor:pointer;background:none;border:none;font-family:var(--font-ui)}.header-export-menu button:hover{background:var(--bg-hover);color:var(--gold)}.dim-input-wrap{display:flex;flex-direction:column;gap:3px;margin-bottom:10px}.dim-input-label{font-size:11px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.dim-input-field{position:relative;display:flex;align-items:center}.dim-input{background:var(--bg-primary);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);padding:6px 8px;font-size:13px;font-family:var(--font-mono);width:100%;transition:border-color .15s}.dim-input-field.focused .dim-input{border-color:var(--gold);outline:none}.dim-input-field.invalid .dim-input{border-color:var(--danger)}.dim-input-preview{position:absolute;right:8px;font-size:10px;font-family:var(--font-mono);color:var(--gold-dim);pointer-events:none}.dim-input-error{position:absolute;right:8px;font-size:12px;color:var(--danger);pointer-events:none}.dim-input-hint{display:flex;align-items:center;gap:2px;padding:2px 2px 0;font-size:11px;font-family:var(--font-mono);min-height:16px}.dim-hint-ftIn{color:var(--gold);font-weight:600}.dim-hint-sep{color:var(--text-dim)}.dim-hint-in{color:var(--text-secondary)}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;z-index:10}.sidebar-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-tab{flex:1;padding:8px 0;font-size:12px;font-weight:500;color:var(--text-secondary);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .15s;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.05em}.sidebar-tab.active{color:var(--gold);border-bottom-color:var(--gold)}.sidebar-tab:hover:not(.active){color:var(--text-primary);background:var(--bg-tertiary)}.sidebar-content{flex:1;overflow-y:auto;overflow-x:hidden}.sidebar-empty-props{padding:16px 12px;text-align:center}.sidebar-empty-props p{font-size:11px;color:var(--text-dim);font-style:italic}.palette-section{margin-bottom:4px}.palette-section-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px 4px;cursor:pointer;-webkit-user-select:none;user-select:none}.palette-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gold)}.palette-section-arrow{font-size:10px;color:var(--text-dim);transition:transform .15s}.palette-section-arrow.open{transform:rotate(180deg)}.palette-items{padding:0 8px 8px;display:flex;flex-direction:column;gap:2px}.palette-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:5px;cursor:pointer;transition:all .15s;border:1px solid transparent;background:transparent;color:var(--text-primary);font-family:var(--font-ui);font-size:13px;text-align:left;width:100%}.palette-item:hover{background:var(--bg-hover);border-color:var(--border)}.palette-item.active{background:#c9a84c1f;border-color:var(--gold-dim);color:var(--gold)}.palette-item-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.8}.palette-item.active .palette-item-icon{opacity:1}.palette-item-label{font-size:12px;font-weight:500}.palette-item-sub{font-size:10px;color:var(--text-dim);margin-left:auto}.properties-panel{padding:0 0 12px}.properties-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);padding:8px 12px 6px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.properties-type-badge{font-size:9px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:3px;padding:2px 6px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.properties-body{padding:10px 12px}.prop-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.prop-label{font-size:11px;color:var(--text-secondary);flex:1}.prop-value{flex:1;text-align:right}.prop-value input,.prop-value select{background:var(--bg-primary);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);padding:4px 6px;font-size:12px;width:100%;font-family:var(--font-ui)}.prop-value input:focus,.prop-value select:focus{border-color:var(--gold);outline:none}.prop-value select option{background:var(--bg-secondary)}.properties-actions{padding:0 12px;display:flex;gap:6px;flex-wrap:wrap}.properties-actions .btn{font-size:11px;padding:4px 8px}.layer-row{display:flex;align-items:center;gap:8px;padding:6px 12px}.layer-row label{font-size:12px;color:var(--text-primary);flex:1}.layer-panel{padding:12px}.layer-section{margin-bottom:16px}.layer-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);margin-bottom:10px}.layer-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);margin-bottom:4px}.layer-toggle-label{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-primary)}.layer-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.layer-active-section{margin-top:16px}.layer-active-label{font-size:11px;color:var(--text-secondary);margin-bottom:8px}.layer-active-buttons{display:flex;gap:6px}.layer-active-btn{flex:1;padding:8px;border-radius:5px;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;font-family:var(--font-ui);transition:all .15s;text-align:center}.layer-active-btn:hover{background:var(--bg-hover)}.layer-active-btn.active{border-color:var(--gold);background:#c9a84c1f;color:var(--gold)}.context-menu{position:fixed;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:6px;padding:4px;min-width:180px;z-index:9000;box-shadow:0 8px 24px #0009;font-family:var(--font-ui)}.ctx-header{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gold);padding:4px 10px 6px;border-bottom:1px solid var(--border);margin-bottom:4px}.ctx-item{display:block;width:100%;text-align:left;padding:7px 12px;font-size:12px;color:var(--text-primary);background:none;border:none;border-radius:4px;cursor:pointer;font-family:var(--font-ui);transition:all .12s;white-space:nowrap}.ctx-item:hover{background:var(--bg-hover);color:var(--gold)}.ctx-danger{color:var(--danger)}.ctx-danger:hover{background:#e055551a;color:var(--danger)}.ctx-sep{height:1px;background:var(--border);margin:3px 4px}.dim-edit-overlay{position:absolute;z-index:500;background:var(--bg-secondary);border:1px solid var(--gold);border-radius:6px;padding:8px 10px;box-shadow:0 6px 20px #0009;min-width:170px;transform:translate(-50%,-120%);pointer-events:all}.dim-edit-axis{font-size:9px;font-weight:700;letter-spacing:.1em;color:var(--gold);text-transform:uppercase;margin-bottom:5px;font-family:var(--font-ui)}.dim-edit-input{width:100%;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:4px;color:var(--text-primary);padding:5px 8px;font-size:14px;font-family:var(--font-mono);font-weight:600;outline:none;transition:border-color .12s}.dim-edit-input:focus{border-color:var(--gold)}.dim-edit-input.invalid{border-color:var(--danger)}.dim-edit-hint{font-size:10px;font-family:var(--font-mono);color:var(--gold-dim);margin-top:4px;white-space:nowrap}.dim-edit-hint.invalid{color:var(--danger)}.canvas-container{flex:1;overflow:hidden;background:#e8e8e3;position:relative}.status-bar{height:var(--statusbar-height);background:var(--bg-primary);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 12px;flex-shrink:0;font-size:11px;font-family:var(--font-mono);color:var(--text-secondary);z-index:100;gap:8px}.status-left,.status-right{display:flex;align-items:center;gap:6px}.status-item{display:flex;align-items:center;gap:5px;white-space:nowrap}.status-label{font-size:9px;font-weight:700;letter-spacing:.08em;color:var(--text-dim);text-transform:uppercase}.status-cursor{min-width:120px}.status-selected{color:var(--gold);font-weight:600}.status-sep{width:1px;height:14px;background:var(--border)}.status-select{background:transparent;border:none;color:var(--text-primary);font-family:var(--font-mono);font-size:11px;cursor:pointer;padding:0 2px}.status-select option{background:var(--bg-secondary)}.status-toggle{padding:2px 7px;border-radius:3px;font-size:10px;font-family:var(--font-mono);font-weight:500;color:var(--text-dim);background:transparent;border:1px solid transparent;cursor:pointer;transition:all .12s;letter-spacing:.03em}.status-toggle:hover{color:var(--text-secondary);border-color:var(--border)}.status-toggle.active{color:var(--gold);border-color:var(--gold-dim);background:#c9a84c14}.titleblock-modal{width:680px;max-width:95vw}.titleblock-preview{background:#fff;border:1px solid #ccc;border-radius:4px;margin-bottom:20px;overflow:hidden}.tb-preview-bar{display:flex;height:80px;border-top:3px solid #0a0a0a}.tb-preview-logo{width:130px;background:#0a0a0a;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;flex-shrink:0}.tb-logo-main{font-size:20px;font-weight:800;color:#c9a84c;letter-spacing:.1em;font-family:DM Sans,sans-serif}.tb-logo-sub{font-size:8px;color:#8a7040;text-align:center;line-height:1.3;margin-top:2px;font-family:DM Sans,sans-serif}.tb-logo-url{font-size:7px;color:#665530;margin-top:4px;font-family:JetBrains Mono,monospace}.tb-preview-info{flex:1;padding:8px 12px;display:flex;flex-direction:column;justify-content:center;border-right:1px solid #ddd}.tb-proj-name{font-size:13px;font-weight:700;color:#111;font-family:DM Sans,sans-serif}.tb-proj-client,.tb-proj-loc{font-size:9px;color:#555;margin-top:2px;font-family:DM Sans,sans-serif}.tb-drawing-type{font-size:11px;font-weight:700;color:#333;margin-top:6px;font-family:DM Sans,sans-serif;letter-spacing:.05em}.tb-preview-meta{width:130px;flex-shrink:0;padding:6px 10px;display:flex;flex-direction:column;justify-content:space-around}.tb-meta-row{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid #eee;padding:2px 0}.tb-meta-row span{font-size:7px;color:#999;text-transform:uppercase;letter-spacing:.06em;font-family:DM Sans,sans-serif}.tb-meta-row strong{font-size:9px;color:#222;font-family:JetBrains Mono,monospace}.titleblock-fields{display:flex;flex-direction:column;gap:0}.titleblock-fields .field{margin-bottom:0}.titleblock-fields .field-row{margin-bottom:10px}.titleblock-fields input,.titleblock-fields select{background:var(--bg-primary);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);padding:6px 8px;font-size:13px;width:100%;transition:border-color .15s;font-family:var(--font-ui)}.titleblock-fields input:focus,.titleblock-fields select:focus{border-color:var(--gold);outline:none}.titleblock-fields select option{background:var(--bg-secondary)}.titleblock-fields label{font-size:11px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:4px}.designer-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0a0a0a;--bg-secondary: #1a1a1a;--bg-tertiary: #242424;--bg-hover: #2e2e2e;--gold: #C9A84C;--gold-light: #e0bf6e;--gold-dim: #8a6f30;--text-primary: #e8e8e8;--text-secondary: #a0a0a0;--text-dim: #666666;--border: #333333;--border-light: #444444;--canvas-bg: #f5f5f0;--danger: #e05555;--success: #5cb85c;--font-ui: "DM Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--sidebar-width: 260px;--header-height: 48px;--statusbar-height: 28px}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--font-ui);background:var(--bg-primary);color:var(--text-primary);font-size:13px;line-height:1.4;-webkit-font-smoothing:antialiased}button{font-family:var(--font-ui);cursor:pointer;border:none;outline:none;background:none;color:inherit}input,select,textarea{font-family:var(--font-ui);outline:none;border:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gold-dim)}.btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:4px;font-size:13px;font-weight:500;transition:all .15s ease;cursor:pointer;white-space:nowrap}.btn-primary{background:var(--gold);color:#000}.btn-primary:hover{background:var(--gold-light)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-light)}.btn-ghost{color:var(--text-secondary);padding:5px 8px}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-tertiary)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#f06666}.btn-icon{width:30px;height:30px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;color:var(--text-secondary);transition:all .15s ease}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon.active{background:var(--gold);color:#000}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.field label{font-size:11px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.field input,.field select,.field textarea{background:var(--bg-primary);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);padding:6px 8px;font-size:13px;width:100%;transition:border-color .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold)}.field select option{background:var(--bg-secondary)}.field-row{display:flex;gap:8px}.field-row .field{flex:1}.section-header{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);padding:8px 12px 4px;border-bottom:1px solid var(--border);margin-bottom:8px}.divider{height:1px;background:var(--border);margin:8px 0}.tooltip{position:relative}.tooltip:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#000;color:var(--text-primary);font-size:11px;padding:4px 8px;border-radius:3px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;z-index:9999;border:1px solid var(--border)}.tooltip:hover:after{opacity:1}.app-layout{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.app-main{display:flex;flex:1;overflow:hidden;position:relative}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:24px;min-width:400px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #000c}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-size:16px;font-weight:600;color:var(--gold)}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.toggle{position:relative;width:36px;height:20px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:20px;transition:.2s}.toggle-slider:before{content:"";position:absolute;height:14px;width:14px;left:2px;top:2px;background:var(--text-dim);border-radius:50%;transition:.2s}.toggle input:checked+.toggle-slider{background:var(--gold-dim);border-color:var(--gold)}.toggle input:checked+.toggle-slider:before{transform:translate(16px);background:var(--gold)}.chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.chip-existing{background:#64647840;color:#999;border:1px solid #555}.chip-proposed{background:#c9a84c26;color:var(--gold);border:1px solid var(--gold-dim)}
