.garment-detail-mode-indicator{position:absolute;top:60px;left:50%;transform:translate(-50%);color:#0e3147;padding:12px 20px;border-radius:8px;box-shadow:0 2px 8px #0003;z-index:1000;display:flex;flex-direction:column;align-items:center;gap:10px;background:#fff9f79d;-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px)}.garment-detail-mode-text{font-weight:600;font-size:14px}.detail-type-buttons{display:flex;gap:8px;flex-wrap:wrap;max-width:600px;justify-content:center}.detail-type-btn{padding:6px 12px;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:4px;color:#0e3147;cursor:pointer;font-size:12px;transition:all .2s}.detail-type-btn:hover{background:#ffffff4d}.detail-type-btn.active{background:#fff;color:#0e3147}.detail-cursor{cursor:crosshair!important}.garment-detail-mode-button{padding:8px 16px;background:#fff;color:#0e3147;border:none;font-size:12px;border-radius:4px;cursor:pointer;font-weight:500}.garment-detail-form{width:360px;max-width:90vw;max-height:50vh;background-color:var(--form-bg, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:8px;box-shadow:0 6px 20px #0000001f;z-index:1000;transition:opacity .15s ease-out;opacity:0;display:flex;flex-direction:column;overflow:hidden}.garment-detail-form[style*="opacity: 1"]{opacity:1!important}.garment-detail-form .form-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:var(--header-bg, #f8f8f8);border-bottom:1px solid var(--border-color, #e0e0e0);flex-shrink:0}.garment-detail-form .form-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary, #222222)}.garment-detail-form .close-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background:transparent;border-radius:4px;color:var(--text-secondary, #555555);cursor:pointer;transition:background .2s ease,color .2s ease}.garment-detail-form .close-button:hover{background-color:var(--hover-bg, #e9e9e9);color:var(--text-primary, #222222)}.garment-detail-form .form-content{padding:16px;overflow-y:auto;flex-grow:1}.garment-detail-form .form-row{margin-bottom:14px}.garment-detail-form .form-row label{display:block;margin-bottom:5px;font-size:12px;font-weight:500;color:var(--label-color, #444444);text-transform:uppercase;letter-spacing:.5px}.garment-detail-form .form-row input[type=text],.garment-detail-form .form-row input[type=number],.garment-detail-form .form-row select{width:100%;padding:9px 10px;border:1px solid var(--input-border, #d0d0d0);border-radius:4px;font-size:13px;color:var(--text-primary, #333333);background:var(--input-bg, #ffffff);transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.garment-detail-form .form-row input:focus,.garment-detail-form .form-row select:focus{outline:none;border-color:var(--primary-color, #f77f00);box-shadow:0 0 0 2px #f77f001a}.garment-detail-form .form-row input::placeholder{color:var(--placeholder-color, #a0a0a0)}.garment-detail-form input[type=number]{-moz-appearance:textfield}.garment-detail-form input[type=number]::-webkit-outer-spin-button,.garment-detail-form input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.garment-detail-form select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23666666' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px;cursor:pointer}.garment-detail-form .form-row-group{display:grid;grid-template-columns:1fr 1fr;gap:10px}.garment-detail-form .image-upload-section{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color, #e0e0e0)}.garment-detail-form .image-upload-section label{display:block;margin-bottom:10px;font-size:13px;font-weight:600;color:var(--text-primary, #333333)}.garment-detail-form .upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;border:2px dashed var(--upload-border, #d0d0d0);border-radius:6px;background:var(--upload-bg, #f9f9f9);cursor:pointer;transition:border-color .2s ease,background .2s ease,transform .1s ease}.garment-detail-form .upload-area:hover{border-color:var(--primary-color, #f77f00);background:var(--primary-light, #fff5e6)}.garment-detail-form .upload-area:active{transform:scale(.98)}.garment-detail-form .upload-area svg{margin-bottom:8px;color:var(--icon-color, #666666)}.garment-detail-form .upload-area span{font-size:13px;color:var(--text-secondary, #666666)}.garment-detail-form .uploaded-images-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px;margin-top:14px}.garment-detail-form .image-preview-item{background:var(--preview-bg, #f5f5f5);border:1px solid var(--border-color, #e0e0e0);border-radius:4px;overflow:hidden;transition:box-shadow .2s ease}.garment-detail-form .image-preview-item:hover{box-shadow:0 2px 8px #0000001a}.garment-detail-form .image-preview-item img{display:block;width:100%;height:60px;object-fit:cover}.garment-detail-form .image-preview-item span{display:block;padding:3px 6px;font-size:10px;color:var(--text-secondary, #666666);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.garment-detail-form .form-actions{display:flex;gap:10px;padding:12px 16px;background:var(--footer-bg, #f9f9f9);border-top:1px solid var(--border-color, #e0e0e0);flex-shrink:0}.garment-detail-form .form-actions button{flex:1;padding:9px 18px;border:none;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s ease,color .2s ease,transform .1s ease}.garment-detail-form .form-actions button:active{transform:scale(.98)}.garment-detail-form .cancel-button{background:var(--button-secondary-bg, #e9ecef);color:var(--button-secondary-text, #495057);border:1px solid var(--button-secondary-border, #ced4da)}.garment-detail-form .cancel-button:hover{background:var(--button-secondary-hover-bg, #d8e0e7)}.garment-detail-form .save-button{background:var(--primary-action, #0e3147);color:var(--primary-action-text, #fff)}.garment-detail-form .save-button:hover{background:#1a4361}.garment-detail-form.above:before,.garment-detail-form.above:after,.garment-detail-form.below:before,.garment-detail-form.below:after{content:"";position:absolute;left:50%;transform:translate(-50%);width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent}.garment-detail-form.above:before{bottom:-11px;border-top:11px solid var(--border-color, #e0e0e0);z-index:999}.garment-detail-form.above:after{bottom:-10px;border-top:10px solid var(--form-bg, #ffffff);z-index:1000}.garment-detail-form.below:before{top:-11px;border-bottom:11px solid var(--border-color, #e0e0e0);z-index:999}.garment-detail-form.below:after{top:-10px;border-bottom:10px solid var(--header-bg, #f8f8f8);z-index:1000}.fabric-library{display:flex;flex-direction:column;height:100%;padding:0;font-family:Inter,sans-serif}.fabric-library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:0 4px}.fabric-header-title{font-size:16px;font-weight:600;color:#0e3147}.fabric-add-button{width:32px;height:32px;background-color:#fefdfe;border:1px solid #e0e0e0;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#0e3147;transition:all .2s ease;z-index:5;position:relative}.fabric-add-button:hover{background-color:#f3f3f3}.fabric-edit-btn{width:24px;height:24px;background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#0e3147;transition:all .2s ease;margin-left:8px;flex-shrink:0}.fabric-edit-btn:hover{background-color:#e9ecef;border-color:#0e3147;color:#0e3147}.fabric-edit-form{padding:12px;margin:8px 0 16px;border-radius:6px;background:#f8f9fa;border:1px solid #e0e0e0;box-shadow:0 1px 3px #0000000d}.fabric-edit-form .form-group{margin-bottom:10px}.fabric-edit-form .form-group label{display:block;margin-bottom:3px;font-size:11px;font-weight:500;color:#0e3147}.fabric-edit-form .form-group input:not([type=color]){width:100%;padding:6px 8px;font-size:11px;border-radius:4px;border:1px solid #ddd;background:#fefdfe;box-sizing:border-box;font-family:Inter,sans-serif}.fabric-edit-form .form-group input:focus{outline:none;border-color:#0e3147;box-shadow:0 0 0 2px #0e31471a}.fabric-edit-form .form-actions{display:flex;gap:8px;margin-top:12px}.fabric-edit-form .cancel-btn,.fabric-edit-form .submit-btn{padding:6px 12px;font-size:11px;border-radius:4px;border:1px solid #ddd;cursor:pointer;transition:all .2s ease;font-family:Inter,sans-serif}.fabric-edit-form .cancel-btn{background-color:#f8f9fa;color:#666}.fabric-edit-form .cancel-btn:hover{background-color:#e9ecef;border-color:#999}.fabric-edit-form .submit-btn{background-color:#0e3147;color:#fff;border-color:#0e3147}.fabric-edit-form .submit-btn:hover{background-color:#0a2333;border-color:#0a2333}.fabric-search input{width:100%;padding:12px;border:1px solid #E5E7EB;border-radius:12px;font-size:15px;background:#fafbfc;transition:all .2s cubic-bezier(.4,0,.2,1)}.fabric-search input::placeholder{color:#9ca3af;font-weight:400}.fabric-search input:focus{outline:none;border-color:var(--accent-orange);background:#fff;box-shadow:0 0 0 3px #e85d3c1a}.fabric-selection-status{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;margin-bottom:16px;border-radius:4px;background-color:#0e31470d;font-size:12px}.selection-label{color:#0e3147;font-size:12px}.clear-selection-btn{background:none;border:none;cursor:pointer;color:#0e3147;padding:2px 6px;font-size:12px;border-radius:3px}.clear-selection-btn:hover{background-color:#0e31471a}.fabric-grid{flex-direction:column;gap:8px;overflow-y:auto;padding-right:4px}.fabric-card{display:flex;align-items:center;padding:8px 10px;border-radius:6px;background-color:#fff;cursor:pointer;transition:all .2s ease;border:1px solid #f0f0f0}.fabric-card:hover{background-color:#f8f8f8;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.fabric-card.selected{border:2px solid #0e3147;background-color:#0e31470d}.fabric-info{display:flex;flex-direction:column;flex-grow:1}.fabric-name{font-weight:500;color:#242424;font-size:13px;margin-bottom:2px}.fabric-composition,.fabric-weight{color:#666;font-size:11px;line-height:1.4}.selection-indicator{color:#0e3147;display:flex;align-items:center;justify-content:center}.fabric-form{padding:12px;margin-bottom:16px;border-radius:8px;background:#f9f9f9;border:1px solid #e0e0e0}.form-group{margin-bottom:12px}.form-group label{display:block;margin-bottom:4px;font-size:12px;font-weight:500;color:#0e3147}.form-group input:not([type=color]){width:100%;padding:8px;font-size:12px;border-radius:4px;border:1px solid #ddd;background:#fefdfe;box-sizing:border-box;font-family:Inter,sans-serif}.form-group input:focus{border-color:#0e3147;outline:none;box-shadow:0 0 0 2px #0e31471a}.color-picker{width:50px;height:36px;border-radius:4px;border:1px solid #ddd;cursor:pointer}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}.cancel-btn{padding:6px 12px;background:#f0f0f0;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:12px;font-family:Inter,sans-serif;transition:background-color .2s ease}.cancel-btn:hover{background:#e5e5e5}.submit-btn{padding:6px 12px;background:#0e3147;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-family:Inter,sans-serif;transition:background-color .2s ease}.submit-btn:hover{background:#0a2535}.fabric-grid::-webkit-scrollbar{width:4px}.fabric-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.fabric-grid::-webkit-scrollbar-thumb{background:#c1c9d1;border-radius:4px}.fabric-grid::-webkit-scrollbar-thumb:hover{background:#a8b1bb}.fabric-texture-preview{position:relative;width:60px;height:60px;border-radius:4px;overflow:hidden;border:1px solid #ddd}.fabric-swatch-preview{width:28px;height:28px;border-radius:4px;margin-right:10px;border:1px solid rgba(0,0,0,.15);flex-shrink:0;background-size:cover;background-position:center center;background-color:#eee;overflow:hidden}.fabric-texture-preview img{width:100%;height:100%;object-fit:cover}.fabric-texture-preview .remove-btn{position:absolute;top:2px;right:2px;background:#fffc;border:none;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:10px}.upload-texture-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f0f0f0;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:12px}.fabric-delete-btn{width:24px;height:24px;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#d32f2f;margin-left:4px;transition:background .2s,border .2s}.fabric-delete-btn:hover{background-color:#ffeaea;border-color:#d32f2f}.fabric-delete-dialog{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000002e;z-index:1000;display:flex;align-items:center;justify-content:center}.fabric-delete-dialog-content{background:#fff;border-radius:8px;padding:24px 28px;box-shadow:0 4px 24px #00000021;min-width:320px;max-width:90vw;border:1px solid #e0e0e0}.fabric-delete-dialog-title{font-size:17px;font-weight:600;color:#d32f2f;margin-bottom:10px}.fabric-delete-dialog-message{font-size:14px;color:#333;margin-bottom:18px}.fabric-delete-dialog-error{color:#d32f2f;font-size:13px;margin-bottom:10px}.fabric-delete-dialog-actions{display:flex;gap:12px;justify-content:flex-end}.fabric-delete-dialog .delete-btn{background:#d32f2f;color:#fff;border:none;border-radius:4px;padding:7px 16px;font-size:13px;cursor:pointer;transition:background .2s}.fabric-delete-dialog .delete-btn:hover{background:#a31515}.fabric-delete-dialog .cancel-btn{background:#f8f9fa;color:#333;border:1px solid #e0e0e0;border-radius:4px;padding:7px 16px;font-size:13px;cursor:pointer;transition:background .2s}.fabric-delete-dialog .cancel-btn:hover{background:#e9ecef}.garment-detail-panel{display:flex;flex-direction:column;height:100%;background-color:var(--panel-bg, #ffffff);color:var(--text-primary, #333333)}.garment-detail-panel .panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border-color, #e0e0e0);background-color:var(--header-bg, #f5f5f5)}.garment-detail-panel .panel-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-primary, #333333)}.garment-detail-panel .visibility-toggle{display:flex;align-items:center;justify-content:center;height:32px;border:none;background-color:transparent;border-radius:4px;cursor:pointer;color:var(--text-secondary, #666666);transition:all .2s ease}.garment-detail-panel .visibility-toggle:hover{background-color:var(--hover-bg, #e0e0e0);color:var(--text-primary, #333333)}.garment-detail-panel .detail-type-selector{padding:12px;border-bottom:1px solid var(--border-color, #e0e0e0)}.garment-detail-panel .add-detail-dropdown{position:relative;width:100%}.garment-detail-panel .add-detail-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;border:2px dashed var(--border-color, #e0e0e0);background-color:var(--button-bg, #f9f9f9);border-radius:6px;font-size:14px;font-weight:500;color:var(--text-primary, #333333);cursor:pointer;transition:all .2s ease}.garment-detail-panel .add-detail-button:hover{border-color:var(--primary-color, #2196F3);background-color:var(--primary-light, #e3f2fd);color:var(--primary-color, #2196F3)}.garment-detail-panel .detail-type-menu{position:absolute;top:100%;left:0;right:0;margin-top:4px;background-color:var(--panel-bg, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:6px;box-shadow:0 4px 12px #0000001a;max-height:400px;overflow-y:auto;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease;z-index:1000;display:flex;flex-direction:column;padding:8px;gap:4px}.garment-detail-panel .add-detail-dropdown:hover .detail-type-menu,.garment-detail-panel .add-detail-dropdown:focus-within .detail-type-menu{opacity:1;visibility:visible;transform:translateY(0)}.garment-detail-panel .detail-type-option{width:100%;padding:16px 12px;border:none;background-color:transparent;text-align:left;font-size:14px;color:var(--text-primary, #333333);cursor:pointer;transition:background-color .2s ease;border-radius:8px;box-sizing:border-box}.garment-detail-panel .detail-type-option:hover{background-color:var(--hover-bg, #f5f5f5)}.garment-detail-panel .detail-type-option:active{background-color:var(--active-bg, #e0e0e0)}.garment-detail-panel .details-list{flex:1;overflow-y:auto;padding:8px}.garment-detail-panel .detail-type-group{margin-bottom:8px;background-color:var(--group-bg, #f9f9f9);border:1px solid var(--border-color, #e0e0e0);border-radius:6px;overflow:hidden}.garment-detail-panel .type-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:var(--header-bg, #f5f5f5);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.garment-detail-panel .type-header:hover{background-color:var(--hover-bg, #e8e8e8)}.garment-detail-panel .type-header span:first-child{font-weight:600;color:var(--text-primary, #333333)}.garment-detail-panel .expand-icon{font-size:16px;color:var(--text-secondary, #666666);transition:transform .2s ease}.garment-detail-panel .type-details{padding:8px;background-color:var(--panel-bg, #ffffff)}.garment-detail-panel .detail-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;margin-bottom:4px;background-color:var(--item-bg, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:4px;cursor:pointer;transition:all .2s ease}.garment-detail-panel .detail-item:hover{border-color:var(--primary-light, #90caf9);box-shadow:0 2px 4px #0000000d}.garment-detail-panel .detail-item.selected{border-color:var(--primary-color, #2196F3);background-color:var(--primary-light, #e3f2fd);box-shadow:0 2px 6px #2196f31a}.garment-detail-panel .detail-info{display:flex;align-items:center;gap:8px;flex:1}.garment-detail-panel .detail-name{font-size:14px;color:var(--text-primary, #333333)}.garment-detail-panel .detail-quantity{padding:2px 6px;background-color:var(--quantity-bg, #e0e0e0);border-radius:12px;font-size:12px;font-weight:500;color:var(--text-secondary, #666666)}.garment-detail-panel .has-images-icon{color:var(--secondary-color, #4caf50)}.garment-detail-panel .detail-actions{display:flex;gap:4px}.garment-detail-panel .detail-actions button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background-color:transparent;border-radius:4px;color:var(--text-secondary, #666666);cursor:pointer;transition:all .2s ease}.garment-detail-panel .detail-actions button:hover{background-color:var(--hover-bg, #e0e0e0);color:var(--text-primary, #333333)}.garment-detail-panel .detail-actions button:active{transform:scale(.95)}.garment-detail-panel .detail-actions button[title=Delete]:hover{background-color:var(--error-light, #ffebee);color:var(--error-color, #f44336)}.garment-detail-panel .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;text-align:center;padding:20px}.garment-detail-panel .empty-state p{margin:8px 0;color:var(--text-secondary, #666666);font-size:14px}.garment-detail-panel .empty-state p:first-child{font-size:16px;font-weight:500;color:var(--text-primary, #333333)}.garment-detail-panel .details-list::-webkit-scrollbar{width:6px}.garment-detail-panel .details-list::-webkit-scrollbar-track{background:var(--scrollbar-track, #f1f1f1)}.garment-detail-panel .details-list::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb, #c1c1c1);border-radius:3px}.garment-detail-panel .details-list::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover, #a1a1a1)}@media (max-width: 768px){.garment-detail-panel .panel-header{padding:12px}.garment-detail-panel .panel-header h3{font-size:16px}.garment-detail-panel .detail-type-selector{padding:8px}.garment-detail-panel .detail-item{padding:8px 10px}.garment-detail-panel .detail-name{font-size:13px}.garment-detail-panel .detail-actions button{width:24px;height:24px}}:root{--side-panel-background: rgba(255, 249, 247, .95);--side-panel-border-color: rgba(255, 225, 220, .5);--tabs-background: rgba(255, 255, 255, .7);--tab-text-color: #0F3047;--tab-text-color-hover: #0F3047;--tab-text-color-active: #E85D3C;--tab-indicator-color: #E85D3C;--tab-hover-background: rgba(255, 241, 237, .6);--content-padding: 24px;--side-panel-width: 380px;--side-panel-collapsed-width: 48px;--transition-speed: .3s;--grid-indicator-height: 60px;--accent-orange: #E85D3C;--accent-pink: #FFE1DC;--navy-dark: #0F3047;--navy-medium: #1a4361}#side-panel-container{position:absolute;top:60px;right:0;bottom:var(--grid-indicator-height);max-height:calc(100vh - 60px - var(--grid-indicator-height));width:var(--side-panel-width);background:#fffffffa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:-1px 0 3px #0000000a,-4px 0 16px #00000008;display:flex;flex-direction:column;z-index:10;overflow:hidden;color:var(--navy-dark);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;transition:width var(--transition-speed) cubic-bezier(.4,0,.2,1);border-left:1px solid rgba(15,48,71,.06)}#side-panel-container.collapsed{width:var(--side-panel-collapsed-width)}.side-panel-header{height:52px;display:flex;align-items:center;justify-content:flex-end;padding:0 16px;border-bottom:1px solid var(--side-panel-border-color);background:linear-gradient(to bottom,#ffffff80,#ffffff4d)}.collapse-toggle-btn{width:30px;height:30px;border-radius:12px;background:var(--navy-medium);border:none;display:flex;margin-top:10px;margin-bottom:10px;align-items:center;justify-content:center;cursor:pointer;padding:0;color:#fff;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0f304733}.collapse-toggle-btn:hover{background:var(--navy-medium);transform:translateY(-1px);box-shadow:0 4px 12px #0f30474d}.collapse-toggle-btn:active{transform:translateY(0)}#side-panel-container.collapsed .side-panel-header{justify-content:center;padding:0}.side-panel-tabs{display:flex;background:transparent;flex-shrink:0;padding:8px 24px;gap:8px;border-bottom:1px solid rgba(15,48,71,.08);align-items:center;justify-content:flex-start;flex-wrap:wrap}.tab-button{background:transparent;border:none;border-bottom:2px solid transparent;padding:10px 8px;flex:0 0 auto;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:500;color:#6b7280;white-space:nowrap;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;border-radius:8px;min-width:fit-content}.tab-button:hover{color:var(--navy-dark);background:#00000005}.tab-button.active{color:var(--accent-orange);background:#e85d3c0d;font-weight:600}.tab-button.active:after{content:"";position:absolute;bottom:-8px;left:20px;right:20px;height:2px;background:var(--accent-orange);border-radius:1px}.tab-button:focus-visible{outline:2px solid var(--accent-orange);outline-offset:-2px}.comment-count{background:var(--navy-dark);color:#fff;font-size:12px;font-weight:600;padding:2px;border-radius:12px;line-height:1;width:12px;height:12px;display:flex;align-items:center;justify-content:center;text-align:center;box-shadow:0 1px 3px #0f304733}.tab-button.active .comment-count{background:var(--accent-orange);box-shadow:0 1px 3px #e85d3c4d}.side-panel-content{flex-grow:1;overflow-y:auto;overflow-x:hidden;background:transparent;padding:24px 20px 32px 24px;scroll-behavior:smooth;overscroll-behavior-y:contain}.side-panel-content::-webkit-scrollbar{width:6px}.side-panel-content::-webkit-scrollbar-track{background:transparent}.side-panel-content::-webkit-scrollbar-thumb{background:#0f304726;border-radius:3px}.side-panel-content::-webkit-scrollbar-thumb:hover{background:#0f304740}.search-wrapper{position:relative;margin-bottom:24px}.search-icon{position:relative;left:14px;top:55%;transform:translateY(-50%);color:#888;pointer-events:none;z-index:2}.search-input{width:100%;padding:12px;border:1px solid #E5E7EB;border-radius:12px;font-size:15px;background:#fafbfc;transition:all .2s cubic-bezier(.4,0,.2,1)}.search-input:focus{outline:none;border-color:var(--accent-orange);background:#fff;box-shadow:0 0 0 3px #e85d3c1a}.search-input::placeholder{color:#9ca3af;font-weight:400}.fabric-item{display:flex;align-items:center;gap:16px;padding:16px;margin-bottom:8px;background:transparent;border:none;border-radius:12px;cursor:pointer;transition:all .15s ease;position:relative;min-height:auto}.fabric-item:hover{background:#00000005}.fabric-item.selected{background:#e85d3c14}.fabric-item.selected:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:32px;background:var(--accent-orange);border-radius:0 2px 2px 0}.fabric-preview{width:56px;height:56px;border-radius:10px;object-fit:cover;box-shadow:0 1px 3px #0000001a;background:#f3f4f6;flex-shrink:0}.fabric-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.fabric-name{font-size:16px;font-weight:500;color:#111827;line-height:1.3;white-space:normal;word-wrap:break-word;overflow-wrap:break-word}.fabric-details{font-size:14px;color:#6b7280;line-height:1.4;white-space:normal}.fabric-weight{font-size:13px;color:#9ca3af;margin-top:2px}.add-button{width:40px;height:40px;border-radius:8px;background:#fff;border:1px solid #E5E7EB;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:#6b7280;transition:all .15s ease;flex-shrink:0}.add-button:hover{background:#f9fafb;border-color:#d1d5db;color:var(--navy-dark)}.add-button:active{transform:scale(.95)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding:0 4px}.section-title{font-size:20px;font-weight:600;color:var(--navy-dark);letter-spacing:-.02em}.group-node-row,.comment-item,.stitch-item{padding:16px;margin-bottom:12px;background:#fff;border:2px solid transparent;border-radius:16px;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000a}.group-node-row:hover,.comment-item:hover,.stitch-item:hover{transform:translateY(-2px);box-shadow:0 8px 24px #e85d3c1f;border-color:var(--accent-pink)}.group-node-row.selected,.comment-item.selected,.stitch-item.selected{background:linear-gradient(to right,#e85d3c0d,#ffe1dc1a);border-color:var(--accent-orange)}button{cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;transition:all .2s cubic-bezier(.4,0,.2,1)}input,textarea,select{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;border:2px solid transparent;border-radius:12px;padding:10px 16px;background:#fffc;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000a}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-orange);background:#fff;box-shadow:0 4px 16px #e85d3c1a}#side-panel-container.collapsed .side-panel-tabs,#side-panel-container.collapsed .side-panel-content{display:none}.empty-state{text-align:center;padding:48px 24px;color:#9ca3af}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state-text{font-size:14px;line-height:1.5}.enhanced-tooltip-container{position:relative;display:inline-block}.enhanced-tooltip{z-index:10000;background:#1e1e1ef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px 16px;min-width:200px;max-width:280px;box-shadow:0 8px 32px #0000004d;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;pointer-events:none;-webkit-user-select:none;user-select:none}.tooltip-arrow{position:absolute;width:0;height:0;border-style:solid;left:-6px;top:50%;transform:translateY(-50%);border-width:6px 6px 6px 0;border-color:transparent rgba(30,30,30,.95) transparent transparent}.tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:12px}.tooltip-name{color:#fff;font-weight:600;font-size:14px;line-height:1.2}.tooltip-shortcut{background:#ffffff1a;color:#ccc;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:500;letter-spacing:.5px;border:1px solid rgba(255,255,255,.15);flex-shrink:0}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-cyrillic-ext-400-normal-Dc4VJyIJ.woff2) format("woff2"),url(/assets/inter-cyrillic-ext-400-normal-BPnxn4xp.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-cyrillic-400-normal-BLGc9T1a.woff2) format("woff2"),url(/assets/inter-cyrillic-400-normal-ZzOtrSSW.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-greek-ext-400-normal-Bput3-QP.woff2) format("woff2"),url(/assets/inter-greek-ext-400-normal-DCpCPQOf.woff) format("woff");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-greek-400-normal-DxZsaF_h.woff2) format("woff2"),url(/assets/inter-greek-400-normal-BZzXV7-1.woff) format("woff");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-vietnamese-400-normal-DMkecbls.woff2) format("woff2"),url(/assets/inter-vietnamese-400-normal-BUNmGMP1.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-latin-ext-400-normal-hnt3BR84.woff2) format("woff2"),url(/assets/inter-latin-ext-400-normal-C1t-h-pH.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-latin-400-normal-BOOGhInR.woff2) format("woff2"),url(/assets/inter-latin-400-normal-gitzw0hO.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-cyrillic-ext-500-normal-BShVwWPj.woff2) format("woff2"),url(/assets/inter-cyrillic-ext-500-normal-CUiC4oBV.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-cyrillic-500-normal-D4Vwzodn.woff2) format("woff2"),url(/assets/inter-cyrillic-500-normal-DH2hs3aW.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-greek-ext-500-normal-B6guLgqG.woff2) format("woff2"),url(/assets/inter-greek-ext-500-normal-M2hEX8vc.woff) format("woff");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-greek-500-normal-CeQXL5ds.woff2) format("woff2"),url(/assets/inter-greek-500-normal-d_eO-yCQ.woff) format("woff");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-vietnamese-500-normal-DOriooB6.woff2) format("woff2"),url(/assets/inter-vietnamese-500-normal-DQPw2Hwd.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-latin-ext-500-normal-CIS2RHJS.woff2) format("woff2"),url(/assets/inter-latin-ext-500-normal-UMdmhHu2.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-latin-500-normal-D2bGa7uu.woff2) format("woff2"),url(/assets/inter-latin-500-normal-deR1Tlfd.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-cyrillic-ext-600-normal-CaqZN2hq.woff2) format("woff2"),url(/assets/inter-cyrillic-ext-600-normal-Bt9VVOA-.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-cyrillic-600-normal-BGBWG807.woff2) format("woff2"),url(/assets/inter-cyrillic-600-normal-BuzJQFbW.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-greek-ext-600-normal-Cnui8OiR.woff2) format("woff2"),url(/assets/inter-greek-ext-600-normal-C9WLioJ8.woff) format("woff");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-greek-600-normal-Dhlb-90d.woff2) format("woff2"),url(/assets/inter-greek-600-normal-CwicyhtI.woff) format("woff");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-vietnamese-600-normal-Cc8MFFhd.woff2) format("woff2"),url(/assets/inter-vietnamese-600-normal-Cm6aH8_k.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-latin-ext-600-normal-BnYJhD27.woff2) format("woff2"),url(/assets/inter-latin-ext-600-normal-CAF0vJDd.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-latin-600-normal-D273HNI0.woff2) format("woff2"),url(/assets/inter-latin-600-normal-B5cFAncS.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}.tech-pack-form{background-color:#f8f9fa;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.tech-pack-form h3{color:#2c3e50;font-size:1.4rem;margin-top:0;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid #dee2e6}.tech-pack-form h4{color:#495057;font-size:1.1rem;margin-top:0;margin-bottom:15px}.form-section{margin-bottom:25px;padding-bottom:15px;border-bottom:1px solid #e9ecef}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px}.form-group{margin-bottom:15px}.form-group.full-width{grid-column:1 / -1}.form-group label{display:block;margin-bottom:5px;font-size:.9rem;color:#495057;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid #ced4da;border-radius:4px;font-size:.9rem;color:#495057;background-color:#fff;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem #007bff40}.form-group textarea{resize:vertical;min-height:80px}@media (max-width: 768px){.form-grid{grid-template-columns:1fr}}.tech-pack-fabrics{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px;margin-bottom:15px;max-height:200px;overflow-y:auto;padding:5px 0}.tech-pack-fabric-item{display:flex;align-items:center;padding:8px 12px;border-radius:6px;border:1px solid #e0e0e0;cursor:pointer;transition:all .2s ease;min-width:120px;max-width:180px}.tech-pack-fabric-item:hover{background-color:#f5f5f5;border-color:#d0d0d0}.tech-pack-fabric-item.selected{background-color:#e7f1fd;border-color:#5090e0;box-shadow:0 2px 8px #5090e026;position:relative}.tech-pack-fabric-color{width:24px;height:24px;border-radius:4px;margin-right:10px;border:1px solid rgba(0,0,0,.1)}.tech-pack-fabric-name{font-size:13px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 50px)}.tech-pack-fabric-item.selected:after{content:"✓";position:absolute;right:8px;top:50%;transform:translateY(-50%);color:#5090e0;font-weight:700}.logo-upload-container{display:flex;align-items:center;margin-top:5px}.logo-upload-wrapper{width:100%;position:relative}.logo-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2}.logo-upload-label{display:flex;align-items:center;justify-content:center;padding:8px 16px;background-color:#f8f9fa;border:1px dashed #ced4da;border-radius:4px;color:#6c757d;font-size:14px;width:100%;text-align:center;cursor:pointer;transition:all .2s ease;height:40px}.logo-upload-label:hover{background-color:#e9ecef;color:#495057}.logo-preview-wrapper{display:flex;align-items:center;width:100%}.logo-preview{max-width:150px;max-height:60px;margin-right:10px;object-fit:contain;border:1px solid #efefef;border-radius:4px;padding:2px}.remove-logo-btn{background-color:#e74c3c;color:#fff;border:none;padding:5px 10px;border-radius:4px;font-size:12px;cursor:pointer;transition:background-color .2s ease}.remove-logo-btn:hover{background-color:#c0392b}.fabric-status-indicator{position:fixed;left:50%;bottom:24px;transform:translate(-50%);padding:8px 16px;background-color:#f5f8fa;border-radius:20px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:8px;z-index:1000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.fabric-status-swatch{width:24px;height:24px;border-radius:50%;border:1px solid rgba(0,0,0,.1);flex-shrink:0}.fabric-status-swatch-texture{background-size:cover;background-position:center}.fabric-status-name{font-size:13px;font-weight:700;color:#444}.fabric-status-hint{font-size:12px;background-color:#0000000d;padding:2px 6px;border-radius:4px;margin-left:4px}.fabric-context-menu{position:fixed;background:#fffffffa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;box-shadow:0 10px 40px #0000001f,0 2px 10px #0000000f,0 0 0 1px #0f30470d;overflow:hidden;z-index:1000;min-width:280px;max-width:320px;max-height:400px;display:flex;flex-direction:column;animation:fadeIn .2s cubic-bezier(.4,0,.2,1);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}@keyframes fadeIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.fabric-menu-header{padding:16px 20px;font-size:16px;font-weight:600;color:#0f3047;border-bottom:1px solid rgba(15,48,71,.08);background:linear-gradient(to bottom,rgba(255,249,247,.5),transparent)}.fabric-menu-items{flex:1;overflow-y:auto;padding:8px}.fabric-menu-items::-webkit-scrollbar{width:6px}.fabric-menu-items::-webkit-scrollbar-track{background:transparent}.fabric-menu-items::-webkit-scrollbar-thumb{background:#0f304726;border-radius:3px}.fabric-menu-items::-webkit-scrollbar-thumb:hover{background:#0f304740}.fabric-menu-item{display:flex;align-items:center;gap:12px;padding:12px;margin-bottom:4px;border-radius:12px;cursor:pointer;transition:all .15s ease;border:2px solid transparent}.fabric-menu-item:hover{background:#e85d3c14;border-color:#e85d3c33}.fabric-menu-item:active{transform:scale(.98)}.fabric-menu-swatch{width:48px;height:48px;border-radius:8px;flex-shrink:0;box-shadow:0 1px 3px #0000001a;border:1px solid rgba(0,0,0,.05)}.fabric-menu-swatch-texture{background-size:cover;background-position:center;background-repeat:no-repeat}.fabric-menu-item-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.fabric-menu-item-name{font-size:14px;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fabric-menu-item-composition{font-size:12px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fabric-menu-footer{padding:12px 16px;border-top:1px solid rgba(15,48,71,.08);background:#f9fafb80}.fabric-menu-cancel{width:100%;padding:10px 16px;background:#fff;border:1px solid #E5E7EB;border-radius:8px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .15s ease}.fabric-menu-cancel:hover{background:#f9fafb;border-color:#d1d5db;color:#111827}.fabric-menu-cancel:active{transform:scale(.98)}.fabric-menu-empty{padding:32px 20px;text-align:center;color:#9ca3af;font-size:14px}.fabric-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999;background:transparent}body{font-family:Arial,sans-serif;margin:0;padding:0;height:100vh;background-color:#e8d4b0;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#sketch-screen-container{display:flex;flex-direction:column;height:100vh;position:relative;overflow:visible}:root{--primary-color: #0e3147;--accent-color: #0066ff;--text-color: #333;--light-text-color: #666;--border-color: #ccc;--light-border-color: #ddd;--background-color: #f9f7f6;--white-color: #fff;--light-gray: #f5f5f5;--dark-gray: #555;--toolbar-bg-light: rgba(248, 240, 238, 255);--toolbar-border-light: rgba(244, 238, 241, .8);--transition-speed-fast: .2s;--transition-speed-normal: .3s;--transition-speed-slow: .5s;--radius-small: 4px;--radius-medium: 6px;--radius-large: 8px;--radius-xl: 12px;--radius-round: 48px}body *{font-family:Inter,Arial,sans-serif}#sketch-screen-container{display:flex;flex-direction:column;height:100vh;width:100vw;position:relative;overflow:hidden}#top-header{position:absolute;top:0;left:0;width:100%;height:55px;background:var(--background-color);border-bottom:1px solid #f8f2ef;display:flex;align-items:center;z-index:1000}#top-header-content{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 16px}#main-drawing-area{flex:1;position:relative;margin-top:55px;width:100%;height:calc(100vh - 55px);overflow:hidden}#stage-container{width:100%;height:100%;background:var(--white-color);position:relative;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}#stage-container canvas{touch-action:none}.fabric-library-panel{position:absolute;top:70px;right:20px;width:280px;max-height:calc(100vh - 100px);overflow-y:auto;border-radius:var(--radius-round);border:5px solid var(--toolbar-border-light);background:radial-gradient(ellipse 70% 70% at 50% 0%,var(--toolbar-bg-light) 0%,rgba(255,0,0,0) 100%),radial-gradient(ellipse 70% 70% at 50% 100%,var(--toolbar-bg-light) 0%,rgba(0,0,255,0) 100%);box-shadow:0 -14px 42px -12px #e3d6ff0f inset;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:999;padding:8px 16px;transition:width var(--transition-speed-normal) ease,right var(--transition-speed-normal) ease}.fabric-collapsed .fabric-library-panel{width:80px}#group-overview-container{position:absolute;top:100px;right:360px;width:0px;z-index:19;padding:12px;background:none;border:none;border-radius:0;font-size:14px;color:var(--text-color);transition:right var(--transition-speed-normal) ease,width var(--transition-speed-normal) ease}.fabric-collapsed #group-overview-container{right:180px}body:not(.fabric-collapsed) #group-overview-container{right:380px}#comment-panel{position:absolute;top:100px;right:20px;width:320px;background:var(--white-color);z-index:19;border-radius:var(--radius-large);box-shadow:0 2px 8px #0000001a;overflow:hidden;max-height:calc(100vh - 200px);display:flex;flex-direction:column;transition:right var(--transition-speed-normal) ease}.fabric-collapsed #comment-panel{right:120px}#vertical-toolbar{position:absolute;left:20px;top:100px;z-index:999;width:75px;height:77%;border-radius:var(--radius-round);border:5px solid var(--toolbar-border-light);background:radial-gradient(ellipse 70% 70% at 50% 0%,var(--toolbar-bg-light) 0%,rgba(255,0,0,0) 100%),radial-gradient(ellipse 70% 70% at 50% 100%,var(--toolbar-bg-light) 0%,rgba(0,0,255,0) 100%);box-shadow:0 -14px 42px -12px #e3d6ff0f inset;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;flex-direction:column;align-items:center;justify-content:space-evenly;padding-top:20px;padding-bottom:20px;gap:6px;max-height:calc(100vh - 120px);overflow-y:auto;transform:none;isolation:auto;overflow:visible!important}.toolbar-button{position:relative;box-sizing:border-box;border:0px solid transparent;background-color:var(--white-color);width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-medium);cursor:pointer;font-size:12px;outline:none;transition:background-color var(--transition-speed-fast) ease,border-color var(--transition-speed-fast) ease;overflow:visible!important}.toolbar-button:hover{background-color:var(--light-gray)}.toolbar-button.active{background-color:#0066ff26;border-color:#0066ff80}.toolbar-button.clear-button{background:#dc3545;border-color:#dc3545;color:var(--white-color);margin-top:8px}.toolbar-button.clear-button:hover{background:#c82333;border-color:#bd2130}.toolbar-button svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-color)}.tool-indicator{position:absolute;bottom:3px;left:10px;right:10px;height:4px;background-color:var(--accent-color);border-radius:2px;pointer-events:none}.toolbar-menu{position:absolute;left:calc(100% + 8px);top:0;background:var(--white-color);border:1px solid var(--border-color);border-radius:var(--radius-medium);box-shadow:0 2px 8px #00000026;z-index:1500;min-width:180px;overflow:hidden;padding:4px}.toolbar-menu button{width:100%;padding:8px 12px;border:none;background:transparent;cursor:pointer;font-size:13px;text-align:left;transition:background-color var(--transition-speed-fast) ease;color:var(--dark-gray)}.toolbar-menu button:hover{background:var(--light-gray)}.toolbar-menu button:disabled{color:#6c757d;cursor:not-allowed}.toolbar-menu .menu-divider{height:1px;background:var(--border-color);margin:4px 0}.silhouette-menu{width:130px;position:absolute;top:0;left:50px;display:flex;flex-direction:column;background:#fff;border:1px solid #ccc;border-radius:6px;padding:4px;gap:4px;z-index:9999;min-width:auto}.silhouette-menu button{background:#f9f9f9;border:1px solid #ddd;border-radius:4px;cursor:pointer;padding:4px 8px;font-size:14px;width:auto;text-align:center}.silhouette-menu button:hover{background:#eee}.pen-controls-menu{min-width:240px;max-width:280px;width:auto;padding:16px;position:absolute;top:50%;left:100%;transform:translateY(-50%);background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;border:1px solid var(--border-color);z-index:9999;overflow:visible}.pen-tool-controls{width:100%;background:transparent;border:none;border-radius:0;box-shadow:none;padding:0;position:static;left:auto;top:auto}.pen-tool-controls .control-section{display:flex;flex-direction:column;gap:12px;width:100%}.pen-tool-controls .control-section h3{margin:0 0 8px;font-size:16px;font-weight:600;color:var(--text-color);border-bottom:1px solid #eee;padding-bottom:8px}.pen-tool-controls .control-group{display:flex;flex-direction:column;gap:6px;margin-bottom:10px;width:100%}.pen-tool-controls .control-group label{font-size:14px;font-weight:500;color:var(--dark-gray);margin-bottom:4px}.pen-tool-controls .size-controls,.pen-tool-controls .line-style-options,.pen-tool-controls .dash-controls{display:flex;align-items:center;gap:10px;margin-bottom:8px;width:100%}.pen-tool-controls .button-controls{display:flex;align-items:center;gap:10px;margin-top:4px;justify-content:center}.pen-tool-controls .size-button{width:30px;height:30px;border-radius:var(--radius-small);border:1px solid var(--light-border-color);background-color:var(--light-gray);display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:all var(--transition-speed-fast) ease}.pen-tool-controls .size-button:hover:not(:disabled){background-color:#eee}.pen-tool-controls .size-button:disabled{opacity:.5;cursor:not-allowed}.pen-tool-controls .size-display{font-size:16px;font-weight:600;min-width:20px;text-align:center}.pen-tool-controls .style-button{flex:1;padding:6px 12px;border-radius:var(--radius-small);border:1px solid var(--light-border-color);background-color:var(--light-gray);font-size:14px;cursor:pointer;transition:all var(--transition-speed-fast) ease;text-align:center}.pen-tool-controls .style-button:hover{background-color:#eee}.pen-tool-controls .style-button.active{background-color:#e6f7ff;border-color:#1890ff;color:#1890ff}.pen-tool-controls .brush-size-slider,.pen-tool-controls input[type=range]{width:100%;margin-top:4px}.pen-tool-controls .dash-controls{display:flex;flex-direction:column;margin-bottom:8px;width:100%}.pen-tool-controls .dash-controls label{font-size:14px;margin-bottom:4px}.pen-tool-controls .dash-controls input[type=range]{width:100%;margin-top:4px}.pen-tool-controls .button-group{display:flex;gap:8px;margin-top:8px}.pen-tool-controls .tool-select-button{flex:1;padding:8px 12px;border-radius:var(--radius-medium);border:1px solid var(--light-border-color);background-color:var(--light-gray);font-size:14px;display:flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:all var(--transition-speed-fast) ease}.pen-tool-controls .tool-select-button:hover{background-color:#eee}.pen-tool-controls .tool-select-button.active{background-color:#e6f7ff;border-color:#1890ff;color:#1890ff}.project-title-input{font-size:16px;font-weight:600;color:var(--text-color);background:none;border:none;outline:none;padding:0 8px;margin:0;vertical-align:middle;line-height:normal;border-radius:var(--radius-small);height:auto;min-width:120px;box-sizing:border-box}.project-title-input:focus{background-color:#ffffffe6;box-shadow:0 0 0 2px #0e31471a;border-radius:var(--radius-medium)}.project-title-container{display:flex;align-items:center;padding:0;margin:0;overflow:visible;border-radius:var(--radius-large)}.top-header-button{font-size:14px;background-color:var(--primary-color);color:var(--white-color);border:1px solid var(--primary-color);border-radius:var(--radius-small);padding:6px 12px;margin-left:8px;cursor:pointer;outline:none;display:flex;align-items:center;transition:opacity var(--transition-speed-fast) ease}.top-header-button:hover{opacity:.8}.top-header-button:disabled{opacity:.5;cursor:not-allowed}.icon-button{background:none;border:none;padding:0;cursor:pointer;margin-left:8px;color:var(--primary-color);font:inherit;display:flex;align-items:center;transition:opacity var(--transition-speed-fast) ease}.icon-button:hover{opacity:.8}#measurement-tooltip{position:absolute;background:var(--white-color);color:var(--text-color);padding:4px 8px;border:1px solid var(--border-color);border-radius:var(--radius-small);pointer-events:none;transform:translate(var(--tooltip-x, 0px),var(--tooltip-y, 0px));z-index:900}#scale-bar-container{position:absolute;right:20px;bottom:20px;background:#ffffffb3;padding:8px;border-radius:var(--radius-small);text-align:center;z-index:900}#scale-bar{height:10px;background-color:#000;width:var(--scale-bar-width, 100px)}#scale-bar-label{font-size:12px;margin-top:4px}.tech-pack-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#00000080;z-index:2000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.tech-pack-modal-content{width:80%;max-width:800px;height:80%;max-height:800px;background:#fffffffa;box-shadow:0 0 16px 1px #0003;border-radius:var(--radius-xl);padding:30px;overflow-y:auto;display:flex;flex-direction:column}.tech-pack-modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e2e2e2;padding-bottom:15px;margin-bottom:20px}.tech-pack-modal-header h2{font-weight:600;color:var(--primary-color);margin:0;white-space:nowrap}.tech-pack-form{display:flex;flex-direction:column;flex:1;overflow-y:auto}.tech-pack-form-row{display:flex;margin-bottom:20px;flex-wrap:wrap;gap:25px}.tech-pack-form-group{display:flex;flex-direction:column;flex:1;min-width:200px;margin-bottom:15px}.tech-pack-form-group label{font-weight:500;font-size:14px;color:var(--dark-gray);margin-bottom:5px}.tech-pack-form-group input,.tech-pack-form-group textarea,.tech-pack-form-group select,.tech-pack-input,.tech-pack-textarea{padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-small);font-size:14px;transition:border-color var(--transition-speed-fast) ease,box-shadow var(--transition-speed-fast) ease}.tech-pack-form-group input:focus,.tech-pack-form-group textarea:focus,.tech-pack-form-group select:focus,.tech-pack-input:focus,.tech-pack-textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 2px #0e314733}.tech-pack-form-group textarea,.tech-pack-textarea{min-height:80px;resize:vertical}.tech-pack-form-section{margin-bottom:25px;border-bottom:1px solid #eaeaea;padding-bottom:15px}.tech-pack-form-section h3{font-weight:600;font-size:16px;color:var(--primary-color);margin-top:0;margin-bottom:15px}.tech-pack-modal-actions{display:flex;justify-content:flex-end;margin-top:25px;padding-top:15px;border-top:1px solid #e2e2e2;gap:10px}.tech-pack-modal-actions button{padding:10px 20px;border:none;border-radius:var(--radius-medium);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-speed-fast) ease}.tech-pack-modal-cancel{background-color:var(--light-gray);color:var(--text-color)}.tech-pack-modal-cancel:hover{background-color:#e5e5e5}.tech-pack-modal-export{background-color:var(--primary-color);color:var(--white-color)}.tech-pack-modal-export:hover{background-color:#0a2535}.tech-pack-loading{display:flex;align-items:center;justify-content:center;margin-right:10px}.tech-pack-spinner{border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top:2px solid white;width:16px;height:16px;animation:spin 1s linear infinite;margin-right:8px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tech-pack-fabrics{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.tech-pack-fabric-item{display:flex;align-items:center;padding:8px 12px;border:1px solid #eaeaea;border-radius:var(--radius-medium);background:var(--white-color);cursor:pointer;transition:all var(--transition-speed-fast) ease}.tech-pack-fabric-item:hover{border-color:var(--primary-color);background:var(--light-gray)}.tech-pack-fabric-item.selected{border-color:var(--primary-color);background:#0e31471a}.tech-pack-fabric-color{width:20px;height:20px;border-radius:var(--radius-small);margin-right:8px;border:1px solid rgba(0,0,0,.1)}.tech-pack-fabric-name{font-size:13px;color:var(--text-color)}@media (max-width: 768px){.tech-pack-modal-content{width:95%;height:90%;padding:20px}.tech-pack-form-group{min-width:100%;margin-right:0}}.tech-pack-tabs{display:flex;gap:10px;margin-right:20px}.tech-pack-tab{background:none;border:none;border-bottom:2px solid transparent;padding:8px 12px;font-size:14px;font-weight:500;color:var(--light-text-color);cursor:pointer;transition:all var(--transition-speed-fast) ease}.tech-pack-tab:hover{color:var(--primary-color)}.tech-pack-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.tech-pack-bullet-list{margin-bottom:15px;max-height:200px;overflow-y:auto;border:1px solid #e5e5e5;border-radius:var(--radius-small);padding:5px 0;background-color:var(--white-color)}.tech-pack-bullet-item{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;margin:2px 0;transition:background-color var(--transition-speed-fast) ease}.tech-pack-bullet-item:hover{background-color:var(--light-gray)}.bullet-content{display:flex;align-items:flex-start;flex:1}.bullet-point{margin-right:8px;color:var(--primary-color);font-weight:700}.bullet-text{font-size:14px;color:var(--text-color);line-height:1.4;flex:1}.bullet-remove-btn{background:none;border:none;color:#999;font-size:18px;cursor:pointer;padding:0 5px;border-radius:var(--radius-small);transition:all var(--transition-speed-fast) ease}.bullet-remove-btn:hover{color:#d32f2f;background-color:#d32f2f1a}.tech-pack-add-item{display:flex;margin-top:5px}.tech-pack-add-item input{flex:1;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-small) 0 0 var(--radius-small);font-size:14px}.tech-pack-add-btn{background-color:var(--primary-color);color:var(--white-color);border:none;border-radius:0 var(--radius-small) var(--radius-small) 0;padding:8px 15px;cursor:pointer;font-weight:500;font-size:14px;transition:background-color var(--transition-speed-fast) ease}.tech-pack-add-btn:hover{background-color:#0a2535}.tech-pack-preview{margin-top:30px;border:1px solid #e0e0e0;border-radius:var(--radius-large);overflow:hidden;background-color:var(--light-gray)}.tech-pack-preview-header{background-color:var(--primary-color);color:var(--white-color);padding:15px;font-weight:600;font-size:16px}.tech-pack-preview-content{padding:20px}.tech-pack-preview-section{margin-bottom:20px}.tech-pack-preview-section h4{font-weight:600;font-size:14px;color:var(--text-color);margin-bottom:10px;border-bottom:1px solid #e0e0e0;padding-bottom:5px}.tech-pack-preview-items{background:var(--white-color);border:1px solid #e0e0e0;border-radius:var(--radius-small);padding:10px 15px}.tech-pack-preview-item{margin-bottom:5px;font-size:13px;line-height:1.4}.fabric-application-mode{cursor:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20"><circle cx="10" cy="10" r="8" fill="%230e3147" opacity="0.5"/><circle cx="10" cy="10" r="2" fill="%23ffffff"/></svg>') 10 10,auto}.eraser-cursor{cursor:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20" fill="none" stroke="black" stroke-width="1.5"><circle cx="10" cy="10" r="7" fill="rgba(255,255,255,0.7)" /><line x1="7" y1="10" x2="13" y2="10" stroke="red" stroke-width="1.5" /><line x1="10" y1="7" x2="10" y2="13" stroke="red" stroke-width="1.5" /></svg>') 10 10,auto}.lasso-cursor,.pen-cursor,.stitch-mode{cursor:crosshair!important}.regular-lasso-cursor{cursor:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="%23ff5722" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M7 22a5 5 0 0 1-2-4"/><path d="M3.3 14A6.8 6.8 0 0 0 2 18c0 1 0 3 2 4"/><path d="M7 22h7"/><path d="M22 17c0 3-2 5-5 5"/><path d="M19 8V4a2 2 0 0 0-2-2H4a2 2 0 0 0-2 2v6c0 2 2 4 4 4h.5"/><path d="M10 2v2"/><path d="M14 2v2"/><path d="M10 14v8"/><path d="M18 14v3"/></svg>') 12 12,auto!important}.copy-cursor{cursor:copy!important}.draggable-cursor{cursor:move!important}.drag-active{cursor:grabbing!important}.hoverable-shape{transition:stroke var(--transition-speed-fast) ease}.hoverable-shape:hover{stroke:var(--primary-color)!important;stroke-width:3px!important;filter:drop-shadow(0 0 3px rgba(14,49,71,.3))}.eraser-cursor .hoverable-shape:hover,.eraser-cursor [segmentid]:hover,.eraser-cursor Line:hover{stroke:#f33!important;stroke-width:3px!important;filter:drop-shadow(0 0 3px rgba(255,51,51,.5))!important;cursor:pointer}.segment-selected{stroke-width:2px!important;filter:drop-shadow(0 0 3px rgba(255,51,51,.4))}.draggable-cursor .segment-selected:hover{cursor:grab!important}.segment-dragging{opacity:.8;stroke-opacity:.9;filter:drop-shadow(0 0 5px rgba(0,0,0,.3))}.segment-copied{stroke-dasharray:4,4;animation:dash 1s linear infinite}@keyframes dash{to{stroke-dashoffset:8}}.status-indicator{position:fixed;top:80px;left:50%;transform:translate(-50%);background-color:#f1f8ff;border:1px solid #b4d2ff;border-radius:var(--radius-medium);padding:10px 15px;display:flex;align-items:center;gap:10px;z-index:1000;box-shadow:0 2px 8px #0000001a;animation:fadeIn var(--transition-speed-fast) ease-in-out}.status-text{font-size:14px;color:var(--primary-color)}.status-action-button{background-color:var(--primary-color);color:var(--white-color);border:none;border-radius:var(--radius-small);padding:6px 12px;cursor:pointer;font-size:12px;font-weight:500;transition:background-color var(--transition-speed-fast) ease}.status-action-button:hover{background-color:#18546c}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-10px)}to{opacity:1;transform:translate(-50%)}}.dragging-indicator{position:fixed;top:80px;left:50%;transform:translate(-50%);background-color:#3498dbe6;color:var(--white-color);padding:8px 16px;border-radius:var(--radius-small);font-size:14px;z-index:1000;box-shadow:0 2px 6px #0003;pointer-events:none}.toast-notification{position:fixed!important;left:50%!important;top:80px!important;bottom:auto!important;transform:translate(-50%)!important;width:fit-content!important;min-width:150px!important;max-width:400px!important;height:auto!important;background-color:#323232d9!important;color:var(--white-color)!important;border:none!important;box-shadow:0 2px 10px #0003!important;border-radius:var(--radius-small)!important;padding:10px 20px!important;z-index:9999!important;font-size:14px!important;text-align:center!important;overflow:hidden!important;animation:fadeInOutTop 3s ease-in-out forwards!important;box-sizing:border-box!important}@keyframes fadeInOutTop{0%{opacity:0;transform:translate(-50%,-40px)}15%{opacity:1;transform:translate(-50%)}85%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-40px)}}.comment-mode-indicator{position:fixed;top:80px;left:50%;transform:translate(-50%);background:#1e90ffcc;color:var(--white-color);padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500;box-shadow:0 2px 8px #0003;z-index:1000;display:flex;align-items:center;gap:8px}.comment-mode-indicator .comment-mode-button{background:var(--white-color);color:var(--primary-color);border:none;border-radius:16px;padding:4px 10px;font-size:12px;cursor:pointer;transition:background-color var(--transition-speed-fast) ease}.comment-mode-indicator .comment-mode-button:hover{background-color:#eee}.comment-mode-indicator svg{width:16px;height:16px}.comment-form-container{position:absolute;background-color:var(--white-color);border-radius:var(--radius-medium);box-shadow:0 2px 10px #0003;font-family:Inter,sans-serif;z-index:1000;padding:15px}.finalize-drawing-button{position:absolute;bottom:20px;left:50%;transform:translate(-50%);z-index:1001;background-color:#e6eef5;color:#33475b;border:1px solid rgba(0,0,0,.05);border-radius:50px;padding:12px 25px;font-size:15px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1;box-shadow:5px 5px 10px #0000001a,inset 3px 3px 5px #ffffffb3,inset -1px -1px 3px #c8c8d24d,0 0 0 1px #ffdcd280;transition:all var(--transition-speed-normal) ease;opacity:1;visibility:visible}.finalize-drawing-button:hover{background-color:#cfe2f3;box-shadow:6px 6px 12px #0000001f,inset 2px 2px 4px #fffc,inset -1px -1px 2px #c8c8d266,0 0 0 1px #ffd7cd99;transform:translate(-50%) translateY(-1px)}.finalize-drawing-button:active{background-color:#d0e3f4;box-shadow:2px 2px 5px #00000014,inset 4px 4px 6px #c8c8d280,inset -2px -2px 4px #fff9;transform:translate(-50%) translateY(1px)}.silhouette-height-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;background:#e0e0e0;border-radius:2px;outline:none;opacity:.8;transition:opacity var(--transition-speed-fast) ease}.silhouette-height-slider:hover{opacity:1}.silhouette-height-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--text-color);cursor:pointer;transition:all var(--transition-speed-fast) ease}.silhouette-height-slider::-webkit-slider-thumb:hover{background:#000;transform:scale(1.2)}.silhouette-height-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--text-color);cursor:pointer;border:none;transition:all var(--transition-speed-fast) ease}.silhouette-height-slider::-moz-range-thumb:hover{background:#000;transform:scale(1.2)}.silhouette-menu .menu-divider{height:1px;background:#e0e0e0;margin:4px 0}.mode-buttons{display:flex;gap:8px;margin-top:8px}.mode-button{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--light-border-color);background:var(--white-color);border-radius:var(--radius-small);cursor:pointer;transition:all var(--transition-speed-fast) ease;font-size:12px}.mode-button:hover{background:var(--light-gray);border-color:#999}.mode-button.active{background:#007bff;color:var(--white-color);border-color:#007bff}.mode-button svg{width:16px;height:16px}.freehand-mode-indicator{position:fixed;top:80px;left:50%;transform:translate(-50%);background:#28a745;color:var(--white-color);padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500;box-shadow:0 2px 8px #0003;z-index:1000;display:flex;align-items:center;gap:8px}.freehand-mode-indicator svg{width:16px;height:16px}.mirror-popup{position:absolute;background-color:var(--white-color);border:1px solid var(--border-color);border-radius:var(--radius-small);box-shadow:0 2px 8px #00000026;z-index:1000;padding:12px;width:220px}.mirror-popup h3{margin:0 0 10px;font-size:14px;font-weight:500;color:var(--text-color)}.mirror-option{display:flex;align-items:center;padding:8px 12px;cursor:pointer;border-radius:var(--radius-small);transition:background-color var(--transition-speed-fast) ease}.mirror-option:hover{background-color:var(--light-gray)}.mirror-option.active{background-color:#e6f7ff;border:1px solid #91d5ff}.mirror-icon{margin-right:10px;color:var(--dark-gray)}.enhanced-tooltip-container{position:relative;display:inline-block;z-index:1}.enhanced-tooltip{position:fixed;z-index:10000;background:#1e1e1ef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-large);padding:12px 16px;min-width:200px;max-width:280px;box-shadow:0 8px 32px #0000004d;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;animation:tooltipFadeIn var(--transition-speed-fast) ease-out;pointer-events:none}.enhanced-tooltip:before{content:"";position:absolute;width:0;height:0;border-style:solid;left:-6px;top:50%;transform:translateY(-50%);border-width:6px 6px 6px 0;border-color:transparent rgba(30,30,30,.95) transparent transparent}.tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.tooltip-name{color:var(--white-color);font-weight:600;font-size:14px;line-height:1.2}.tooltip-shortcut{background:#ffffff1a;color:#ccc;padding:2px 6px;border-radius:var(--radius-small);font-size:11px;font-weight:500;letter-spacing:.5px;border:1px solid rgba(255,255,255,.15)}.tooltip-description{color:#ccc;font-size:12px;line-height:1.4;margin-top:4px}@keyframes tooltipFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:1}}@media (max-height: 800px){.toolbar-button{width:40px;height:40px}#vertical-toolbar{gap:4px;padding:10px 6px}}@media (max-height: 600px){.toolbar-button{width:36px;height:36px}#vertical-toolbar{gap:3px;padding:8px 5px}}.toggle-button{background-color:var(--white-color);border:none;border-radius:var(--radius-round);padding:12px 24px;box-shadow:0 2px 8px #0000001a;font-size:16px;cursor:pointer;color:var(--primary-color);font-weight:500;display:flex;align-items:center;justify-content:center;transition:none;height:48px}.toggle-button:hover{background-color:var(--light-gray);box-shadow:0 3px 6px #0003}body.fabric-collapsed #fabric-library-overlay{width:80px}body:not(.fabric-collapsed) #fabric-library-overlay{width:280px}#fabric-library-overlay{position:absolute;top:100px;right:20px;width:280px;transition:width var(--transition-speed-normal) ease;z-index:20}#fabric-library-column{display:none}.view-selector{display:flex;background-color:#f0f0f0;border-radius:8px;padding:4px}.view-selector-tab{padding:6px 16px;border:none;background-color:transparent;color:#555;font-weight:500;font-size:14px;border-radius:6px;cursor:pointer;transition:all .2s ease-in-out}.view-selector-tab:hover{background-color:#e0e0e0}.view-selector-tab.active{background-color:#fff;color:#0f3047;box-shadow:0 1px 3px #0000001a}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-cyrillic-ext-700-normal-ClVoMEGq.woff2) format("woff2"),url(/assets/inter-cyrillic-ext-700-normal-Ced3hgUT.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-cyrillic-700-normal-bGtGjVdZ.woff2) format("woff2"),url(/assets/inter-cyrillic-700-normal-Bc8_fv8J.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-greek-ext-700-normal-SzCdnevJ.woff2) format("woff2"),url(/assets/inter-greek-ext-700-normal-DXvzx4Na.woff) format("woff");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-greek-700-normal-Cxpycf-U.woff2) format("woff2"),url(/assets/inter-greek-700-normal-BRYTaFLL.woff) format("woff");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-vietnamese-700-normal-CGpBpxLq.woff2) format("woff2"),url(/assets/inter-vietnamese-700-normal-dAnkLlTo.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-latin-ext-700-normal-CzikT_rs.woff2) format("woff2"),url(/assets/inter-latin-ext-700-normal-6V9MnIL5.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-latin-700-normal-Sckx8rpT.woff2) format("woff2"),url(/assets/inter-latin-700-normal-B8MtJ_2k.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}.comment-mode{cursor:crosshair!important}.comment-form-container{width:280px;background-color:#fff;border-radius:6px;box-shadow:0 2px 10px #0003;font-family:Inter,sans-serif}.comment-form{padding:12px;display:flex;flex-direction:column}.comment-textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-family:Inter,sans-serif;font-size:14px;resize:vertical;min-height:60px}.comment-textarea:focus{outline:none;border-color:#0e3147;box-shadow:0 0 0 2px #0e314733}.comment-form-actions{display:flex;justify-content:flex-end;margin-top:10px;gap:8px}.comment-cancel-btn,.comment-save-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:4px;font-family:Inter,sans-serif;font-size:13px;cursor:pointer;transition:background-color .2s}.comment-cancel-btn{background:none;border:1px solid #ddd;color:#666}.comment-cancel-btn:hover{background-color:#f5f5f5}.comment-save-btn{background-color:#0e3147;border:none;color:#fff}.comment-save-btn:hover{background-color:#0a2535}.comment-save-btn:disabled{background-color:#ccc;cursor:not-allowed}.comments-section{background-color:#fff;border-radius:15px;box-shadow:0 2px 8px #0000001a;margin-top:0;font-family:Inter,sans-serif;overflow:hidden}.comments-header{font-size:16px;font-weight:600;color:#0e3147;padding:12px 16px;margin:0;border-bottom:1px solid #eee;background-color:#f9f9f9}.comments-list{max-height:300px;overflow-y:auto}.comment-item{display:flex;padding:12px 16px;border-bottom:1px solid #eee;transition:background-color .2s;cursor:pointer;align-items:flex-start}.comment-item:hover{background-color:#f5f5f5}.comment-item.selected{background-color:#0e31470d}.comment-marker-number{margin-right:12px;padding-top:2px}.comment-dot{width:24px;height:24px;border-radius:50%;background-color:#ff5722;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;transition:box-shadow .2s}.comment-content{flex:1}.comment-text{margin:0;font-size:14px;line-height:1.4;color:#333}.comment-actions{display:flex;gap:6px;opacity:0;transition:opacity .2s}.comment-item:hover .comment-actions{opacity:1}.comment-action-btn{background:none;border:none;font-size:12px;cursor:pointer;padding:2px 6px;border-radius:3px;color:#666}.comment-action-btn:hover{background-color:#eee;color:#333}.comment-action-btn.delete-btn:hover{color:#e74c3c}.comment-mode-indicator{position:fixed;top:80px;left:50%;transform:translate(-50%);background-color:#fff3e0;border:1px solid #ffcc80;border-radius:6px;padding:10px 15px;display:flex;align-items:center;gap:10px;z-index:1000;box-shadow:0 2px 8px #0000001a;font-family:Inter,sans-serif;width:auto;margin:0 auto}.comment-mode-text{font-size:14px;color:#e65100}.comment-mode-button{background-color:#ff5722;color:#fff;border:none;border-radius:4px;padding:6px 12px;cursor:pointer;font-size:12px;font-weight:500;transition:background-color .2s}.comment-mode-button:hover{background-color:#e64a19}.toolbar-button.comment{position:relative}.toolbar-button.active .tool-indicator{position:absolute;bottom:3px;left:10px;right:10px;height:4px;background-color:#ff5722;border-radius:2px}#comment-panel{position:absolute;bottom:20px;right:20px;width:320px;background:#fff;z-index:19;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden;max-height:calc(100vh - 550px);display:flex;flex-direction:column;transition:right .3s ease}body.fabric-collapsed #comment-panel{right:120px}body:not(.fabric-collapsed) #comment-panel{right:320px}.toggle-button{background-color:#fff;border:none;border-radius:24px;padding:12px 24px;box-shadow:0 2px 8px #0000001a;font-family:"Inter, sans-serif";font-size:16px;cursor:pointer;color:#0e3147;font-weight:500;display:flex;align-items:center;justify-content:center;height:48px;transition:background-color .2s}.toggle-button:hover{background-color:#f8f8f8}#ui-controls{position:absolute;top:150px;left:10px;display:flex;flex-direction:column;gap:10px;z-index:999}.stitch-mode{cursor:crosshair!important}.stitch-mode-indicator{position:fixed;top:80px;left:50%;transform:translate(-50%);background-color:#fff3e0;border:1px solid #ffcc80;border-radius:6px;padding:10px 15px;display:flex;align-items:center;gap:10px;z-index:1000;box-shadow:0 2px 8px #0000001a;font-family:Inter,sans-serif;width:auto;margin:0 auto}.stitch-mode-text{font-size:14px;color:#e65100}.stitch-mode-button{background-color:#ff5722;color:#fff;border:none;border-radius:4px;padding:6px 12px;cursor:pointer;font-size:12px;font-weight:500;transition:background-color .2s}.stitch-mode-button:hover{background-color:#e64a19}.toolbar-button.stitch{position:relative}.toolbar-button.active .tool-indicator{position:absolute;bottom:3px;left:10px;right:10px;height:4px;background-color:#00acc1;border-radius:2px}.stitch-form-container{width:280px;background-color:#fff;border-radius:6px;box-shadow:0 2px 10px #0003;font-family:Inter,sans-serif}.stitch-form{padding:12px;display:flex;flex-direction:column}.stitch-textarea,.stitch-select{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-family:Inter,sans-serif;font-size:14px;margin-bottom:10px}.stitch-textarea{resize:vertical;min-height:60px}.stitch-textarea:focus,.stitch-select:focus{outline:none;border-color:#00acc1;box-shadow:0 0 0 2px #00acc133}.stitch-label{font-size:14px;font-weight:500;margin-bottom:6px;color:#333}.stitch-form-actions{display:flex;justify-content:flex-end;margin-top:10px;gap:8px}.stitch-cancel-btn,.stitch-save-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:4px;font-family:Inter,sans-serif;font-size:13px;cursor:pointer;transition:background-color .2s}.stitch-cancel-btn{background:none;border:1px solid #ddd;color:#666}.stitch-cancel-btn:hover{background-color:#f5f5f5}.stitch-save-btn{background-color:#00acc1;border:none;color:#fff}.stitch-save-btn:hover{background-color:#0097a7}.stitch-save-btn:disabled{background-color:#ccc;cursor:not-allowed}.pen-controls-container-light{background-color:#f8f9fa;color:#212529;padding:8px;border-radius:12px;width:240px;display:flex;flex-direction:column;gap:14px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;box-shadow:0 5px 20px #0000001a;border:1px solid #dee2e6}.divider-light{height:1px;background-color:#e9ecef;margin:-4px 0}.control-row-light{display:flex;align-items:center;gap:12px;font-size:13px}.control-row-light label{flex:0 0 50px;color:#495057;font-size:12px;font-weight:500}.slider-container-light{flex-grow:1}.value-display-light{flex:0 0 40px;text-align:center;font-variant-numeric:tabular-nums;color:#495057;background-color:#e9ecef;padding:3px 6px;border-radius:6px;font-size:11px;font-weight:600}.mode-selector-light{display:flex;width:100%;background-color:#e9ecef;border-radius:8px;padding:3px;gap:3px}.mode-btn-light{flex-grow:1;background:transparent;color:#495057;border:none;padding:6px 8px;border-radius:6px;cursor:pointer;transition:background-color .2s,color .2s,box-shadow .2s;display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;font-weight:500}.mode-btn-light:hover{background-color:#f1f3f5}.mode-btn-light.active{background-color:#fff;color:#212529;font-weight:600;box-shadow:0 1px 3px #0000001a}.styled-slider-light{-webkit-appearance:none;width:100%;height:6px;background:linear-gradient(to right,#007aff 50%,#d1d1d6 50%);border-radius:3px;outline:none;padding:0;margin:0;cursor:pointer}.styled-slider-light::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:#fff;border-radius:50%;cursor:pointer;border:1px solid #ced4da;box-shadow:0 1px 3px #00000026;margin-top:-5px}.styled-slider-light::-moz-range-thumb{width:16px;height:16px;background:#fff;border-radius:50%;cursor:pointer;border:1px solid #ced4da;box-shadow:0 1px 3px #00000026}.color-picker-wrapper-light{position:relative;width:28px;height:28px;border-radius:8px;overflow:hidden;border:1px solid #dee2e6;cursor:pointer}.color-picker-wrapper-light input[type=color]{position:absolute;top:-5px;left:-5px;width:40px;height:40px;opacity:0;cursor:pointer}.color-swatch-light{width:100%;height:100%;pointer-events:none}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-cyrillic-ext-400-normal-Dc4VJyIJ.woff2) format("woff2"),url(/assets/inter-cyrillic-ext-400-normal-BPnxn4xp.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-cyrillic-400-normal-BLGc9T1a.woff2) format("woff2"),url(/assets/inter-cyrillic-400-normal-ZzOtrSSW.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-greek-ext-400-normal-Bput3-QP.woff2) format("woff2"),url(/assets/inter-greek-ext-400-normal-DCpCPQOf.woff) format("woff");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-greek-400-normal-DxZsaF_h.woff2) format("woff2"),url(/assets/inter-greek-400-normal-BZzXV7-1.woff) format("woff");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-vietnamese-400-normal-DMkecbls.woff2) format("woff2"),url(/assets/inter-vietnamese-400-normal-BUNmGMP1.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-latin-ext-400-normal-hnt3BR84.woff2) format("woff2"),url(/assets/inter-latin-ext-400-normal-C1t-h-pH.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-latin-400-normal-BOOGhInR.woff2) format("woff2"),url(/assets/inter-latin-400-normal-gitzw0hO.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-cyrillic-ext-500-normal-BShVwWPj.woff2) format("woff2"),url(/assets/inter-cyrillic-ext-500-normal-CUiC4oBV.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-cyrillic-500-normal-D4Vwzodn.woff2) format("woff2"),url(/assets/inter-cyrillic-500-normal-DH2hs3aW.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-greek-ext-500-normal-B6guLgqG.woff2) format("woff2"),url(/assets/inter-greek-ext-500-normal-M2hEX8vc.woff) format("woff");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-greek-500-normal-CeQXL5ds.woff2) format("woff2"),url(/assets/inter-greek-500-normal-d_eO-yCQ.woff) format("woff");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-vietnamese-500-normal-DOriooB6.woff2) format("woff2"),url(/assets/inter-vietnamese-500-normal-DQPw2Hwd.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-latin-ext-500-normal-CIS2RHJS.woff2) format("woff2"),url(/assets/inter-latin-ext-500-normal-UMdmhHu2.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-latin-500-normal-D2bGa7uu.woff2) format("woff2"),url(/assets/inter-latin-500-normal-deR1Tlfd.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-cyrillic-ext-700-normal-ClVoMEGq.woff2) format("woff2"),url(/assets/inter-cyrillic-ext-700-normal-Ced3hgUT.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-cyrillic-700-normal-bGtGjVdZ.woff2) format("woff2"),url(/assets/inter-cyrillic-700-normal-Bc8_fv8J.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-greek-ext-700-normal-SzCdnevJ.woff2) format("woff2"),url(/assets/inter-greek-ext-700-normal-DXvzx4Na.woff) format("woff");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-greek-700-normal-Cxpycf-U.woff2) format("woff2"),url(/assets/inter-greek-700-normal-BRYTaFLL.woff) format("woff");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-vietnamese-700-normal-CGpBpxLq.woff2) format("woff2"),url(/assets/inter-vietnamese-700-normal-dAnkLlTo.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-latin-ext-700-normal-CzikT_rs.woff2) format("woff2"),url(/assets/inter-latin-ext-700-normal-6V9MnIL5.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-latin-700-normal-Sckx8rpT.woff2) format("woff2"),url(/assets/inter-latin-700-normal-B8MtJ_2k.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}.dashboard-container{width:100%;height:100vh;position:relative;background:#fff9f7;overflow:hidden;font-family:Inter,sans-serif}.dashboard-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;background-image:url(/assets/cool-bg-CTu18Ac7.png),repeating-linear-gradient(to right,rgba(0,0,0,.2) 0px,rgba(0,0,0,.2) 1px,transparent 1px,transparent 10px),repeating-linear-gradient(to bottom,rgba(0,0,0,.2) 0px,rgba(0,0,0,.2) 1px,transparent 1px,transparent 10px);background-size:cover;background-position:center;background-repeat:no-repeat}.dashboard-content-wrapper{position:relative;z-index:1;display:flex;flex-direction:column;height:100%}.dashboard-header{height:55px;padding:0 28px;display:flex;align-items:center;justify-content:space-between;background:#fff9f754;box-shadow:0 -14px 42px -12px #e3d6ff0f inset;border-radius:48px;border:5px rgba(244,238,241,255) solid;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);margin:26px 28px 0;position:relative;z-index:50}#auto-logo,.dashboard-logo{height:32px}.dashboard-nav{display:flex;gap:12px;align-items:center}.nav-item{height:40px;padding:0 20px;display:flex;align-items:center;justify-content:center;background:#faf5f333;box-shadow:0 0 16px 1px #fffc inset;border-radius:48px;-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px);color:#0f3047;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease}.nav-item.active{background:#0f3047;color:#e1f3ff}.dashboard-user{width:40px;height:40px;border-radius:50%;overflow:hidden;cursor:pointer}.dashboard-main{display:flex;flex:1;margin:14px 28px;gap:15px}.sidebar{width:194px;background:#fff9f754;box-shadow:0 -14px 42px -12px #e3d6ff0f inset;border-radius:48px;border:5px rgba(244,238,241,255) solid;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:15px 0;display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{background:#0f3047;box-shadow:0 0 16px 1px #fffc inset;border-radius:48px;height:59.46px;width:171px;margin:0 auto;display:flex;align-items:center;justify-content:center}.sidebar-header-text{color:#e1f3ff;font-size:20px;font-weight:500;text-align:center}.sidebar-section{margin-top:20px;padding:0 15px}.sidebar-section-title{color:#0f3047;font-size:16px;font-weight:500;margin-bottom:10px;padding-left:10px}.sidebar-divider{height:1px;background:#ccc;outline:none;margin:15px}.sidebar-item{display:flex;align-items:center;padding:8px 10px 8px 15px;margin:2px 0;color:#0f3047;font-size:14px;font-weight:400;cursor:pointer;position:relative;border-radius:6px;transition:background-color .2s ease}.sidebar-item:hover{background-color:#0f30470d}.sidebar-item-placeholder{padding:8px 15px;font-size:13px;color:#777;font-style:italic}.content-area{flex:1;background:#fff9f754;box-shadow:0 0 16px 1px #fffc inset;border-radius:48px;border:5px rgba(244,238,241,255) solid;-webkit-backdrop-filter:blur(50px);backdrop-filter:blur(50px);padding:20px 30px;overflow-y:auto}.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.add-design-button{background:#0f3047;box-shadow:0 3px 5px -1px #0003;border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid white;color:#fff;transition:background-color .2s}.add-design-button:hover{background-color:#1a4361}.content-divider{height:1px;background:#ccc;outline:none;margin:15px 0 20px}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}.project-card-container{position:relative}.project-card-more-actions{position:absolute;top:8px;right:8px;background-color:#ffffffd9;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:3;border:1px solid rgba(0,0,0,.05);padding:0;box-shadow:0 1px 4px #0000001f;transition:background-color .2s,box-shadow .2s}.project-card-more-actions:hover{background-color:#f5f5f5f2;box-shadow:0 2px 6px #00000026}.project-card-more-actions svg{color:#0f3047;font-size:18px}.project-card-dropdown-menu{position:absolute;top:42px;right:8px;background-color:var(--bg-global-app);border-radius:10px;box-shadow:0 5px 15px #0000001a,0 2px 5px #0000000d;z-index:10;width:140px;padding:6px;border:1px solid #E0E0E0;display:flex;flex-direction:column;gap:4px;animation:fadeInScaleUp .15s ease-out forwards}@keyframes fadeInScaleUp{0%{opacity:0;transform:translateY(-5px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.dropdown-menu-item{background-color:transparent;border:none;padding:9px 12px;text-align:left;font-size:14px;font-weight:500;color:var(--app-text-dark, #333);cursor:pointer;display:flex;align-items:center;gap:10px;border-radius:6px;width:100%;transition:background-color .15s ease,color .15s ease}.dropdown-menu-item:hover{background-color:#0f30470d;color:var(--app-primary-color, #0F3047)}.dropdown-menu-item.delete-action{color:#d32f2f}.dropdown-menu-item.delete-action:hover{background-color:#d32f2f14;color:#b71c1c}.dropdown-menu-item.delete-action:hover svg{color:#b71c1c!important}.dropdown-menu-item svg{font-size:16px;transition:color .15s ease}.project-card{background:#fff9f766;box-shadow:0 -14px 42px -12px #e3d6ff0f inset,0 2px 5px #0000000d;border-radius:16px;border:1px solid white;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);overflow:hidden;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;height:100px}.project-card:hover{transform:translateY(-4px);box-shadow:0 -14px 42px -12px #e3d6ff0f inset,0 6px 12px #0000001a}.project-info{padding:15px;text-align:center;flex-grow:1;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}.project-title{color:#0f3047;font-size:16px;font-weight:600;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-dates{color:#8ea0ac;font-size:11px;font-weight:400;line-height:1.2;margin-top:2px}.favorite-toggle{position:absolute;top:12px;right:12px;background:#ffffffb3;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;border:none;padding:0;box-shadow:0 1px 2px #0000001a;transition:background-color .2s}.favorite-toggle:hover{background-color:#e6e6e6e6}.delete-project-button{position:absolute;top:12px;right:48px;background:#ffffffb3;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;border:none;padding:0;box-shadow:0 1px 2px #0000001a;transition:background-color .2s}.delete-project-button:hover{background-color:#f5dedee6}.delete-project-button svg{font-size:13px}.create-project-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-content{background:#fff9f7;border-radius:16px;padding:25px 30px;width:400px;max-width:90%;box-shadow:0 5px 15px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:10px;border-bottom:1px solid #eee}.modal-title{color:#0f3047;font-size:20px;font-weight:600}.close-modal{background:none;border:none;font-size:28px;cursor:pointer;color:#aaa;padding:0;line-height:1;transition:color .2s}.close-modal:hover{color:#333}.form-group{margin-bottom:20px}.form-label{display:block;color:#0f3047;font-size:14px;font-weight:500;margin-bottom:6px}.form-input{width:100%;padding:10px 15px;border-radius:8px;border:1px solid #ccc;background:#fff;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-input:focus{border-color:#0f3047;box-shadow:0 0 0 2px #0f30471a;outline:none}.form-buttons{display:flex;justify-content:flex-end;gap:10px;margin-top:25px}.cancel-button,.create-button{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s,border-color .2s,color .2s}.cancel-button{border:1px solid #ccc;background:transparent;color:#555}.cancel-button:hover{background-color:#f8f8f8;border-color:#bbb}.create-button{border:none;background:#0f3047;color:#e1f3ff}.create-button:hover{background:#1a4361}.create-button:disabled{background-color:#ccc;cursor:not-allowed;opacity:.7}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:#fff9f7;position:absolute;top:0;left:0;width:100%;z-index:2000}.user-menu-container{position:relative}.dashboard-user-button{width:40px;height:40px;border-radius:50%;background-color:#faf5f34d;border:1px solid rgba(255,255,255,.7);box-shadow:0 0 10px -2px #fff9 inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;color:#0f3047;transition:background-color .2s ease}.dashboard-user-button:hover{background-color:#faf5f380}.user-avatar-image{width:100%;height:100%;border-radius:50%;object-fit:cover}.user-email-display{padding:8px 12px;font-size:13px;color:#555;border-bottom:1px solid #eee;margin-bottom:4px;word-break:break-all}.user-dropdown-menu{position:absolute;top:44px;right:-23px;-webkit-backdrop-filter:blur(8px);position:relative;overflow:hidden;background:#fff9f7d4;box-shadow:0 5px 40px #0000001a,0 100px 80px #e8853212,0 41.7776px 33.4221px #0000000d,0 12.5216px 10.0172px #7190af09,0 22.3363px 17.869px #7190af0b,0 6.6501px 5.32008px #00000007,0 2.76726px 2.21381px #00000005,inset 0 -28px 84px -24px #e2e8ff80,inset 0 0 2px 2px #ffe1dc,inset 0 0 8px 5px #edf7e966,inset 0 0 16px 1px #fffc;backdrop-filter:blur(9px);border-radius:48px;width:220px;padding:25px}.user-dropdown-header{padding:0 16px;font-size:16px;font-weight:500;color:#0f3047;margin-bottom:8px}.user-dropdown-item{display:flex;align-items:center;justify-content:space-between;background:#fff9f7e6;box-shadow:0 -14px 42px -12px #e3d6ff0f inset,0 2px 5px #0000000d;border-radius:16px;border:1px solid white;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:12px 20px;margin:8px 0;width:100%;box-sizing:border-box;color:#0f3047;font-size:16px;font-weight:600;text-decoration:none;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.user-dropdown-item:hover{transform:translateY(-2px);box-shadow:0 -14px 42px -12px #e3d6ff0f inset,0 6px 12px #0000001a}.user-dropdown-item svg{margin-right:10px;color:#0f3047}.user-dropdown-item.sign-out-button:hover{background-color:#f5dedee6;color:#d32f2f}.user-dropdown-item.sign-out-button:hover svg{color:#d32f2f}.sidebar-item{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.initials-avatar{width:100%;height:100%;background-color:#0f3047;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:500;text-transform:uppercase;width:32px;height:32px;border-radius:50%;object-fit:cover}.project-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:#fff9f7;position:fixed;top:0;left:0;width:100%;z-index:9999}.loading-spinner{width:50px;height:50px;border:5px solid rgba(15,48,71,.2);border-radius:50%;border-top-color:#0f3047;animation:spin 1s ease-in-out infinite;margin-bottom:20px}.loading-container p{font-family:Inter,sans-serif;font-size:16px;color:#0f3047;font-weight:500}.auth-container{display:flex;align-items:center;justify-content:center;width:100%;max-width:550px;padding:20px;font-family:Inter,sans-serif;position:relative}.login-background{width:100vw;height:100vh;background-size:cover;background-position:center;background-repeat:no-repeat;position:fixed;top:0;left:0;display:flex;align-items:center;justify-content:center;overflow:auto}.auth-card{padding:40px;box-shadow:0 20px 40px -12px #00000014,0 0 0 1px #fff9f780;width:100%;text-align:center;-webkit-backdrop-filter:blur(8px);position:relative;overflow:hidden;background:#fff9f754;box-shadow:0 5px 40px #0000001a,0 100px 80px #e8853212,0 41.7776px 33.4221px #0000000d,0 12.5216px 10.0172px #7190af09,0 22.3363px 17.869px #7190af0b,0 6.6501px 5.32008px #00000007,0 2.76726px 2.21381px #00000005,inset 0 -28px 84px -24px #e2e8ff80,inset 0 0 2px 2px #ffe1dc,inset 0 0 8px 5px #edf7e966,inset 0 0 16px 1px #fffc;backdrop-filter:blur(9px);border-radius:48px}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ffffff1a,#fff0);pointer-events:none;border-radius:24px}.auth-logo{width:100px;height:auto;margin-bottom:20px}.auth-card h2{margin-bottom:25px;color:#0f3047;font-size:24px;font-weight:600}.form-group{margin-bottom:20px;text-align:left}.form-group label{display:block;margin-bottom:8px;color:#334155;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px 15px;border:1px solid #CBD5E1;border-radius:8px;font-size:15px;color:#0f3047;background-color:#fff;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus{border-color:#0f3047;box-shadow:0 0 0 3px #0f30471a;outline:none}.auth-button{width:100%;padding:12px;background-color:#0f3047;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s ease;margin-top:10px}.auth-button:hover{background-color:#1a4361}.auth-button:disabled{background-color:#94a3b8;cursor:not-allowed}.google-auth-button{width:100%;padding:12px;background-color:#fff;color:#334155;border:1px solid #CBD5E1;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s ease,border-color .2s ease;margin-top:15px;display:flex;align-items:center;justify-content:center;gap:8px}.google-auth-button:hover{background-color:#f8fafc;border-color:#94a3b8}.google-auth-button:disabled{background-color:#e2e8f0;color:#94a3b8;cursor:not-allowed}.auth-switch{margin-top:25px;font-size:14px;color:#475569}.auth-switch a{color:#0f3047;font-weight:500;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.inline-message{margin-bottom:.75rem;font-family:Inter,sans-serif;color:#c62828;text-align:center}.toast-notification{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:1000;padding:16px 24px;border-radius:8px;box-shadow:0 4px 12px #00000026;font-size:14px;font-weight:500;animation:slideDown .3s ease-out;max-width:90vw;text-align:center}@keyframes slideDown{0%{transform:translate(-50%) translateY(-100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.toast-error{background-color:#ef4444;color:#fff}.toast-info{background-color:#3b82f6;color:#fff}.loading-spinner{width:50px;height:50px;border:4px solid rgba(15,48,71,.2);border-top-color:#0f3047;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}.auth-container-standalone{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:#fff9f7;padding:20px;font-family:Inter,sans-serif}.account-screen-container{position:relative;width:100%;height:100vh;overflow:hidden;background:#fff9f7;font-family:Inter,sans-serif}.account-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;background-image:url(/assets/cool-bg-CTu18Ac7.png),repeating-linear-gradient(to right,rgba(0,0,0,.2) 0px,rgba(0,0,0,.2) 1px,transparent 1px,transparent 10px),repeating-linear-gradient(to bottom,rgba(0,0,0,.2) 0px,rgba(0,0,0,.2) 1px,transparent 1px,transparent 10px);background-repeat:no-repeat,repeat-x,repeat-y;background-size:cover,auto,auto;background-position:center center,left top,left top}.account-content-wrapper{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.account-card{padding:40px;box-shadow:0 20px 40px -12px #00000014,0 0 0 1px #fff9f780;width:100%;-webkit-backdrop-filter:blur(8px);position:relative;overflow:hidden;background:#fff9f754;box-shadow:0 5px 40px #0000001a,0 100px 80px #e8853212,0 41.7776px 33.4221px #0000000d,0 12.5216px 10.0172px #7190af09,0 22.3363px 17.869px #7190af0b,0 6.6501px 5.32008px #00000007,0 2.76726px 2.21381px #00000005,inset 0 -28px 84px -24px #e2e8ff80,inset 0 0 2px 2px #ffe1dc,inset 0 0 8px 5px #edf7e966,inset 0 0 16px 1px #fffc;backdrop-filter:blur(9px);border-radius:48px;max-width:480px;width:90%;text-align:center}.account-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;margin:16px auto;border:4px solid white;box-shadow:0 2px 5px #0000001a}.user-name{font-size:20px;font-weight:600;color:#0f3047;margin-bottom:24px}.account-logo{width:80px;margin-bottom:24px}.content-title{color:#0f3047;font-size:24px;font-weight:500}.account-info{text-align:left;background:#ffffffb3;border-radius:8px;padding:16px;margin-bottom:32px}.account-info p{margin:8px 0;font-size:15px;color:#334155;word-break:break-all}.account-info p strong{color:#0f3047}.account-actions{display:flex;flex-direction:column;gap:16px}.account-button{padding:12px;border:none;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s;box-shadow:0 2px 5px #0000001a}.account-button:active{transform:translateY(1px)}.manage-subscription-button{background-color:#0f3047;color:#fff}.manage-subscription-button:hover{background-color:#0f3047;color:#359fec}.sign-out-button-alt{background-color:#0f3047;color:#fff}.sign-out-button-alt:hover{background-color:#f5dedee6;color:#d32f2f}.back-dashboard-button{background-color:#0f3047;color:#fff}.back-dashboard-button:hover{background-color:#0f3047;color:#359fec}.measurement-editor{position:absolute;background-color:#fff;border-radius:8px;box-shadow:0 10px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border:1px solid #E5E7EB;min-width:280px;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #E5E7EB}.editor-header h4{margin:0;font-size:.875rem;font-weight:600;color:#1f2937;text-transform:uppercase;letter-spacing:.025em}.modified-indicator{color:#f59e0b;font-size:.75rem}.editor-content{padding:1.25rem}.input-group{display:flex;gap:.5rem;margin-bottom:.75rem}.measurement-input{width:80px;flex:1;padding:.625rem .875rem;border:2px solid #E5E7EB;border-radius:6px;font-size:1rem;font-weight:500;color:#1f2937;transition:border-color .2s}.measurement-input:focus{outline:none;background:#e5e7eb;border-color:#007aff;box-shadow:0 0 0 3px #007aff1a}.measurement-input.error{border-color:#ef4444}.measurement-input.error:focus{box-shadow:0 0 0 3px #ef44441a}.unit-select{padding:.625rem 2rem .625rem .875rem;border:2px solid #E5E7EB;border-radius:6px;font-size:.875rem;font-weight:500;color:#1f2937;background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24'%3E%3Cpath stroke='%236B7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;background-size:1.25rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:border-color .2s}.unit-select:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 3px #007aff1a}.error-message{font-size:.75rem;color:#ef4444;margin-top:.375rem;margin-bottom:.75rem}.original-value{font-size:.75rem;color:#6b7280;display:flex;align-items:center;gap:.25rem}.scale-info{color:#9ca3af}.editor-actions{display:flex;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid #E5E7EB;background-color:#f9fafb;border-radius:0 0 8px 8px}.cancel-btn,.save-btn{flex:1;padding:.625rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.cancel-btn{background-color:#fff;color:#374151;border:1px solid #D1D5DB}.cancel-btn:hover{background-color:#f9fafb;border-color:#9ca3af}.save-btn{background-color:#007aff;color:#fff;border:none}.save-btn:hover:not(:disabled){background-color:#0051d5}.save-btn:disabled{background-color:#d1d5db;cursor:not-allowed}@media (prefers-color-scheme: dark){.measurement-editor{background-color:#1f2937;border-color:#374151}.editor-header{border-bottom-color:#374151}.editor-header h4{color:#f9fafb}.measurement-input,.unit-select{background-color:#111827;border-color:#374151;color:#f9fafb}.measurement-input:focus,.unit-select:focus{border-color:#3b82f6}.original-value{color:#9ca3af}.editor-actions{background-color:#111827;border-top-color:#374151}.cancel-btn{background-color:#1f2937;color:#f9fafb;border-color:#374151}.cancel-btn:hover{background-color:#374151}}@media (max-width: 480px){.measurement-editor{min-width:240px;left:50%!important;transform:translate(-50%)}.editor-header{padding:.875rem 1rem}.editor-content{padding:1rem}.editor-actions{padding:.875rem 1rem}}.review-adjust-container{display:flex;flex-direction:column;height:100vh;background-color:#f9fafb;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.review-adjust-header{background-color:#fff;border-bottom:1px solid #E5E7EB;padding:1rem 2rem;box-shadow:0 1px 2px #0000000d}.review-adjust-header h1{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0 0 .5rem}.header-info{display:flex;gap:1.5rem;font-size:.875rem;color:#6b7280}.project-name{font-weight:500;color:#374151}.measurement-count{color:#6b7280}.review-adjust-content{flex:1;display:flex;overflow:hidden}.canvas-container{flex:1;position:relative;background-color:#fff;border-radius:8px;margin:1rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;overflow:hidden}.controls-panel{width:320px;background-color:#fff;margin:1rem 1rem 1rem 0;border-radius:8px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;padding:1.5rem;overflow-y:auto}.controls-section{margin-bottom:2rem}.controls-section:last-child{margin-bottom:0}.controls-section h3{font-size:.875rem;font-weight:600;color:#374151;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.025em}.scale-controls{display:flex;align-items:center;gap:.75rem}.scale-slider{flex:1;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#e5e7eb;border-radius:3px;outline:none}.scale-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:#003049;border:2px solid #FFFFFF;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;transition:transform .2s}.scale-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.scale-slider::-moz-range-thumb{width:20px;height:20px;background:#003049;border:2px solid #FFFFFF;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;transition:transform .2s}.scale-slider::-moz-range-thumb:hover{transform:scale(1.1)}.scale-input{width:70px;padding:.375rem .5rem;border:1px solid #D1D5DB;border-radius:6px;font-size:.875rem;text-align:center;transition:border-color .2s}.scale-input:focus{outline:none;border-color:#003049;box-shadow:0 0 0 3px #007aff1a}.scale-label{font-size:.875rem;color:#6b7280;margin-left:-.25rem}.scale-hint{font-size:.75rem;color:#9ca3af;margin-top:.5rem;margin-bottom:0}.action-buttons{display:flex;flex-direction:column;gap:.75rem}.action-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border:1px solid #D1D5DB;border-radius:6px;background-color:#fff;font-size:.875rem;font-weight:500;color:#374151;cursor:pointer;transition:all .2s}.action-btn:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn svg{width:16px;height:16px}.undo-btn:hover:not(:disabled){border-color:#003049;color:#003049}.redo-btn:hover:not(:disabled){border-color:#003049;color:#003049}.reset-btn:hover:not(:disabled){border-color:#ef4444;color:#ef4444}.stats-grid{display:grid;gap:1rem}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:#f9fafb;border-radius:6px}.stat-label{font-size:.875rem;color:#6b7280}.stat-value{font-size:1.125rem;font-weight:600;color:#1f2937}.review-adjust-footer{background-color:#fff;border-top:1px solid #E5E7EB;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 -1px 2px #0000000d}.footer-btn{padding:.75rem 1.5rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.secondary-btn{background-color:#fff;color:#374151;border:1px solid #D1D5DB}.secondary-btn:hover{background-color:#f9fafb;border-color:#9ca3af}.primary-btn{background-color:#003049;color:#fff;border:none}.primary-btn:hover:not(:disabled){background-color:#0051d5}.primary-btn:disabled{background-color:#d1d5db;cursor:not-allowed}.review-adjust-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:#f9fafb}.review-adjust-header{display:flex;justify-content:space-between;align-items:center}.header-actions{display:flex;align-items:center;gap:1rem}.unit-toggle-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#f0f0f0;border:1px solid #ccc;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;color:#333}.unit-toggle-button:hover{background-color:#e0e0e0}.unit-toggle-button svg{margin-right:.25rem}.loading-spinner{width:48px;height:48px;border:3px solid #E5E7EB;border-top-color:#003049;border-radius:50%;animation:spin 1s linear infinite}.review-adjust-loading p{margin-top:1rem;color:#6b7280;font-size:.875rem}@media (max-width: 1280px){.controls-panel{width:280px}}@media (max-width: 768px){.review-adjust-content{flex-direction:column}.controls-panel{width:100%;margin:0 1rem 1rem;max-height:300px}.canvas-container{min-height:400px}.review-adjust-header{padding:1rem}.review-adjust-footer{padding:1rem;flex-direction:column-reverse;gap:.75rem}.footer-btn{width:100%}}@media (max-width: 480px){.review-adjust-header h1{font-size:1.25rem}.header-info{flex-direction:column;gap:.25rem}.scale-controls{flex-wrap:wrap}.scale-slider{width:100%;order:2;margin-top:.5rem}}:root{--color-primary-action: #0e3147;--color-primary-action-text: #fff;--color-secondary-action: #28a745;--color-secondary-action-text: #fff;--color-text-dark: #242424;--color-text-medium: #333;--color-text-light: #666;--color-icon: #0e3147;--bg-global-app: #FFF9F7;--color-toolbar-icon: #0F3047;--color-toolbar-button-active-bg: rgba(0, 102, 255, .15);--color-toolbar-button-active-border: rgba(0, 102, 255, .5);--color-toolbar-indicator: #0066ff;--color-status-indicator-bg: #f1f8ff;--color-status-indicator-border: #b4d2ff;--color-status-indicator-text: #0e3147;--color-toast-bg: rgba(14, 49, 71, .9);--color-toast-text: #fff;--color-error: #EF4444;--color-error-bg: rgba(239, 68, 68, .1);--color-white: #fff;--color-black: #000;--color-grey-light: #f9f9f9;--color-grey-medium: #ccc;--color-grey-dark: #666;--color-transparent: transparent;--bg-sketch-screen: visible;--bg-top-header: #f9f7f6;--bg-main-drawing-area: #fff;--bg-toolbar-button: #fefdfe;--bg-toolbar-button-hover: #ddd;--bg-toolbar-glass-border: rgba(244,238,241,255);--bg-toolbar-radial-top: rgba(248,240,238,255);--bg-toolbar-radial-bottom: rgba(248,240,238,255);--bg-panel-overlay: rgba(255, 255, 255, .7);--border-top-header: 1px solid #f8f2ef;--border-input: 1px solid #ccc;--border-input-focus: 1px solid #0e3147;--border-toolbar: 10px solid var(--bg-toolbar-glass-border);--shadow-toolbar: 0px -14px 42px -12px rgba(227,214,255,.06) inset;--shadow-button-finalize: 0 4px 12px rgba(0, 0, 0, .15);--shadow-button-finalize-hover: 0 4px 8px rgba(0, 0, 0, .1), 0 2px 4px rgba(0,0,0,.07);--shadow-button-finalize-active: 0 1px 2px rgba(0,0,0,.05);--backdrop-filter-toolbar: blur(20px);--height-top-header: 55px;--width-toolbar: 80px;--width-toolbar-button: 50px;--height-toolbar-button: 40px;--border-radius-toolbar: 48px;--border-radius-toolbar-button: 6px;--border-radius-pill: 25px;--padding-header-content: 0 16px;--padding-finalize-button: 10px 20px;--side-panel-expanded-width: 340px;--side-panel-collapsed-width: 40px;--finalize-button-margin: 20px;--finalize-button-top-offset: 70px;--app-primary-color: #0F3047;--app-primary-text-color: #E1F3FF;--app-light-background: #FFFFFF;--app-panel-bg-glassy: rgba(255, 255, 255, .75);--app-panel-border-glassy: rgba(255, 255, 255, .4);--app-panel-shadow-glassy: 0px 8px 30px rgba(0, 0, 0, .08);--app-panel-backdrop-blur: 12px;--app-text-dark: #242424;--app-text-medium: #33475b;--button-border-radius-standard: 6px;--transition-speed: .3s;--app-button-secondary-bg: rgba(240, 245, 250, .7);--app-button-secondary-border: rgba(0, 0, 0, .08);--app-button-secondary-text: var(--app-text-medium);--app-button-secondary-hover-bg: rgba(230, 235, 240, .85);--app-button-secondary-active-bg: var(--app-primary-color);--app-button-secondary-active-text: var(--app-primary-text-color)}body,#root{color:"#0F3047";font-family:Inter,sans-serif;background-color:var(--bg-global-app)}p,h1,h2,h3,h4,h5,h6,span,div{color:"#0F3047";font-family:Inter,sans-serif}input,textarea,select{width:100%;padding:8px 12px;margin-bottom:10px;border-radius:23px;border:2px white solid;background:radial-gradient(ellipse 70.71% 70.71% at 50% 50%,#7692ff00 81%,#7a96ff05),radial-gradient(ellipse 70.71% 70.71% at 50% 50%,#e2e8ff00 34%,#e2e8ff08),linear-gradient(180deg,#e3d6ff00,#ffdec31f),#fff9f740;box-shadow:0 -14px 42px -12px #e3d6ff0f inset;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);font-family:inherit;color:inherit;outline:none;box-sizing:border-box}textarea{resize:vertical}label{display:block;margin-bottom:5px;font-weight:700}button{background:var(--background-paper-elevation-6, white);box-shadow:0 3px 5px -1px #0003;border-radius:10px;margin:2px;border:none;overflow:hidden;display:inline-flex;justify-content:center;align-items:center;vertical-align:middle;padding:8px 16px;color:#0f3047;font-family:inherit;font-size:inherit;font-weight:500;text-align:center;text-decoration:none;cursor:pointer;transition:background-color .2s ease-in-out,box-shadow .2s ease-in-out;-webkit-appearance:none;-moz-appearance:none;appearance:none}button:hover{box-shadow:0 4px 8px -1px #00000040}button:focus-visible{outline:2px solid #0F3047;outline-offset:2px;box-shadow:0 4px 8px -1px #00000040}button:disabled{background:#e0e0e0;color:#a0a0a0;box-shadow:0 1px 3px #0000001f;cursor:not-allowed}button>svg,button>img{width:1.2em;height:1.2em;vertical-align:middle}button>svg:not(:only-child),button>img:not(:only-child){margin-right:8px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:#fff9f7}.loading-spinner{width:50px;height:50px;border:5px solid rgba(244,238,241,.8);border-radius:50%;border-top-color:#0f3047;animation:spin 1s ease-in-out infinite;margin-bottom:20px}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{font-family:Inter,sans-serif;font-size:18px;color:#0f3047;font-weight:500}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:#fff9f7;text-align:center;padding:20px}.error-container p{font-family:Inter,sans-serif;font-size:18px;color:#0f3047;font-weight:500;margin-bottom:20px}.back-button{background-color:#0f3047;color:#e1f3ff;border:none;padding:10px 20px;border-radius:8px;font-family:Inter,sans-serif;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.back-button:hover{background-color:#1a4361}.group-tree-container{padding:5px;max-height:calc(100vh - 250px);overflow-y:auto;margin-top:5px}.group-node-container{margin-bottom:3px}.group-node-row{display:flex;align-items:center;justify-content:space-between;padding:4px 6px;border-radius:4px;cursor:pointer;transition:background-color .15s ease-in-out}.group-node-row:hover{background-color:#f0f4f8}.group-node-row.selected{background-color:#e0eaf5;font-weight:500}.group-node-info{display:flex;align-items:center;gap:6px;flex-grow:1;min-width:0}.group-node-color-indicator{width:14px;height:14px;border-radius:3px;border:1px solid rgba(0,0,0,.2);flex-shrink:0}.group-node-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-node-details{font-size:11px;color:#555;margin-top:-2px;padding-bottom:2px}.group-node-actions{display:flex;align-items:center;gap:2px;flex-shrink:0;opacity:0;transition:opacity .15s ease-in-out}.group-node-row:hover .group-node-actions,.group-node-row.selected .group-node-actions{opacity:1}.group-action-button{background:none;border:none;padding:2px 4px;margin:0;cursor:pointer;color:#555;border-radius:3px;display:flex;align-items:center;justify-content:center}.group-action-button:hover{background-color:#0000001a;color:#111}.group-action-button.delete:hover{color:#d9534f;background-color:#d9534f1a}.group-node-form{display:flex;flex-grow:1;align-items:center}.group-node-input{font-size:13px;padding:2px 4px;border:1px solid #a0b0c0;border-radius:3px;flex-grow:1;height:22px;min-width:50px}.group-node-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 1px #3498db}.add-root-form-container{padding:5px 10px;border-bottom:1px solid #eee}.add-root-group-button{background:none;border:1px solid transparent;color:#0e3147;padding:3px 6px;margin:0 5px;font-size:12px;font-weight:500;cursor:pointer;border-radius:4px;display:flex;align-items:center;gap:4px}.add-root-group-button:hover{background-color:#0000000d;border-color:#0000001a}.empty-groups-message{padding:10px;text-align:center;color:#777;font-size:13px}.fabric-library-panel .panel-header{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-bottom:1px solid rgba(0,0,0,.05);height:45px;box-sizing:border-box}.fabric-library-panel .panel-title{font-size:15px;font-weight:600;color:#0e3147}.panel-toggle-button{background-color:#fff;color:#0e3147;border:1px solid #ccc;padding:6px 12px;border-radius:5px;cursor:pointer;font-size:13px;font-weight:500;box-shadow:0 1px 3px #0000001a;transition:background-color .2s ease}.panel-toggle-button:hover{background-color:#f8f8f8}
