body{margin:0;min-height:100vh}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#e0e0e0;height:100vh;overflow:hidden}#root,body,html{height:100%}.app{display:flex;flex-direction:column;height:100vh}.app-header{background:#16213e;padding:12px 24px;border-bottom:1px solid #0f3460;display:flex;align-items:center;justify-content:space-between}.app-header h1{font-size:1.4rem;color:#e94560;font-weight:600}.app-body{flex:1 1}.app-body,.sidebar{display:flex;overflow:hidden}.sidebar{width:300px;min-width:300px;background:#16213e;border-right:1px solid #0f3460;flex-direction:column}.sidebar-tabs{flex-shrink:0;display:flex;background:#0f1428;border-bottom:1px solid #0f3460}.sidebar-tab{flex:1 1;padding:10px 0;border:none;border-bottom:2px solid transparent;background:transparent;color:#4a5a6e;font-size:.82rem;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s;font-family:inherit}.sidebar-tab:hover{color:#8a9ab0}.sidebar-tab.active{color:#e94560;border-bottom-color:#e94560}.sidebar-body{flex:1 1;min-height:0;overflow-y:auto;padding:12px 16px}.panel{margin-bottom:8px}.panel h3{font-size:.68rem;color:#e94560;text-transform:uppercase;letter-spacing:.8px;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:8px}.panel h3:after{content:"";flex:1 1;height:1px;background:rgba(233,69,96,.15)}.line-inputs{display:flex;flex-direction:column;gap:4px}.line-input-row{display:flex;align-items:center;gap:4px}.line-input{flex:1 1;padding:7px 10px;border:1px solid #0f3460;border-radius:6px;background:#0a0a1a;color:#e0e0e0;font-size:.9rem;font-family:inherit}.line-input:focus{outline:none;border-color:#e94560}.line-input::placeholder{color:#2a3a50}.line-remove{flex-shrink:0;width:26px;height:26px;padding:0;border:1px solid #1a2a3e;border-radius:6px;background:rgba(10,10,26,.4);color:#3a4a5e;font-size:1.1rem;line-height:1;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.line-remove:hover:not(:disabled){background:rgba(233,69,96,.18);border-color:rgba(233,69,96,.4);color:#e94560}.line-remove:disabled{opacity:.2;cursor:not-allowed}.line-add{margin-top:2px;padding:5px 10px;border:1px dashed #1a3050;border-radius:6px;background:transparent;color:#3a5070;font-size:.75rem;font-family:inherit;cursor:pointer;text-align:left;transition:all .15s}.line-add:hover{border-color:rgba(233,69,96,.35);color:#e94560;background:rgba(233,69,96,.05)}.text-editor textarea{width:100%;padding:10px;border:1px solid #0f3460;border-radius:6px;background:#0a0a1a;color:#e0e0e0;font-size:.95rem;resize:vertical;min-height:80px;font-family:inherit}.text-editor textarea:focus{outline:none;border-color:#e94560}.text-editor select{width:100%;padding:8px;border:1px solid #0f3460;border-radius:6px;background:#0a0a1a;color:#e0e0e0;font-size:.9rem;margin-bottom:8px}.file-upload{display:inline-block;padding:6px 12px;background:#0f3460;border-radius:6px;cursor:pointer;font-size:.8rem;transition:background .2s}.file-upload:hover{background:#1a4a7a}.file-upload input{display:none}.slider-row{display:flex;align-items:center;gap:10px}.slider-row input[type=range]{flex:1 1;accent-color:#e94560}.slider-row span{min-width:45px;text-align:right;font-size:.85rem;color:#aaa}.controls label{display:block;margin-bottom:6px}.layer-btn-group{display:flex;gap:6px;margin-bottom:8px}.layer-btn{flex:1 1;padding:6px 0;border:1px solid #0f3460;border-radius:6px;background:#0a0a1a;color:#aaa;font-size:.9rem;cursor:pointer;transition:all .15s}.layer-btn:hover{background:#0f3460;color:#e0e0e0}.layer-btn.active{background:#e94560;border-color:#e94560;color:white;font-weight:600}.color-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;font-size:.85rem;color:#ccc}.color-row input[type=color]{width:36px;height:24px;padding:1px 2px;border:1px solid #333;border-radius:4px;background:none;cursor:pointer}.export-section{flex-shrink:0;padding:12px 16px;border-top:1px solid #0f3460;background:#16213e}.stl-mode{margin-bottom:8px}.export-buttons{display:flex;gap:8px}.export-buttons button{flex:1 1;padding:10px 16px;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.export-buttons .btn-svg{background:#e94560;color:white}.export-buttons .btn-svg:hover:not(:disabled){background:#d63050}.export-buttons .btn-stl{background:#0f3460;color:white}.export-buttons .btn-stl:hover:not(:disabled){background:#1a4a7a}.export-buttons .btn-obj{background:#0d6860;color:white}.export-buttons .btn-obj:hover:not(:disabled){background:#0f8078}.export-buttons button:disabled{opacity:.4;cursor:not-allowed}.export-buttons button:active:not(:disabled){transform:scale(.97)}.preview-area{flex:1 1;display:flex;flex-direction:column;overflow:hidden}.tab-bar{display:flex;background:#16213e;border-bottom:1px solid #0f3460}.tab{padding:10px 24px;background:transparent;color:#aaa;font-size:.9rem;cursor:pointer;border:none;border-bottom:2px solid transparent;transition:all .2s}.tab:hover{color:#e0e0e0}.tab.active{color:#e94560;border-bottom-color:#e94560}.preview-content{flex:1 1;display:flex;padding:16px;overflow:auto;background:#0f0f23;min-height:0}.svg-preview{flex:1 1;min-width:0;min-height:0;position:relative}.svg-preview svg{display:block;width:100%;height:100%;background:#1a1a2e;border-radius:8px;border:1px solid #0f3460}.drag-hint{position:absolute;top:10px;left:50%;transform:translateX(-50%);background:rgba(10,10,26,.82);border:1px solid #0f3460;border-radius:20px;padding:5px 13px;font-size:.75rem;color:#6a7a8e;white-space:nowrap;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:hint-fade-in .4s ease}@keyframes hint-fade-in{0%{opacity:0;transform:translateX(-50%) translateY(-4px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.three-preview{flex:1 1;min-width:0;min-height:0;position:relative}.three-preview>div{position:absolute!important;inset:0!important}.preview-placeholder{color:#666;font-size:1.1rem;text-align:center}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:#e94560;font-size:1.1rem}.ctrl-section{padding:10px 0;border-bottom:1px solid rgba(15,52,96,.5)}.ctrl-section:first-child{padding-top:0}.ctrl-section:last-child{border-bottom:none;padding-bottom:0}.ctrl-label{display:block;font-size:.73rem;color:#7a8499;margin-bottom:3px;font-weight:500;letter-spacing:.2px}.slider-row .value-badge{min-width:56px;text-align:right;font-size:.78rem;font-family:SFMono-Regular,Consolas,Courier New,monospace;color:#c8d0dc;background:rgba(10,10,26,.6);border:1px solid #0f3460;border-radius:4px;padding:2px 6px;white-space:nowrap}.font-consent{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;background:rgba(10,10,26,.4);border:1px solid rgba(15,52,96,.7);border-radius:6px;margin-bottom:8px;cursor:pointer}.font-consent input[type=checkbox]{margin-top:2px;accent-color:#e94560;flex-shrink:0;width:13px;height:13px;cursor:pointer}.font-consent .consent-text{font-size:.73rem;color:#7a8499;line-height:1.45;-webkit-user-select:none;-moz-user-select:none;user-select:none}.font-consent:has(input:checked){border-color:rgba(233,69,96,.3);background:rgba(233,69,96,.05)}.font-consent:has(input:checked) .consent-text{color:#a0aabc}.preview-dims{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:7px;background:rgba(10,10,26,.78);border:1px solid #0f3460;border-radius:20px;padding:4px 8px 4px 12px;font-size:.78rem;font-family:SFMono-Regular,Consolas,Courier New,monospace;color:#c8d0dc;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:10;pointer-events:auto;white-space:nowrap}.preview-dims .dim-label{font-size:.68rem;color:#7a8499;font-weight:600;letter-spacing:.3px}.preview-dims .dim-sep{color:#3a4a5e}.preview-dims .dim-unit{font-size:.73rem;color:#7a8499}.preview-dims input[type=number]{width:58px;background:rgba(255,255,255,.06);border:1px solid rgba(15,52,96,.9);border-radius:4px;color:#c8d0dc;font-family:inherit;font-size:.78rem;padding:1px 4px;text-align:right;-moz-appearance:textfield}.preview-dims input[type=number]::-webkit-inner-spin-button,.preview-dims input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.preview-dims input[type=number]:focus{outline:none;border-color:rgba(233,69,96,.6);background:rgba(233,69,96,.05)}.unit-toggle{background:rgba(233,69,96,.18);border:1px solid rgba(233,69,96,.35);border-radius:10px;color:#e94560;font-size:.7rem;font-family:inherit;padding:1px 7px;cursor:pointer;transition:background .15s;line-height:1.6}.unit-toggle:hover{background:rgba(233,69,96,.32)}.toggle-label{display:inline-flex;align-items:center;cursor:pointer;font-size:0;text-transform:none;letter-spacing:0;font-weight:400}.toggle-label input[type=checkbox]{display:none}.toggle-track{position:relative;display:inline-block;width:28px;height:15px;background:#1a2a3e;border:1px solid #0f3460;border-radius:8px;transition:background .2s,border-color .2s;flex-shrink:0}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:9px;height:9px;border-radius:50%;background:#3a4a5e;transition:left .2s,background .2s}.toggle-label input:checked+.toggle-track{background:rgba(233,69,96,.2);border-color:rgba(233,69,96,.5)}.toggle-label input:checked+.toggle-track:after{left:15px;background:#e94560}.file-upload.disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.btn-signin{padding:6px 14px;border:1px solid #e94560;border-radius:6px;background:transparent;color:#e94560;font-size:.82rem;font-family:inherit;cursor:pointer;transition:background .15s,color .15s}.btn-signin:hover{background:#e94560;color:#fff}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:8px;padding:5px 10px;border:1px solid #0f3460;border-radius:20px;background:rgba(15,52,96,.3);color:#c0cad8;font-size:.8rem;font-family:inherit;cursor:pointer;transition:background .15s,border-color .15s}.user-menu-trigger:hover{background:rgba(15,52,96,.6);border-color:#1a4a7a}.user-email{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plan-badge{font-size:.65rem;font-weight:700;letter-spacing:.5px;padding:1px 6px;border-radius:10px;flex-shrink:0}.plan-badge.free{background:rgba(100,100,130,.25);color:#8090a8}.plan-badge.pro{background:rgba(233,69,96,.2);color:#e94560}.user-menu-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:140px;background:#16213e;border:1px solid #0f3460;border-radius:8px;padding:4px;box-shadow:0 8px 24px rgba(0,0,0,.5);z-index:100}.user-menu-signout{width:100%;padding:8px 12px;border:none;border-radius:6px;background:transparent;color:#8090a8;font-size:.82rem;font-family:inherit;text-align:left;cursor:pointer;transition:background .15s,color .15s}.user-menu-signout:hover{background:rgba(233,69,96,.1);color:#e94560}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-box{position:relative;background:#16213e;border:1px solid #0f3460;border-radius:12px;padding:28px 28px 24px;width:340px;max-width:calc(100vw - 32px);box-shadow:0 16px 48px rgba(0,0,0,.7)}.modal-close{position:absolute;top:10px;right:12px;width:28px;height:28px;border:none;background:transparent;color:#4a5a6e;font-size:1.3rem;line-height:1;cursor:pointer;transition:color .15s;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:#e94560}.modal-title{font-size:1.1rem;font-weight:600;color:#e0e0e0;margin-bottom:18px;text-align:center}.auth-modal-box{text-align:center;padding:36px 32px 32px}.auth-subtitle{font-size:.82rem;color:#4a5a6e;margin:-10px 0 24px;line-height:1.5}.auth-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px 16px;border:1px solid #0f3460;border-radius:8px;background:#0a0a1a;color:#c0cad8;font-size:.9rem;font-family:inherit;cursor:pointer;transition:background .15s,border-color .15s}.auth-google:hover:not(:disabled){background:rgba(15,52,96,.5);border-color:#1a4a7a}.auth-google:disabled{opacity:.6;cursor:not-allowed}.auth-error{font-size:.78rem;color:#e94560;margin:0 0 14px}.auth-error,.upgrade-box{text-align:center}.upgrade-icon{font-size:2.2rem;margin-bottom:10px}.upgrade-feature-name{font-size:.82rem;color:#7a8499;margin-bottom:14px}.upgrade-desc{font-size:.84rem;color:#8090a8;line-height:1.55;margin-bottom:18px}.upgrade-cta{width:100%;padding:11px;border:none;border-radius:6px;background:#e94560;color:#fff;font-size:.92rem;font-weight:700;font-family:inherit;cursor:pointer;transition:background .15s;margin-bottom:10px}.upgrade-cta:hover{background:#d63050}.upgrade-note{font-size:.73rem;color:#3a4a5e}.designs-list{list-style:none;display:flex;flex-direction:column;gap:5px;margin-top:10px}.designs-item{display:flex;align-items:center;gap:4px}.designs-load{flex:1 1;text-align:left;padding:7px 10px;border:1px solid #0f3460;border-radius:6px;background:#0a0a1a;color:#c0cad8;font-size:.85rem;font-family:inherit;cursor:pointer;transition:background .15s,border-color .15s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.designs-load:hover{background:rgba(15,52,96,.6);border-color:#1a4a7a}.design-save-btn{width:100%;padding:8px;border:1px dashed #1a3050;border-radius:6px;background:transparent;color:#3a5070;font-size:.8rem;font-family:inherit;cursor:pointer;text-align:center;transition:all .15s;margin-bottom:6px}.design-save-btn:hover{border-color:rgba(233,69,96,.35);color:#e94560;background:rgba(233,69,96,.05)}.design-save-row{display:flex;align-items:center;gap:4px;margin-bottom:6px}.design-confirm{flex-shrink:0;width:26px;height:26px;padding:0;border:1px solid #0f3460;border-radius:6px;background:rgba(10,10,26,.4);color:#5a8a5a;font-size:1rem;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.design-confirm:hover:not(:disabled){background:rgba(90,138,90,.2);border-color:rgba(90,138,90,.5);color:#8aba8a}.designs-empty{font-size:.8rem;color:#3a4a5e;margin-top:10px;text-align:center}.designs-pro-msg{font-size:.8rem;color:#4a5a6e;margin-top:6px;line-height:1.5}.tutorial-box{text-align:center;padding:32px 32px 24px;width:360px}.tutorial-step-label{font-size:.72rem;color:#3a4a5e;text-transform:uppercase;letter-spacing:.08em;margin:0 0 16px}.tutorial-icon{font-size:2.8rem;margin-bottom:14px;line-height:1}.tutorial-title{font-size:1.1rem;font-weight:600;color:#e0e0e0;margin:0 0 10px}.tutorial-desc{font-size:.85rem;color:#6a7a8e;line-height:1.6;margin:0 0 22px}.tutorial-dots{display:flex;justify-content:center;gap:6px;margin-bottom:22px}.tutorial-dot{width:7px;height:7px;border-radius:50%;background:#1a2a40;transition:background .2s}.tutorial-dot.active{background:#e94560}.tutorial-actions{display:flex;gap:8px;justify-content:center}.tutorial-back{padding:9px 20px;border:1px solid #0f3460;border-radius:6px;background:transparent;color:#6a7a8e;font-size:.88rem;font-family:inherit;cursor:pointer;transition:border-color .15s,color .15s}.tutorial-back:hover{border-color:#1a4a7a;color:#c0cad8}.tutorial-next{flex:1 1;padding:9px 20px;border:none;border-radius:6px;background:#e94560;color:#fff;font-size:.88rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}.tutorial-next:hover{background:#d63050}.tutorial-skip{display:block;margin:14px auto 0;background:none;border:none;color:#2a3a50;font-size:.75rem;font-family:inherit;cursor:pointer;transition:color .15s;padding:0}.tutorial-skip:hover{color:#4a5a6e}.export-quota{font-size:.73rem;color:#7a8499;text-align:center;margin-bottom:6px}.font-upload-pro{display:inline-block;padding:6px 12px;background:transparent;border:1px dashed #1a3050;border-radius:6px;color:#3a5070;font-size:.8rem;font-family:inherit;cursor:pointer;transition:all .15s}.font-upload-pro:hover{border-color:rgba(233,69,96,.35);color:#e94560;background:rgba(233,69,96,.05)}@media (max-width:768px){.app-body{flex-direction:column}.sidebar{width:100%;min-width:unset;max-height:55vh;border-right:none;border-bottom:1px solid #0f3460}.export-section,.sidebar-body{padding:10px 12px}}