.cad-viewer{width:100%;height:100%;position:relative;background:#111}.placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#666}.placeholder-content{text-align:center}.placeholder-content h2{margin:0 0 1rem;font-size:2rem;color:#444}.placeholder-content p{margin:0;font-size:1rem;color:#666}.viewer-controls{position:absolute;bottom:1rem;left:1rem;right:1rem;display:flex;justify-content:space-between;align-items:end;pointer-events:none}.control-info{background:rgba(0,0,0,.7);padding:.5rem;border-radius:4px;font-size:.8rem;color:#ccc}.building-info{background:rgba(0,0,0,.7);padding:.5rem;border-radius:4px;font-size:.8rem;color:#ccc;text-align:right}.building-info div{margin-bottom:.25rem}.building-info div:last-child{margin-bottom:0}.prompt-interface{padding:1rem;height:100%;display:flex;flex-direction:column;gap:1.5rem}.prompt-form{background:#333;padding:1rem;border-radius:8px;border:1px solid #555}.input-group{display:flex;flex-direction:column;gap:.5rem}.prompt-input{width:100%;padding:.75rem;background:#444;border:1px solid #666;border-radius:4px;color:#fff;font-family:inherit;resize:vertical;min-height:60px}.prompt-input:focus{outline:none;border-color:#00d4ff}.prompt-input::placeholder{color:#999}.generate-btn{padding:.75rem 1rem;background:#00d4ff;color:#000;border:none;border-radius:4px;cursor:pointer;font-weight:700;transition:background .2s}.generate-btn:hover:not(:disabled){background:#00b8e6}.generate-btn:disabled{background:#666;color:#999;cursor:not-allowed}.examples{background:#333;padding:1rem;border-radius:8px;border:1px solid #555}.examples h3{margin:0 0 .75rem;font-size:.9rem;color:#ccc}.example-btn{display:block;width:100%;padding:.5rem;margin-bottom:.5rem;background:#444;color:#fff;border:1px solid #666;border-radius:4px;cursor:pointer;text-align:left;font-size:.8rem;transition:background .2s}.example-btn:hover:not(:disabled){background:#555}.example-btn:disabled{opacity:.5;cursor:not-allowed}.history{flex:1;background:#333;padding:1rem;border-radius:8px;border:1px solid #555;overflow-y:auto}.history h3{margin:0 0 .75rem;font-size:.9rem;color:#ccc}.history-item{padding:.75rem;margin-bottom:.5rem;background:#444;border-radius:4px;border-left:3px solid #666}.history-item.processing{border-left-color:orange}.history-item.completed{border-left-color:#4ade80}.history-item.error{border-left-color:#ef4444}.history-prompt{font-size:.8rem;margin-bottom:.25rem}.history-status{font-size:.7rem;color:#ccc;margin-bottom:.25rem}.history-time{font-size:.7rem;color:#999}.app{width:100vw;height:100vh;display:flex;flex-direction:column;background:#1a1a1a;color:#fff}.app-header{padding:1rem 2rem;background:#2a2a2a;border-bottom:1px solid #444}.app-header h1{margin:0;font-size:1.5rem;color:#00d4ff}.app-header p{margin:.5rem 0 0;color:#ccc;font-size:.9rem}.app-main{display:flex;flex:1;overflow:hidden}.left-panel{width:400px;background:#2a2a2a;border-right:1px solid #444;display:flex;flex-direction:column}.right-panel{flex:1;background:#111;position:relative}
