.title-bar{background:#fff;padding:15px 20px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.main-tabs{display:flex;gap:10px}.tab{padding:8px 16px;border-radius:16px;cursor:pointer;transition:all .3s;background:#f0f0f0}.tab:hover{background:#e0e0e0}.tab.active{background:#1890ff;color:#fff}.app-title{font-size:18px;font-weight:500;color:#333}.joint-options{margin:15px 0}.joint-buttons{display:flex;gap:15px;margin-top:10px}.joint-btn{display:flex;flex-direction:column;align-items:center;padding:10px 15px;border:1px solid #ddd;background:#fff;border-radius:6px;cursor:pointer;transition:all .2s;min-width:80px;margin-left:65px}.joint-btn:hover{border-color:#4a90e2;background:#f8faff}.joint-btn.active{border-color:#4a90e2;background:#e6f0ff}.joint-btn span{margin-top:6px;font-size:12px;color:#333;font-weight:500}.dimension-inputs{display:flex;justify-content:space-between;gap:20px;margin-bottom:15px}.dimension-input{flex:1}.dimension-input label{display:block;margin-bottom:5px;font-weight:500}.dimension-input input{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px}.window-types-container{height:360px;margin-bottom:15px;overflow-y:auto;padding-right:10px}.window-types-container::-webkit-scrollbar{width:6px}.window-types-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.window-types-container::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.window-types-container::-webkit-scrollbar-thumb:hover{background:#555}.window-types{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.window-type{border:1px solid #ddd;border-radius:4px;padding:10px;cursor:pointer;transition:all .3s;height:150px;display:flex;flex-direction:column}.window-type:hover{border-color:#1890ff;box-shadow:0 2px 4px #0000001a}.window-image{flex:1;display:flex;justify-content:center;align-items:center;margin-bottom:8px}.window-image svg{max-width:100%;max-height:100%}.window-name{text-align:center;font-size:12px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.form-group-inline{display:flex;justify-content:space-between}.form-check{margin-bottom:10px;display:flex;align-items:center;gap:10px}.window-color-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.window-color-popup{background:#fff;padding:20px;border-radius:8px;width:350px;max-width:90%;box-shadow:0 4px 6px #0000001a}.window-color-popup h3{margin-top:0;color:#333;border-bottom:1px solid #eee;padding-bottom:10px}.color-type-selector{margin:15px 0;display:flex;gap:20px}.color-type-selector label{display:flex;align-items:center;gap:5px;cursor:pointer}.color-picker{margin:10px 0;display:flex;align-items:center;gap:10px}.color-picker input[type=color]{width:40px;height:30px;padding:0;border:1px solid #ddd;border-radius:4px;cursor:pointer}.color-picker input[type=text]{width:120px;height:30px;padding:0;border:1px solid #ddd;border-radius:4px;cursor:pointer}.color-preview{margin:20px 0;display:flex;justify-content:center}.preview-box{width:100%;height:50px;border:1px solid #ddd;border-radius:4px}.popup-buttons{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.popup-buttons button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer}.popup-buttons .save-btn{background-color:#4caf50;color:#fff}.popup-buttons .save-btn:hover{background-color:#45a049}.right-panel{width:100%;height:100%;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5}.svg-container{position:absolute;will-change:transform;display:flex;align-items:center;justify-content:center;pointer-events:auto;transform-origin:center center}.svg-content{display:block;margin:auto;pointer-events:auto}.svg-content svg{display:block;max-width:100%;max-height:100%}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .3s ease}.modal-content{background-color:#fff;padding:30px;border-radius:12px;min-width:320px;box-shadow:0 10px 25px #0003;transform:translateY(0);animation:slideUp .3s ease}.modal-content h3{margin-top:0;margin-bottom:20px;color:#333;font-size:1.5rem;font-weight:600;text-align:center;display:flex;align-items:center;justify-content:center}.modal-content h3 svg{color:#4a90e2;margin-right:8px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.input-container{position:relative;display:flex;align-items:center;border:1px solid #ddd;border-radius:6px;transition:all .3s ease}.input-container input{flex:1;width:100%;padding:12px 15px;border:none;border-radius:6px;font-size:1rem;outline:none}.error-message{color:#e74c3c;font-size:.85rem;margin-top:6px;padding-left:2px;display:flex;align-items:center}.modal-buttons{display:flex;justify-content:center;gap:12px;margin-top:20px}.modal-buttons button{padding:10px 20px;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;flex:1}.modal-buttons button svg{margin-right:5px}.modal-buttons .confirm-btn{background-color:#4a90e2;color:#fff}.modal-buttons .confirm-btn:hover{background-color:#3a7bc8}.modal-buttons .cancel-btn{background-color:#f1f1f1;color:#555}.modal-buttons .cancel-btn:hover{background-color:#e5e5e5}.modal-buttons button:active{transform:scale(.98)}.popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .3s ease}.popup-content{background:#fff;padding:30px;border-radius:12px;min-width:320px;box-shadow:0 10px 25px #0003;transform:translateY(0);animation:slideUp .3s ease}.popup-content h3{margin-top:0;margin-bottom:20px;color:#333;font-size:1.5rem;font-weight:600;text-align:center;display:flex;align-items:center;justify-content:center}.popup-content h3 svg{color:#4a90e2}.popup-content form{display:flex;flex-direction:column}.input-container{position:relative;display:flex;align-items:center;margin-bottom:15px;border:1px solid #ddd;border-radius:6px;transition:all .3s ease}.input-container.focused{border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e233}.input-container.error{border-color:#e74c3c;box-shadow:0 0 0 2px #e74c3c1a}.input-container input[type=number]{flex:1;padding:12px 15px;border:none;border-radius:6px;font-size:1rem;outline:none;width:100%}.input-container .unit{padding-right:15px;color:#777;font-size:.9rem}.error-message{color:#e74c3c;font-size:.85rem;margin-bottom:15px;padding-left:2px;display:flex;align-items:center}.error-message:before{content:"⚠️";margin-right:5px}.popup-buttons{margin-top:20px;display:flex;gap:12px;justify-content:center}.popup-buttons button{padding:10px 20px;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.popup-buttons .confirm-btn{background-color:#4a90e2;color:#fff;flex:1}.popup-buttons .confirm-btn:hover{background-color:#3a7bc8}.popup-buttons .cancel-btn{background-color:#f1f1f1;color:#555;flex:1}.popup-buttons .cancel-btn:hover{background-color:#e5e5e5}.popup-buttons button:active{transform:scale(.98)}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.app-container{display:flex;flex-direction:column;height:100vh;width:100vw;background-color:#f5f5f5;overflow:hidden}.content-container{display:flex;flex:1;padding:20px;gap:20px;overflow:hidden}.left-panel{width:450px;background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-y:auto}.right-panel{flex:1;background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:center;align-items:center;overflow:hidden}body{margin:0;padding:0;overflow:hidden}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500}.form-control{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px}.variation-tabs{display:flex;gap:5px;margin-bottom:15px;overflow-x:auto}.variation-tab{padding:8px 12px;background:#f0f0f0;border-radius:4px;cursor:pointer;white-space:nowrap}.variation-tab.active{background:#1890ff;color:#fff}.window-types{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:15px}.window-type{border:1px solid #ddd;border-radius:4px;padding:10px;cursor:pointer;transition:all .3s}.window-type:hover{border-color:#1890ff}.window-type.selected{border-color:#1890ff;background-color:#e6f7ff}.window-image{height:100px;display:flex;justify-content:center;align-items:center;margin-bottom:5px}.window-name{text-align:center;font-size:12px}.joint-options{background:#f9f9f9;padding:15px;border-radius:4px;margin-bottom:15px}.joint-buttons{display:flex;gap:10px;margin-top:10px}.btn{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;transition:all .3s}.btn-blue{background:#1890ff;color:#fff}.btn-blue:hover{background:#40a9ff}.btn-blue.active{background:#096dd9}.button-group{display:flex;gap:10px;margin-top:20px}@media (max-width: 768px){.content-container{flex-direction:column}.left-panel{width:100%}.window-types{grid-template-columns:repeat(3,1fr)}}#chart .apexcharts-legend-series:nth-last-child(-n+4){display:none!important}html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}.context-menu{background:#fff;border:1px solid #e8e8e8;border-radius:4px;box-shadow:0 2px 8px #00000026;padding:4px 0;min-width:120px}.context-menu-item{padding:8px 12px;cursor:pointer;transition:all .3s;font-size:14px;color:#000000d9}.context-menu-item:hover{background-color:#f5f5f5}.context-menu-item:active{background-color:#e6f7ff}.door-details-container{width:100vw;height:100vh;display:flex;flex-direction:column;background-color:#f5f5f5}.top-section{height:40%;padding:20px}.bottom-section{height:60%;padding:0 20px 20px;overflow:hidden;display:flex;flex-direction:column}.door-info,.door-preview{height:100%}.info-card,.preview-card,.table-card{height:100%;display:flex;flex-direction:column}.info-card .ant-card-body,.preview-card .ant-card-body,.table-card .ant-card-body{flex:1;overflow:auto}.info-row{margin-bottom:16px;display:flex;align-items:center;gap:16px}.info-row .ant-typography{display:block;margin-bottom:8px}.dimensions{display:flex;gap:16px;flex-wrap:wrap}.dimension-input{display:flex;align-items:center;gap:8px;min-width:120px}.dimension-input .ant-input-number{width:100px}.svg-container{width:100%;height:100%;display:flex;justify-content:center;align-items:center;overflow:auto}.svg-wrapper{transform:scale(1.5);transform-origin:center;max-width:100%;max-height:100%}.table-card .ant-table{height:100%}.table-card .ant-table-container{height:100%;display:flex;flex-direction:column}.table-card .ant-table-body{flex:1;overflow:auto}.ant-table-row td .ant-upload.ant-upload-select-picture-card:hover{border-color:#1890ff}.category-section{margin-bottom:24px;border:1px solid #f0f0f0;border-radius:8px;overflow:hidden}.category-section h3{margin:0;padding:8px 16px;background:#fafafa;border-bottom:1px solid #f0f0f0;font-size:16px;font-weight:500}.category-section .ant-table{margin:0;border:none;border-radius:0}.category-section .ant-table-tbody>tr:last-child>td{border-bottom:none}.table-card{transition:all .3s ease}.table-card.full-screen{border-radius:0;box-shadow:none}.ant-card-head{position:sticky;top:0;background:#fff;z-index:1;border-bottom:1px solid #f0f0f0}.image-container{width:50px;height:50px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;background-color:#f5f5f5;border-radius:4px}.lazy-image{max-width:100%;max-height:100%;object-fit:contain;opacity:0;transition:opacity .3s ease}.lazy-image.loaded{opacity:1}.image-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5}.spinner{width:20px;height:20px;border:2px solid #e0e0e0;border-top:2px solid #1890ff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.door-info,.door-preview{width:100%;max-width:100%}.dimensions{flex-direction:column;gap:8px}.dimension-input{width:100%}}@media print{body *{visibility:hidden}.invoice-container,.invoice-container *{visibility:visible}.invoice-container{position:absolute;left:0;top:0;width:100%;margin:0;padding:15px;font-size:12px;line-height:1.5}.no-print{display:none!important}}.invoice-container{max-width:1000px;margin:0 auto;padding:20px;background:#fff;box-shadow:0 0 10px #0000001a}.invoice-header{text-align:center;margin-bottom:20px}.invoice-header .ant-typography{margin-bottom:5px}.company-info{margin:15px 0}.customer-info{margin-bottom:20px}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:10px}.invoice-table{width:100%;border-collapse:collapse;margin:15px 0}.invoice-table th,.invoice-table td{border:1px solid #e8e8e8;padding:8px 12px;text-align:left}.invoice-table th{background-color:#f5f5f5;font-weight:600}.invoice-table tbody tr:nth-child(2n){background-color:#fafafa}.invoice-summary{text-align:right;margin:20px 0;padding:15px;background-color:#f9f9f9;border-radius:4px}.total-amount{font-size:1.2em;margin-bottom:10px}.amount-in-words{font-style:italic;margin-top:10px;padding-top:10px;border-top:1px dashed #ddd}.signature-section{display:flex;justify-content:space-between;margin-top:60px;padding-top:20px}.customer-signature,.company-signature{text-align:center;width:200px}.signature-line{border-top:1px solid #333;margin-top:40px;position:relative}.signature-line:after{content:"(Ký, ghi rõ họ tên)";position:absolute;bottom:-20px;left:0;right:0;font-size:11px;color:#666}.print-button{position:fixed;bottom:30px;right:30px;z-index:1000}@media (max-width: 768px){.info-grid{grid-template-columns:1fr}.signature-section{flex-direction:column;align-items:center;gap:30px}.invoice-table{display:block;overflow-x:auto;white-space:nowrap}}#root{max-width:max-content;margin:0 auto;padding:0}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
