:root{--bg-primary:#151512;--bg-secondary:#1e1e1a;--bg-tertiary:#141412;--border-subtle:#2e2e28;--border-faint:#f5f0e80d;--text-primary:#f5f0e8;--text-secondary:#f5f0e899;--text-muted:#f5f0e866;--text-faintest:#f5f0e826;--accent-terracotta:#c4572e;--accent-terracotta-hover:#a84520;--accent-brass:#b8914a;--accent-brass-hover:#d4a85c;--grout-default:#d4cfc8;--error-red:#c0392b;--font-display:"Cormorant Garamond", Georgia, serif;--font-mono:"DM Mono", "Courier New", monospace;--font-body:"DM Mono", system-ui, -apple-system, sans-serif;--radius:2px;--transition-fast:.15s ease-out;--transition-medium:.25s ease-in-out;--transition-slow:.4s ease-in-out}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);min-height:100vh;overflow-x:hidden}#root{min-height:100vh}::selection{background:var(--accent-terracotta);color:#fff}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:.01em;font-weight:400}.font-display{font-family:var(--font-display)}.font-mono{font-family:var(--font-mono)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#b8914a66}.noise-overlay{pointer-events:none;opacity:.035;mix-blend-mode:multiply;z-index:10;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");position:absolute;inset:0}.app-container{flex-direction:column;min-height:100vh;display:flex}.main-layout{flex:1;height:calc(100vh - 56px);display:flex;overflow:hidden}.nav-bar{z-index:40;-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);background:#151512eb;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{align-items:center;gap:14px;display:flex}.nav-logo-diamond{background:var(--accent-terracotta);flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex;transform:rotate(45deg)}.nav-logo-diamond span{color:#fff;font-family:var(--font-display);font-size:16px;font-weight:600;transform:rotate(-45deg)}.nav-title{letter-spacing:.2em;text-transform:uppercase;color:var(--text-primary);font-size:13px;font-weight:300}.nav-actions{align-items:center;gap:10px;display:flex}.btn{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;border-radius:var(--radius);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;align-items:center;gap:8px;padding:8px 18px;font-size:11px;font-weight:500;display:inline-flex}.btn-primary{background:var(--accent-terracotta);color:#fff;border-color:var(--accent-terracotta)}.btn-primary:hover{background:var(--accent-terracotta-hover);border-color:var(--accent-terracotta-hover)}.btn-outline{color:var(--accent-brass);border-color:var(--accent-brass);background:0 0}.btn-outline:hover{background:var(--accent-brass);color:var(--bg-primary)}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000;padding:6px 10px}.btn-ghost:hover{color:var(--text-primary);background:#ffffff0d}.btn-ghost.active{color:var(--accent-terracotta)}.btn-icon{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;display:inline-flex}.btn-icon:hover{color:var(--text-primary);background:#ffffff0d}.btn-icon:disabled{opacity:.3;cursor:default}.panel-left{background:var(--bg-secondary);border-right:1px solid var(--border-subtle);flex-direction:column;width:280px;min-width:280px;display:flex;overflow-y:auto}.panel-right{background:var(--bg-secondary);border-left:1px solid var(--border-subtle);flex-direction:column;width:340px;min-width:340px;display:flex;overflow-y:auto}.panel-section{border-bottom:1px solid var(--border-subtle);padding:20px}.panel-section:last-child{border-bottom:none}.panel-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.15em;color:var(--accent-brass);align-items:center;gap:8px;margin-bottom:14px;font-size:10px;display:flex}.center-stage{background:var(--bg-tertiary);flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.toolbar{border-bottom:1px solid var(--border-subtle);background:#15151280;flex-shrink:0;justify-content:space-between;align-items:center;height:44px;padding:0 20px;display:flex}.toolbar-group{align-items:center;gap:6px;display:flex}.toolbar-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);margin-right:6px;font-size:9px}.toolbar-divider{background:var(--border-subtle);width:1px;height:16px;margin:0 10px}.grid-viewport{flex:1;justify-content:center;align-items:center;padding:40px;display:flex;position:relative;overflow:hidden}.tile-grid{transition:transform var(--transition-medium);display:grid;position:relative}.tile-cell{line-height:0;overflow:hidden}.tile-cell svg{width:100%;height:100%;display:block}.upload-zone-container{flex-direction:column;justify-content:center;align-items:center;min-height:calc(100vh - 56px);padding:40px;display:flex}.upload-zone{border:2px dashed var(--border-subtle);border-radius:var(--radius);text-align:center;cursor:pointer;width:100%;max-width:560px;transition:all var(--transition-medium);background:#1e1e1a66;padding:60px 40px;position:relative}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent-brass);background:#b8914a0a}.upload-zone-icon{width:56px;height:56px;color:var(--text-muted);transition:color var(--transition-fast);margin:0 auto 20px}.upload-zone:hover .upload-zone-icon{color:var(--accent-brass)}.upload-zone-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:8px;font-size:22px}.upload-zone-sub{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.05em;font-size:11px}.source-preview{border:1px solid var(--border-subtle);border-radius:var(--radius);width:100%;max-width:160px;overflow:hidden}.source-preview img{width:100%;display:block}.zone-row{border-radius:var(--radius);transition:background var(--transition-fast);margin:-4px -10px;padding:10px}.zone-row:hover{background:#ffffff08}.zone-row.highlighted{background:#ffffff0f;box-shadow:inset 0 0 0 1px #ffffff14}.zone-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.zone-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);align-items:center;gap:8px;font-size:10px;display:flex}.zone-color-dot{border:2px solid #ffffff26;border-radius:50%;flex-shrink:0;width:14px;height:14px}.zone-hex-input{font-family:var(--font-mono);border:1px solid var(--border-subtle);color:var(--text-primary);border-radius:var(--radius);text-align:center;width:80px;transition:border-color var(--transition-fast);background:#ffffff0a;padding:4px 8px;font-size:11px}.zone-hex-input:focus{border-color:var(--accent-brass);outline:none}.swatch-grid{grid-template-columns:repeat(6,1fr);gap:4px;display:grid}.swatch-btn{aspect-ratio:1;cursor:pointer;transition:all var(--transition-fast);border:2px solid #0000;border-radius:50%;outline:none}.swatch-btn:hover{transform:scale(1.15)}.swatch-btn.active{border-color:#fff;transform:scale(1.15);box-shadow:0 0 8px #ffffff4d}input[type=color]{appearance:none;cursor:pointer;background:0 0;border:none;width:20px;height:20px;padding:0}input[type=color]::-webkit-color-swatch-wrapper{padding:0}input[type=color]::-webkit-color-swatch{border:1px solid #ffffff26;border-radius:50%}.spec-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.spec-item{border:1px solid var(--border-subtle);border-radius:var(--radius);background:#ffffff05;padding:10px}.spec-item-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:4px;font-size:9px}.spec-item-value{color:var(--text-primary);font-size:13px}.calc-box{border-radius:var(--radius);background:#b8914a0a;border:1px solid #b8914a1f;padding:16px}.calc-input{font-family:var(--font-mono);background:var(--bg-primary);border:1px solid var(--border-subtle);color:var(--text-primary);border-radius:var(--radius);text-align:right;width:70px;transition:border-color var(--transition-fast);padding:6px 10px;font-size:13px}.calc-input:focus{border-color:var(--accent-brass);outline:none}.modal-overlay{z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000c;justify-content:center;align-items:center;padding:20px;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius);width:100%;max-width:480px;animation:.25s ease-out slideUp;overflow:hidden}.modal-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{font-family:var(--font-display);color:var(--text-primary);font-size:22px}.modal-body{max-height:70vh;padding:24px;overflow-y:auto}.modal-input{width:100%;font-family:var(--font-mono);border:1px solid var(--border-subtle);color:var(--text-primary);border-radius:var(--radius);transition:border-color var(--transition-fast);background:#ffffff0a;padding:12px 16px;font-size:12px}.modal-input:focus{border-color:var(--accent-terracotta);outline:none}.modal-input::placeholder{color:var(--text-muted)}textarea.modal-input{resize:vertical;min-height:100px}.toast{z-index:100;border-radius:var(--radius);font-family:var(--font-mono);align-items:center;gap:10px;padding:12px 20px;font-size:12px;animation:.3s ease-out slideInLeft;display:flex;position:fixed;bottom:24px;left:24px;box-shadow:0 8px 32px #00000080}.toast-success{background:var(--bg-secondary);border:1px solid var(--accent-brass);color:var(--text-primary)}.toast-error{border:1px solid var(--error-red);color:#f5d6d0;background:#c0392b26}.toast-info{background:var(--bg-secondary);border:1px solid var(--border-subtle);color:var(--text-primary)}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:24px;padding:60px 40px;display:flex}.loading-pulse{background:var(--accent-terracotta);width:60px;height:60px;animation:1.6s ease-in-out infinite pulse;transform:rotate(45deg)}@keyframes pulse{0%,to{opacity:.7;transform:rotate(45deg)scale(1)}50%{opacity:1;transform:rotate(45deg)scale(1.15)}}.loading-text{font-family:var(--font-display);color:var(--text-secondary);font-size:18px;font-style:italic}.actions-bar{background:var(--bg-primary);border-top:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;height:52px;padding:0 20px;display:flex}.room-bathroom{position:relative}.room-bathroom .tile-grid{transform-origin:bottom;transform:perspective(800px)rotateX(28deg)}.room-kitchen,.room-outdoor{position:relative}.room-outdoor .tile-grid{transform-origin:bottom;transform:perspective(1200px)rotateX(18deg)}.grid-controls-float{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-subtle);z-index:5;opacity:0;transition:opacity var(--transition-medium);background:#151512d9;border-radius:20px;align-items:center;gap:3px;padding:4px 6px;display:flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.grid-viewport:hover .grid-controls-float{opacity:1}.grid-control-btn{font-family:var(--font-mono);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:12px;padding:5px 10px;font-size:10px}.grid-control-btn:hover{color:var(--text-primary)}.grid-control-btn.active{background:var(--accent-terracotta);color:#fff}.nudge-banner{border-radius:var(--radius);color:var(--text-secondary);background:#c4572e14;border:1px solid #c4572e33;align-items:flex-start;gap:10px;padding:12px 16px;font-size:11px;line-height:1.5;display:flex}.nudge-banner a{color:var(--accent-terracotta);cursor:pointer;text-decoration:underline}.nudge-banner button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-size:14px}.upload-preview{flex-direction:column;align-items:center;gap:20px;width:100%;max-width:560px;display:flex}.upload-preview-img{border:1px solid var(--border-subtle);border-radius:var(--radius);object-fit:contain;max-width:300px;max-height:300px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes zoneFlash{0%{outline-offset:-2px;outline:2px solid #fff}to{outline-offset:-2px;outline:2px solid #0000}}@media (width<=1279px){.panel-left{display:none}.panel-right{width:300px;min-width:260px}}@media (width<=899px){.main-layout{flex-direction:column;height:auto;min-height:calc(100vh - 56px)}.panel-left{display:none}.panel-right{border-left:none;border-top:1px solid var(--border-subtle);width:100%;min-width:100%}.center-stage{min-height:50vh}.grid-viewport{padding:20px}.nav-title{display:none}.toolbar{overflow-x:auto}.actions-bar{flex-wrap:wrap;gap:8px;height:auto;padding:12px 16px}.grid-controls-float{opacity:1}}@media print{.nav-bar,.panel-left,.panel-right,.toolbar,.actions-bar,.grid-controls-float{display:none!important}.main-layout{height:auto!important;display:block!important}.center-stage{height:auto!important}}
