.sidebar{height:100vh;background:var(--bg-primary);border-right:1px solid var(--border-color);box-shadow:var(--shadow-base);display:flex;flex-direction:column;overflow:hidden;transition:all var(--transition-base);position:fixed;left:0;top:0;z-index:1000}.sidebar.collapsed{width:80px!important;min-width:80px!important}.logo{padding:var(--spacing-lg);text-align:center;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);min-height:72px;display:flex;align-items:center;justify-content:center}.logo img{width:120px;height:auto;max-height:40px;-o-object-fit:contain;object-fit:contain;transition:all var(--transition-base)}.logo .tac-studio-title{color:#38b6a8!important;font-weight:700;font-size:24px;letter-spacing:1px;margin-left:8px;display:inline-block;vertical-align:middle}.sidebar.collapsed .logo{padding:var(--spacing-md)}.sidebar.collapsed .logo img{width:32px;height:32px}.nav-menu{flex:1;padding:var(--spacing-lg) 0;overflow-y:auto;overflow-x:hidden}.nav-item{display:flex;align-items:center;padding:var(--spacing-md) var(--spacing-lg);margin:var(--spacing-xs) var(--spacing-md);color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-base);transition:all var(--transition-fast);position:relative;font-size:15px;font-weight:500;min-height:44px;white-space:nowrap}.nav-item:hover{background:var(--primary-light);color:var(--primary-color)}.nav-item.active{background:var(--primary-color);color:#fff;font-weight:600;box-shadow:var(--shadow-base)}.nav-item.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:4px;background:#fff;border-radius:2px}.nav-item .anticon{font-size:18px;margin-right:var(--spacing-md);min-width:18px;display:flex;align-items:center;justify-content:center}.sidebar.collapsed .nav-item{justify-content:center;padding:var(--spacing-md);margin:var(--spacing-xs) var(--spacing-sm);position:relative}.sidebar.collapsed .nav-item .anticon{display:inline-flex!important;align-items:center!important;justify-content:center!important;margin-right:0!important;font-size:20px!important;color:var(--text-secondary)!important;visibility:visible!important;opacity:1!important;width:100%!important;height:100%!important}.sidebar.collapsed .nav-item span{display:none}.sidebar.collapsed .nav-item:hover:after{content:attr(title);position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);background:var(--text-primary);color:#fff;padding:4px 12px;border-radius:var(--radius-base);font-size:13px;font-weight:500;white-space:nowrap;z-index:9999;box-shadow:var(--shadow-lg);opacity:.95}.sidebar-settings-bottom{border-top:1px solid var(--border-color);padding:var(--spacing-md) 0;background:var(--bg-secondary)}.sidebar-footer{border-top:1px solid var(--border-color);padding:var(--spacing-md);background:var(--bg-secondary)}.logout-button{width:100%;height:44px;border:none!important;background:transparent!important;color:#ff4d4f!important;display:flex;align-items:center;justify-content:flex-start;padding:0 var(--spacing-md);border-radius:var(--radius-base);font-size:15px;font-weight:500;transition:all var(--transition-fast);cursor:pointer}.logout-button:hover{background:#ff4d4f1a!important;color:var(--error-color)!important}.logout-button .anticon{margin-right:var(--spacing-sm);font-size:16px;color:#ff4d4f!important}.sidebar.collapsed .logout-button{justify-content:center!important;padding:0!important;display:flex!important;align-items:center!important}.sidebar.collapsed .logout-button .anticon{display:inline-flex!important;align-items:center!important;justify-content:center!important;margin-right:0!important;font-size:20px!important;color:#ff4d4f!important;visibility:visible!important;opacity:1!important;width:100%!important;height:100%!important}.sidebar.collapsed .logout-button .anticon{display:inline-flex!important;visibility:visible!important;opacity:1!important;color:#ff4d4f!important}.sidebar.collapsed .logout-button .ant-btn-icon{display:inline-flex!important;visibility:visible!important;opacity:1!important}.sidebar.collapsed .ant-btn.logout-button .anticon{display:inline-flex!important;visibility:visible!important;opacity:1!important;color:#ff4d4f!important;font-size:20px!important}.logout-button.collapsed-logout{justify-content:center!important;padding:0!important;display:flex!important;align-items:center!important;width:100%!important;height:44px!important}.logout-button.collapsed-logout .anticon{display:inline-flex!important;visibility:visible!important;opacity:1!important;color:#ff4d4f!important;font-size:20px!important;margin:0!important;width:auto!important;height:auto!important}.sidebar.collapsed .sidebar-footer .logout-button.collapsed-logout .anticon,.sidebar.collapsed .sidebar-footer .logout-button .anticon{display:inline-flex!important;visibility:visible!important;opacity:1!important;color:#ff4d4f!important;font-size:20px!important;position:relative!important;z-index:1!important}.sidebar.collapsed .logout-button span{display:none}@media (max-width: 768px){.sidebar{width:100%!important;max-width:280px;position:fixed;left:0;top:0;z-index:var(--z-modal);box-shadow:var(--shadow-lg)}.sidebar.collapsed{width:100%!important;max-width:280px}.logo{padding:var(--spacing-lg);min-height:64px}.logo img,.sidebar.collapsed .logo img{width:100px}.nav-item{padding:var(--spacing-md) var(--spacing-lg);font-size:16px;min-height:48px}.nav-item .anticon{font-size:20px;margin-right:var(--spacing-md)}.sidebar.collapsed .nav-item{justify-content:flex-start;padding:var(--spacing-md) var(--spacing-lg)}.sidebar.collapsed .nav-item .anticon{margin-right:var(--spacing-md);font-size:20px}.sidebar.collapsed .nav-item span{display:inline}.logout-button{height:48px;font-size:16px;padding:0 var(--spacing-lg)}.logout-button .anticon{font-size:18px;margin-right:var(--spacing-md);color:#ff4d4f!important}.sidebar.collapsed .logout-button{justify-content:flex-start;padding:0 var(--spacing-lg)}.sidebar.collapsed .logout-button .anticon{margin-right:var(--spacing-md);color:#ff4d4f!important}.sidebar.collapsed .logout-button span{display:inline}}.nav-menu::-webkit-scrollbar{width:4px}.nav-menu::-webkit-scrollbar-track{background:transparent}.nav-menu::-webkit-scrollbar-thumb{background:var(--border-primary);border-radius:var(--radius-sm)}.nav-menu::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.sidebar{transition:width var(--transition-base) cubic-bezier(.4,0,.2,1)}.nav-item{transition:all var(--transition-fast) cubic-bezier(.4,0,.2,1)}.nav-item:hover{transition-duration:.1s}.nav-item:focus{outline:2px solid var(--primary-color);outline-offset:2px}.logout-button:focus{outline:2px solid var(--error-color);outline-offset:2px}@media (prefers-contrast: high){.sidebar{border-right-width:2px}.nav-item.active{border:2px solid white}}.main-layout{min-height:100vh;display:flex;background:var(--bg-layout)}.layout-sider{background:var(--bg-primary);border-right:1px solid var(--border-color);box-shadow:var(--shadow-base);z-index:var(--z-sider);transition:all var(--transition-base);position:fixed;left:0;top:0;height:100vh}.layout-sider.ant-layout-sider-collapsed{width:80px!important;min-width:80px!important}.layout-content{flex:1;display:flex;flex-direction:column;min-height:100vh;background:var(--bg-layout);margin-left:240px;transition:margin-left var(--transition-base)}.layout-content.collapsed{margin-left:80px}.layout-header{background:var(--bg-primary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-base);display:flex;align-items:center;height:64px;padding:0 var(--spacing-lg);position:sticky;top:0;z-index:var(--z-header)}.collapse-btn{font-size:18px;width:40px;height:40px;border-radius:var(--radius-base);color:var(--text-secondary);background:transparent;border:none;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.collapse-btn:hover{background:var(--primary-light);color:var(--primary-color)}.header-title{margin-left:var(--spacing-lg);font-size:22px;font-weight:700;color:var(--primary-color);letter-spacing:.5px}.main-content{flex:1;padding:var(--spacing-xl);background:var(--bg-layout);min-height:calc(100vh - 64px);overflow-x:auto}@media (max-width: 768px){.layout-header{height:56px;padding:0 var(--spacing-md)}.header-title{font-size:18px;margin-left:var(--spacing-md)}.main-content{padding:var(--spacing-md);min-height:calc(100vh - 56px)}}@media (max-width: 768px){.main-layout{position:relative}.layout-sider{position:fixed!important;left:0;top:0;height:100vh;z-index:var(--z-modal);transform:translate(-100%);transition:transform var(--transition-base) cubic-bezier(.4,0,.2,1)}.layout-sider:not(.ant-layout-sider-collapsed){transform:translate(0)}.layout-content{margin-left:0!important;width:100%}.layout-header{padding:0 var(--spacing-md);height:56px;position:fixed;top:0;left:0;right:0;z-index:var(--z-fixed)}.collapse-btn{width:36px;height:36px;font-size:16px}.header-title{font-size:var(--font-size-base);margin-left:var(--spacing-md)}.main-content{margin-top:56px;padding:var(--spacing-sm);min-height:calc(100vh - 56px)}}@media (max-width: 480px){.layout-header{height:48px;padding:0 var(--spacing-sm)}.collapse-btn{width:32px;height:32px;font-size:14px}.header-title{font-size:var(--font-size-sm);margin-left:var(--spacing-sm)}.main-content{margin-top:48px;padding:var(--spacing-xs);min-height:calc(100vh - 48px)}}.mobile-mask{position:fixed;inset:0;background:#00000080;z-index:calc(var(--z-modal) - 1);display:none;transition:opacity var(--transition-base)}.mobile-mask.show{display:block;opacity:1}@keyframes slideIn{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(-100%);opacity:0}}@media (prefers-contrast: high){.layout-header{border-bottom-width:2px}.collapse-btn{border-width:2px}}@media (prefers-reduced-motion: reduce){.layout-sider,.collapse-btn,.mobile-mask{transition:none}}@media (prefers-color-scheme: dark){.main-layout{background:#141414}.layout-header{background:#1f1f1f;border-bottom-color:#303030}.header-title{color:#fff}.collapse-btn{color:#d9d9d9}.collapse-btn:hover{background:#1890ff1a;color:#40a9ff}}.layout{display:flex;min-height:100vh;width:100%;margin:0;padding:0}.settings-button{background:#fff;border:none;box-shadow:0 2px 4px #0000001a}.settings-button:hover{background:#f5f5f5}.header{display:flex;justify-content:flex-end;padding:12px 24px;background:#fff;box-shadow:0 1px 4px #0000000d}.header-right{display:flex;align-items:center}.main-item-total{display:flex;justify-content:flex-end;padding:12px 16px;font-weight:500;border-top:1px solid #f0f0f0}.main-item-total .sub-item-row{background-color:#fafafa}.main-item-total .col-amount strong,.main-item-total .col-cost-amount strong{font-size:14px;color:var(--primary-color)}.total-amount{display:flex;justify-content:flex-end;padding:16px;font-size:16px;font-weight:500;margin-top:16px;border-top:1px solid #f0f0f0}.form-actions,.cost-field{display:none}@media print{.cost-field{display:none!important}}.ant-form-item{margin-bottom:12px}.ant-form-item-label{padding-bottom:4px}.ant-input{height:32px;padding:4px 8px;line-height:24px!important;display:flex!important;align-items:center!important}.ant-card{box-shadow:0 1px 2px #0000000d}.sub-items{padding-left:24px}.main-item-select-modal .ant-modal-content{padding:24px}.main-item-select-modal .ant-modal-body{padding:24px 0}.main-items-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:0 24px;margin-bottom:24px}.main-item-option{height:40px;text-align:left;padding:0 16px;width:100%;background:#fff;border:1px solid #d9d9d9;border-radius:6px;transition:all .3s}.main-item-option:hover:not(.disabled){border-color:var(--primary-color);color:var(--primary-color)}.main-item-option.selected{background:#e6f7ff;border-color:var(--primary-color);color:var(--primary-color)}.main-item-option.disabled{background:#f5f5f5;color:#d9d9d9;cursor:not-allowed}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px 24px 0;margin-top:24px;border-top:1px solid #f0f0f0}.main-item-container{order:var(--item-order)}.section-header{display:flex;align-items:center;margin-bottom:16px}.section-header h2{margin:0 16px 0 0;font-size:18px;font-weight:500}.quotation-form .items-section .sub-items-header,.quotation-form .items-section .sub-item-row{display:grid!important;grid-template-columns:minmax(300px,2fr) 100px 110px 120px 120px 120px 130px 40px!important;gap:4px!important;padding:8px 12px!important;align-items:center!important}.quotation-form .sub-items-header{background:#fafafa;border-bottom:1px solid #f0f0f0}.quotation-form .sub-items-header>div{font-weight:500;color:#333}.quotation-form .sub-item-row{min-height:40px;height:auto;align-items:flex-start;padding:8px 12px}.quotation-form .items-section .col-description{text-align:left;min-width:300px;max-width:none;overflow:visible;height:auto;padding:0}.quotation-form .items-section .col-quantity,.quotation-form .items-section .col-uom{text-align:center}.quotation-form .items-section .col-unit-price,.quotation-form .items-section .col-amount,.quotation-form .items-section .col-unit-cost,.quotation-form .items-section .col-cost-amount{text-align:right}.quotation-form .items-section .sub-item-row .ant-input,.quotation-form .items-section .sub-item-row .ant-input-number{width:100%!important;height:32px!important;border:1px solid #d9d9d9!important;border-radius:2px!important;transition:all .3s!important}.quotation-form .items-section .col-description textarea{width:100%!important;min-height:32px!important;height:auto!important;overflow:hidden!important;resize:none!important;border:none!important;background-color:transparent!important;padding:4px 8px!important;font-family:inherit!important;font-size:inherit!important;line-height:1.5!important;display:block!important}.quotation-form .items-section .col-quantity .ant-input-number{width:100px!important}.quotation-form .items-section .col-quantity .ant-input-number-input{text-align:center!important}.quotation-form .items-section .col-uom .ant-input{width:110px!important;text-align:center!important;text-transform:uppercase!important;line-height:24px!important;height:32px!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:4px 8px!important}.quotation-form .items-section .col-unit-price .ant-input-number,.quotation-form .items-section .col-amount .ant-input-number,.quotation-form .items-section .col-unit-cost .ant-input-number,.quotation-form .items-section .col-cost-amount .ant-input-number{width:120px!important}.quotation-form .items-section .sub-item-row .ant-input:hover,.quotation-form .items-section .sub-item-row .ant-input-number:hover{border-color:var(--primary-color)!important}.quotation-form .items-section .sub-item-row .ant-input:focus,.quotation-form .items-section .sub-item-row .ant-input-number-focused{border-color:var(--primary-color)!important;box-shadow:0 0 0 2px #20b2aa33!important}.quotation-form{width:100%;max-width:100%;padding:24px}.form-header{display:grid;grid-template-columns:2fr 1fr;gap:24px;margin-bottom:32px;width:100%}.client-info{padding-right:24px}.quotation-info{border-left:1px solid #f0f0f0;padding-left:24px}.readonly-field .ant-input{background-color:#f5f5f5;cursor:not-allowed}.quotation-form .items-section .sub-item-row .ant-input-number{width:100%!important;display:flex!important;align-items:center!important}.quotation-form .items-section .sub-item-row .ant-input-number-input{text-align:inherit!important;padding:4px 8px!important;line-height:24px!important;height:24px!important;display:flex!important;align-items:center!important;border:none!important;box-shadow:none!important}.quotation-form .items-section .col-quantity .ant-input-number-input{text-align:center!important;line-height:24px!important;height:24px!important;display:flex!important;align-items:center!important;justify-content:center!important}.quotation-form .items-section .col-unit-price .ant-input-number-input,.quotation-form .items-section .col-amount .ant-input-number-input,.quotation-form .items-section .col-unit-cost .ant-input-number-input,.quotation-form .items-section .col-cost-amount .ant-input-number-input{text-align:right!important;line-height:24px!important;height:24px!important;display:flex!important;align-items:center!important;justify-content:flex-end!important}.add-area-button,.add-sub-button,.delete-button{padding:4px!important;height:24px!important;min-width:24px!important;display:flex!important;align-items:center!important;justify-content:center!important}.add-area-button{color:var(--primary-color)!important;font-size:12px!important}.add-sub-button{color:var(--primary-color)!important}.delete-button{color:#ff4d4f!important}.add-area-button:hover,.add-sub-button:hover,.delete-button:hover{background:#0000000a!important}.quotation-form .items-section .ant-input-number .ant-input-number-handler-wrap{display:none!important}.quotation-form .items-section .ant-input-number input[type=number]::-webkit-outer-spin-button,.quotation-form .items-section .ant-input-number input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.quotation-form .items-section .ant-input-number input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.quotation-form .items-section .ant-input-number{width:100%!important;display:flex!important;align-items:center!important}.quotation-form .items-section .ant-input-number-input{text-align:inherit!important;padding:4px 8px!important;line-height:24px!important;height:24px!important;display:flex!important;align-items:center!important;border:none!important;box-shadow:none!important}.main-item-total,.total-amount-section{padding:8px 12px;border-top:1px solid #f0f0f0}.total-grid{display:grid;grid-template-columns:1fr 120px 120px 40px;gap:8px;justify-items:end}.total-label{grid-column:4 / 5;font-weight:500}.total-amount{grid-column:5 / 6;font-weight:500}.total-cost{grid-column:7 / 8;font-weight:500}.total-amount-section{margin-top:16px;border-top:2px solid #f0f0f0;font-size:16px}.total-amount-section .total-grid{font-weight:500}.summary-row,.summary-subtotal,.summary-discount,.summary-total{display:flex;justify-content:space-between;align-items:center;padding:6px 0;min-height:32px;border-bottom:1px solid #f0f0f0;word-break:break-all;white-space:normal}.summary-total{border-bottom:none}.summary-description,.subtotal-description,.discount-description,.total-description{flex:3;text-align:left;font-size:13px;word-break:break-all;white-space:normal}.summary-amount,.subtotal-amount,.discount-amount-input,.total-amount{width:100px;text-align:right;font-size:13px;padding-right:10px;word-break:break-all;white-space:normal}.summary-cost,.subtotal-cost,.discount-cost,.total-cost{width:250px;text-align:right;font-size:13px;color:#555;padding-right:2px;word-break:break-all;white-space:normal}.summary-profit-margin,.subtotal-profit-margin,.discount-profit-margin,.total-profit{width:90px;text-align:right;font-size:13px;font-style:italic;padding-left:0;word-break:break-all;white-space:normal}.summary-profit-margin[data-margin=low]{color:#ff4d4f}.summary-profit-margin[data-margin=medium]{color:#faad14}.summary-profit-margin[data-margin=high]{color:#52c41a}.discount-input{width:100%;text-align:right}.summary-subtotal,.summary-total{border-top:none;margin-top:0;padding-top:6px}.total-description,.total-amount,.total-cost,.total-profit{font-weight:600}.total-amount{color:var(--primary-color)}@media print{.summary-section{margin-top:16px;padding:12px}.summary-row,.summary-subtotal,.summary-discount,.summary-total{padding:4px 0;min-height:28px;border-bottom:1px solid #f0f0f0}.no-print{display:none!important}}.payment-terms-section{margin-top:24px;padding:16px;border:1px solid #f0f0f0;border-radius:8px;background:#fff}.payment-terms-section h3{margin-bottom:8px;font-size:14px;font-weight:500}.payment-terms-items{display:flex;flex-direction:column}.payment-term-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;min-height:32px;border-bottom:1px solid #f0f0f0}.payment-term-row:last-child{border-bottom:none}.term-description{flex:1;text-align:left;font-size:13px;padding-right:16px}.term-amount{width:120px;text-align:right;font-size:13px;color:var(--primary-color)}@media print{.payment-terms-section{margin-top:16px;padding:12px}.payment-term-row{padding:4px 0;min-height:28px}}.notes-section{margin-top:24px;padding:16px;border:1px solid #f0f0f0;border-radius:8px;background:#fff}.notes-section h3{margin-bottom:12px;font-size:14px;font-weight:500}.notes-items{display:flex;flex-direction:column;gap:8px}.note-item{font-size:12px;color:#666;line-height:1.5;padding-right:16px}@media print{.notes-section{margin-top:16px;padding:12px;page-break-inside:avoid}.notes-items{gap:6px}.note-item{font-size:10px}}.page-header{margin-bottom:24px;padding:16px 0;border-bottom:1px solid #f0f0f0}.header-actions{display:flex;gap:12px;justify-content:flex-start}.some-element{-webkit-appearance:none;-moz-appearance:none;appearance:none}.add-preset-button{color:#1890ff!important}.add-preset-button:hover{background:#1890ff1a!important}.preset-modal .ant-modal-content{overflow:visible!important}.preset-modal .ant-modal-body{height:70vh;padding:20px;display:flex;flex-direction:column}.preset-selection-container{height:100%;padding:0;display:flex;flex-direction:column;flex:1}.preset-list-item{display:flex!important;justify-content:space-between!important;align-items:center!important;padding:12px 16px!important;border:1px solid #f0f0f0!important;border-radius:4px!important;margin-bottom:8px!important;cursor:pointer;transition:all .3s}.preset-list-item:hover{background-color:#f9f9f9}.preset-item-selected{border-color:#1890ff!important;background-color:#e6f7ff!important}.preset-item-left{flex:1;padding-right:16px}.preset-item-description{font-weight:500;line-height:1.4;word-break:break-word}.preset-item-right{display:flex;align-items:center;white-space:nowrap;position:relative}.preset-item-qty,.preset-item-uom,.preset-item-price{margin-right:16px;color:#666}.preset-item-check{color:#1890ff;font-size:16px;margin-left:8px}@media (max-width: 576px){.preset-list-item{flex-direction:column;align-items:flex-start!important}.preset-item-left{width:100%;margin-bottom:8px}.preset-item-right{width:100%;justify-content:space-between}}.auto-expand-textarea{width:100%;min-height:32px;padding:4px 8px;border:none;background-color:transparent;resize:none;line-height:1.5;font-family:inherit;font-size:inherit;overflow:hidden}.col-description{height:auto!important;min-height:32px}.sub-item-row{height:auto!important;min-height:40px;align-items:flex-start!important}.ant-input-textarea-show-count:after{position:absolute!important;bottom:0!important;right:0!important}.col-description{height:auto!important;min-height:40px!important}.col-quantity,.col-uom,.col-unit-price,.col-amount,.col-unit-cost,.col-cost-amount,.col-action{display:flex!important;align-items:center!important;justify-content:center!important;padding:4px!important}.debug-mode .sub-item-row{border:1px solid #ff0000}.debug-mode .col-description{border:1px solid #00ff00}.debug-mode .description-input{border:1px solid #0000ff}.description-input{width:100%!important;min-height:32px!important;height:auto!important;overflow:hidden!important;resize:none!important;border:none!important;background-color:transparent!important;padding:4px 8px!important;font-family:inherit!important;font-size:inherit!important;line-height:1.5!important;display:block!important;box-sizing:border-box!important}.description-input:hover{background-color:#f9f9f9}.description-input:focus{background-color:#f9f9f9;outline:none}@media print{.no-print{display:none!important}.summary-table{width:100%}.summary-table th,.summary-table td{border:1px solid #ddd}}.cost-column,.profit-column,.profit-margin{color:#555;font-weight:400}.profit-margin{font-style:italic}tr:not(.total-row) .profit-margin:not(.no-data){position:relative}tr:not(.total-row) .profit-margin:not(.no-data):after{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;margin-left:5px}tr:not(.total-row) .profit-margin:not(.no-data)[data-margin=low]:after{background-color:#ff4d4f}tr:not(.total-row) .profit-margin:not(.no-data)[data-margin=medium]:after{background-color:#faad14}tr:not(.total-row) .profit-margin:not(.no-data)[data-margin=high]:after{background-color:#52c41a}.cost-analysis{margin-top:20px;border-top:1px solid #e8e8e8;padding-top:16px}.cost-analysis h4{margin-top:0;margin-bottom:12px;font-size:14px;font-weight:600;color:#333}.analysis-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px dashed #f0f0f0}.analysis-description{flex:3}.analysis-amount{flex:1;text-align:right}.analysis-percentage{flex:1;text-align:right;color:#555}.profit-margin[data-margin=low]{color:#ff4d4f}.profit-margin[data-margin=medium]{color:#faad14}.profit-margin[data-margin=high]{color:#52c41a}.payment-terms{margin-top:20px;border-top:1px solid #e8e8e8;padding-top:16px}.payment-terms h4{margin-top:0;margin-bottom:12px;font-size:14px;font-weight:600;color:#333}.term-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px dashed #f0f0f0}.term-description{flex:3}.term-amount{flex:1;text-align:right;font-weight:500}.items-header{display:flex;align-items:center;margin-bottom:16px}.items-header h2{margin:0 16px 0 0;font-size:18px;font-weight:500}.add-main-item-btn{margin-left:8px}.uom-column,.ant-table-cell.uom-column{min-width:80px!important;width:80px!important}.col-description{flex:2;min-width:300px}.col-quantity{width:80px;min-width:80px}.col-unit-price{width:100px;min-width:100px}.col-uom{width:110px;min-width:110px}.col-amount,.col-unit-cost{width:100px;min-width:100px}.col-cost-amount{width:130px;min-width:130px}.col-action{width:60px;min-width:60px}.col-uom input{width:100%!important}.ant-table-cell.uom-column{min-width:110px!important;width:110px!important}.quotation-form .items-section .col-uom .ant-input{width:110px!important}.quotation-actions{display:flex;justify-content:flex-start;gap:8px;width:100%;min-width:80px;align-items:center}.quotation-actions .edit-button,.quotation-actions .delete-button{height:32px;line-height:32px;padding:0 8px;display:flex;align-items:center;justify-content:center}.quotation-actions .edit-button{color:#1890ff}.quotation-actions .delete-button{color:#ff4d4f}.ant-table-column-title:last-child{min-width:100px}.main-item-header .add-area-button{color:#1890ff!important}.main-item-header .add-preset-button{color:#52c41a!important}.main-item-header .add-sub-button{color:#722ed1!important}.main-item-header .delete-button{color:#f5222d!important}.main-item-header .add-area-button:hover{color:#096dd9}.main-item-header .preset-button:hover{color:#389e0d}.main-item-header .add-button:hover{color:#531dab}.main-item-header .delete-button:hover{color:#cf1322}@media (max-width: 768px){.quotation-form{padding:8px}.form-header{grid-template-columns:1fr;gap:16px;margin-bottom:16px}.client-info,.quotation-info{padding:0;border:none}.main-item{padding:16px;margin-bottom:16px}.quotation-form .items-section .sub-items-header{display:none}.quotation-form .items-section .sub-item-row{display:block!important;border:1px solid #f0f0f0;border-radius:8px;padding:12px;margin-bottom:8px;background:#fafafa}.quotation-form .items-section .sub-item-row>div{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding:4px 0}.quotation-form .items-section .sub-item-row>div:last-child{margin-bottom:0}.quotation-form .items-section .col-description:before{content:"Description: ";font-weight:500;color:#666;min-width:80px}.quotation-form .items-section .col-quantity:before{content:"Qty: ";font-weight:500;color:#666;min-width:80px}.quotation-form .items-section .col-uom:before{content:"UOM: ";font-weight:500;color:#666;min-width:80px}.quotation-form .items-section .col-unit-price:before{content:"Unit Price: ";font-weight:500;color:#666;min-width:80px}.quotation-form .items-section .col-amount:before{content:"Amount: ";font-weight:500;color:#666;min-width:80px}.quotation-form .items-section .col-unit-cost:before{content:"Unit Cost: ";font-weight:500;color:#666;min-width:80px}.quotation-form .items-section .col-cost-amount:before{content:"Cost Amount: ";font-weight:500;color:#666;min-width:80px}.quotation-form .items-section .col-action{text-align:center;margin-top:8px}.summary-section{padding:16px;margin-top:16px}.summary-row,.summary-subtotal,.summary-discount,.summary-total{flex-direction:column;align-items:flex-start;gap:4px}.payment-terms-section{padding:16px;margin-top:16px}.payment-term-row{flex-direction:column;align-items:flex-start;gap:4px}.notes-section{padding:16px;margin-top:16px}}@media (max-width: 480px){.quotation-form{padding:4px}.main-item{padding:12px}.form-header{gap:12px;margin-bottom:12px}.quotation-form .items-section .sub-item-row{padding:8px;font-size:14px}.quotation-form .items-section .sub-item-row>div{margin-bottom:6px;padding:2px 0}.summary-section,.payment-terms-section,.notes-section{padding:12px;margin-top:12px}.main-item-actions .ant-btn{min-height:36px;padding:6px 8px;font-size:12px}}.action-cell{display:flex;align-items:center;gap:var(--spacing-xs);justify-content:flex-start}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid transparent;border-radius:var(--radius-base);background:transparent;cursor:pointer;transition:all var(--transition-fast);font-size:16px}.icon-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.icon-button.edit{color:var(--primary-color)}.icon-button.edit:hover{background-color:var(--primary-light);border-color:var(--primary-color)}.icon-button.quote{color:var(--secondary-color)}.icon-button.quote:hover{background-color:#722ed11a;border-color:var(--secondary-color)}.icon-button.delete{color:var(--error-color)}.icon-button.delete:hover{background-color:#ff4d4f1a;border-color:var(--error-color)}.icon-button.view{color:var(--info-color)}.icon-button.view:hover{background-color:#13c2c21a;border-color:var(--info-color)}.add-button{height:40px;padding:0 var(--spacing-lg);font-weight:600;border-radius:var(--radius-base);box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.add-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.client-count{font-size:var(--font-size-sm);color:var(--text-tertiary);font-weight:500}.client-modal .ant-modal-content{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xl)}.client-modal .ant-modal-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-secondary);padding:var(--spacing-lg)}.client-modal .ant-modal-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.client-modal .ant-modal-body{padding:var(--spacing-lg)}.client-modal .ant-modal-footer{background:var(--bg-secondary);border-top:1px solid var(--border-secondary);padding:var(--spacing-md) var(--spacing-lg)}.client-modal .ant-form-item-label>label{font-weight:500;color:var(--text-primary);font-size:var(--font-size-sm)}.client-modal .ant-input,.client-modal .ant-input-textarea{border-radius:var(--radius-base);border-color:var(--border-primary);transition:all var(--transition-fast)}.client-modal .ant-input:hover,.client-modal .ant-input-textarea:hover{border-color:var(--primary-color)}.client-modal .ant-input:focus,.client-modal .ant-input-textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-outline)}.custom-pagination{margin:var(--spacing-lg) 0;text-align:center}.custom-pagination .ant-pagination-item{border-radius:var(--radius-base);border-color:var(--border-primary)}.custom-pagination .ant-pagination-item-active{border-color:var(--primary-color);background:var(--primary-color)}.custom-pagination .ant-pagination-item-active a{color:#fff}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.action-cell{flex-direction:column;gap:var(--spacing-xs)}.icon-button{width:36px;height:36px;font-size:18px}.add-button{width:100%;height:44px}.client-modal .ant-modal-content{margin:var(--spacing-sm)}}@media (max-width: 480px){.icon-button{width:32px;height:32px;font-size:16px}.add-button{height:40px;font-size:var(--font-size-sm)}.client-modal .ant-modal-header,.client-modal .ant-modal-body,.client-modal .ant-modal-footer{padding:var(--spacing-md)}}.add-area-button-blue{color:#1890ff}.add-preset-button-green{color:#52c41a}.add-sub-button-purple{color:#722ed1}.delete-button-red{color:#f5222d}.action-buttons{display:flex;gap:4px;align-items:center}.move-button{padding:2px 4px!important;min-width:24px;height:24px}.move-button:hover{background-color:#f0f0f0}.move-button:disabled{opacity:.3;cursor:not-allowed}.col-action{min-width:120px}.duplicate-button{background-color:#722ed1;border-color:#722ed1;color:#fff}.duplicate-button:hover{background-color:#9254de;border-color:#9254de}.duplicate-button:disabled{background-color:#f5f5f5;border-color:#d9d9d9;color:#bfbfbf}.quotation-actions{display:flex;gap:12px;align-items:center;margin-bottom:16px}.col-description{display:flex;align-items:center;gap:8px}.reorder-controls{display:flex;flex-direction:column;justify-content:center;align-items:center}.reorder-controls .ant-btn{padding:0;height:auto;line-height:1;border:none;background:transparent;box-shadow:none;font-size:12px;color:#888}.reorder-controls .ant-btn:hover{color:#1890ff}.quotation-form{position:relative;height:calc(100vh - 112px);overflow-y:auto;margin:-24px;padding:0}.quotation-form .page-header{position:sticky;top:0;background:#fff;z-index:95;border-bottom:1px solid #e8e8e8;padding:16px 24px;margin:0 0 16px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.quotation-form .ant-form{padding:0 24px 24px}.quotation-form .ant-form>div{margin:0}.quotation-form .header-left{display:flex;align-items:center;gap:16px;flex:1;min-width:0}.quotation-form .header-left h1{font-size:20px;margin:0;font-weight:600;color:#262626;line-height:1.3}.quotation-form .save-status{font-size:12px;margin-top:4px}.quotation-form .header-actions{display:flex;gap:8px;align-items:center;flex-shrink:0;flex-wrap:wrap}.quotation-form .header-actions .ant-btn{margin:0;white-space:nowrap}.quotation-form .variation-order-header{padding:12px 24px;margin:0 0 16px;flex-direction:column;align-items:stretch;gap:12px}.quotation-form .variation-order-header .header-actions{justify-content:flex-start;width:100%}.quotation-form .variation-order-header .save-status{margin-top:0}.quotation-form .save-status span{font-weight:500}.quotation-form .save-status span[style*="color: #1890ff"]{color:#1890ff!important}.quotation-form .save-status span[style*="color: #52c41a"]{color:#52c41a!important}.quotation-form .save-status span[style*="color: #faad14"]{color:#faad14!important}@media (max-width: 768px){.quotation-form{height:calc(100vh - 88px);margin:-16px}.quotation-form .ant-form{padding:0 16px 16px}.quotation-form .page-header{padding:12px 16px;flex-direction:column;align-items:stretch;gap:12px}.quotation-form .header-left{gap:12px}.quotation-form .header-left h1{font-size:18px}.quotation-form .header-actions{justify-content:flex-start;gap:6px}.quotation-form .header-actions .ant-btn{font-size:12px;padding:4px 8px;height:auto}.quotation-form .variation-order-header{padding:10px 16px}}@media (max-width: 480px){.quotation-form{height:calc(100vh - 72px);margin:-12px}.quotation-form .ant-form{padding:0 12px 12px}.quotation-form .page-header{padding:8px 12px}.quotation-form .header-left h1{font-size:16px}.quotation-form .header-actions .ant-btn{font-size:11px;padding:3px 6px}.quotation-form .variation-order-header{padding:8px 12px}}.quotation-view-page{min-height:100vh;background:#f5f5f5}.quotation-view-header{background:#fff;padding:16px 24px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center;margin-bottom:0;position:sticky;top:0;z-index:100}.quotation-view-header .header-left{display:flex;align-items:center}.quotation-view-header .header-left h1{margin:0;color:#333;font-size:20px}.quotation-view-header .header-actions{display:flex;gap:12px}.quotation-view-header .header-actions button[style*="background-color: rgb(82, 196, 26)"]{background-color:#52c41a!important;border-color:#52c41a!important;color:#fff!important}.quotation-view-header .header-actions button[style*="background-color: rgb(82, 196, 26)"]:hover{background-color:#73d13d!important;border-color:#73d13d!important}@media (max-width: 768px){.quotation-view-header{flex-direction:column;align-items:flex-start;gap:16px}.quotation-view-header .header-actions{flex-wrap:wrap;gap:8px;width:100%}.quotation-view-header .header-actions button{flex:1;min-width:120px}}.pdf-container{width:100%;height:calc(100vh - 80px);background:#f5f5f5}.pdf-container iframe{width:100%;height:100%;border:none}@media print{.quotation-view-header{display:none}.pdf-container{height:100vh}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:#f5f7fa}.login-content{width:100%;max-width:420px;padding:20px}.login-card{border-radius:12px;box-shadow:0 8px 24px #0000001a}.login-header{text-align:center;margin-bottom:24px}.login-logo-container{display:flex;justify-content:center;margin-bottom:16px}.login-logo{width:80px;height:80px}.login-form{margin-top:24px}.login-button{background-color:#5cbdb9;border-color:#5cbdb9;height:44px;font-size:16px;margin-top:8px}.login-button:hover{background-color:#4eaaa6;border-color:#4eaaa6}.login-loading{display:flex;justify-content:center;margin:16px 0}.login-footer{text-align:center;margin-top:24px}.studio-name{font-size:36px;font-weight:700;margin-bottom:8px;color:var(--primary-color)!important}.system-name{font-size:18px;font-weight:400;color:#666;margin:0}.login-header .studio-name{color:var(--primary-color)!important}@media (max-width: 480px){.login-content{padding:16px}.login-logo{width:60px;height:60px}}.admin-page{padding:24px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;background:#fff;padding:20px 24px;border-radius:8px;box-shadow:0 2px 4px #00000005}.admin-header h2{margin:0}.ant-table-wrapper{background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;padding:1px}.projects-page{padding:24px}.page-header p{margin:0;color:#666}.user-detail-page{padding:24px}.user-tabs{margin-top:24px}.ant-descriptions{margin-top:16px}.user-edit-page{padding:24px}.user-settings-page{padding:24px}.page-header{margin-bottom:24px}.admin-invoices-page{padding:24px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-header h2{margin:0;font-size:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{margin:0;font-size:18px}.invoice-stats{background-color:#f9f9f9;padding:16px;border-radius:8px;margin-bottom:24px}.ant-statistic-title{font-size:14px}.ant-tabs-nav{margin-bottom:24px}.admin-invoices-page .compact-invoice-table .ant-table-thead>tr>th,.admin-invoices-page .compact-invoice-table .ant-table-tbody>tr>td{padding:6px;font-size:12px;vertical-align:top}.admin-invoices-page .ant-table-pagination.ant-pagination{margin:16px 0 0}.address-cell{white-space:pre-wrap;word-break:break-word;max-width:250px}.admin-invoices-page .ant-btn{font-size:12px;padding:0 10px;height:28px;line-height:26px}.financial-overview-compact{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:6px;padding:8px;box-shadow:0 1px 3px #0000001a}.financial-overview-compact .financial-item{text-align:center;padding:8px;background:#ffffffe6;border-radius:4px;border:1px solid rgba(0,0,0,.05);transition:all .2s ease}.financial-overview-compact .financial-item:hover{background:#fff;box-shadow:0 2px 6px #0000001a;transform:translateY(-1px)}.financial-overview-compact .financial-title{font-size:11px;color:#666;margin-bottom:4px;font-weight:500}.financial-overview-compact .financial-value{font-size:16px;font-weight:700;line-height:1.2}.financial-overview-compact .financial-description{font-size:9px;color:#999;margin-top:2px;line-height:1.2}.financial-overview-compact .user-profit-item{background:linear-gradient(135deg,#e6f7ff,#bae7ff)}.ant-input,.ant-input-number{height:32px;line-height:24px!important;display:flex!important;align-items:center!important}.ant-input-number-input{line-height:24px!important;height:24px!important;display:flex!important;align-items:center!important}.main-item{width:100%;max-width:100%;box-sizing:border-box;margin-bottom:24px;border:1px solid #f0f0f0;border-radius:12px;padding:32px 32px 24px;background:#fff;font-size:14px;overflow-x:visible}.main-item-header{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid #f0f0f0}.main-description{display:flex;align-items:center;gap:8px}.main-item-actions{display:flex;align-items:center;gap:4px;margin-left:8px}.add-area-button,.add-sub-button,.delete-button{padding:4px!important;height:24px!important;min-width:24px!important;display:flex!important;align-items:center!important;justify-content:center!important;border:none!important;background:transparent!important;box-shadow:none!important}.add-area-button-blue{color:#1890ff!important;font-size:12px!important;border:none!important;background:transparent!important;box-shadow:none!important;padding:4px!important;height:24px!important;min-width:24px!important;display:flex!important;align-items:center!important;justify-content:center!important}.add-preset-button-green{color:#52c41a!important;border:none!important;background:transparent!important;box-shadow:none!important;padding:4px!important;height:24px!important;min-width:24px!important;display:flex!important;align-items:center!important;justify-content:center!important}.add-sub-button-purple{color:#722ed1!important;border:none!important;background:transparent!important;box-shadow:none!important;padding:4px!important;height:24px!important;min-width:24px!important;display:flex!important;align-items:center!important;justify-content:center!important}.delete-button-red{color:#f5222d!important;border:none!important;background:transparent!important;box-shadow:none!important;padding:4px!important;height:24px!important;min-width:24px!important;display:flex!important;align-items:center!important;justify-content:center!important}.add-area-button-blue:hover,.add-preset-button-green:hover,.add-sub-button-purple:hover,.delete-button-red:hover{background:#0000000a!important;border:none!important;box-shadow:none!important}.add-area-button-blue:focus,.add-preset-button-green:focus,.add-sub-button-purple:focus,.delete-button-red:focus{background:transparent!important;border:none!important;box-shadow:none!important;outline:none!important}.add-area-button-blue:active,.add-preset-button-green:active,.add-sub-button-purple:active,.delete-button-red:active{border:none!important;box-shadow:none!important}.sub-items-header,.sub-item-row{display:grid!important;grid-template-columns:minmax(300px,2fr) 100px 110px 120px 120px 120px 130px 40px!important;gap:4px!important;padding:8px 12px!important;align-items:center!important}.sub-items-header{background:#fafafa;border-bottom:1px solid #f0f0f0}.sub-items-header>div{font-weight:500;color:#333}.sub-item-row{min-height:40px;height:auto;align-items:flex-start;padding:8px 12px}.col-description{text-align:left;min-width:300px;max-width:none;overflow:visible;height:auto;padding:0}.col-quantity,.col-uom{text-align:center}.col-unit-price,.col-amount,.col-unit-cost,.col-cost-amount{text-align:right}.sub-item-row .ant-input,.sub-item-row .ant-input-number{width:100%!important;height:32px!important;border:1px solid #d9d9d9!important;border-radius:2px!important;transition:all .3s!important;line-height:24px!important;display:flex!important;align-items:center!important}.col-description textarea{width:100%!important;min-height:32px!important;height:auto!important;overflow:hidden!important;resize:none!important;border:none!important;background-color:transparent!important;padding:4px 8px!important;font-family:inherit!important;font-size:inherit!important;line-height:1.5!important;display:block!important}.col-quantity .ant-input-number{width:100px!important}.col-quantity .ant-input-number-input{text-align:center!important;line-height:24px!important;height:24px!important;display:flex!important;align-items:center!important;justify-content:center!important}.col-uom .ant-input{width:110px!important;text-align:center!important;text-transform:uppercase!important;line-height:24px!important;height:32px!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:4px 8px!important}.col-unit-price .ant-input-number,.col-amount .ant-input-number,.col-unit-cost .ant-input-number,.col-cost-amount .ant-input-number{width:120px!important;display:flex!important;align-items:center!important}.col-unit-price .ant-input-number-input,.col-amount .ant-input-number-input,.col-unit-cost .ant-input-number-input,.col-cost-amount .ant-input-number-input{text-align:right!important;line-height:24px!important;height:24px!important;display:flex!important;align-items:center!important;justify-content:flex-end!important;border:none!important;box-shadow:none!important}.sub-item-row .ant-input:hover,.sub-item-row .ant-input-number:hover{border-color:var(--primary-color)!important}.sub-item-row .ant-input:focus,.sub-item-row .ant-input-number-focused{border-color:var(--primary-color)!important;box-shadow:0 0 0 2px #20b2aa33!important}.ant-input-number .ant-input-number-handler-wrap{display:none!important}.ant-input-number input[type=number]::-webkit-outer-spin-button,.ant-input-number input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.ant-input-number input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.area-row{grid-template-columns:1fr auto!important;background-color:#fafafa;padding:8px 16px!important;font-weight:500}.area-row .col-area-description{grid-column:1}.area-row .col-action{grid-column:2;display:flex;justify-content:center}.area-row .ant-input{font-weight:500;background-color:#fafafa}.main-item-total{display:flex;justify-content:flex-end;padding-top:16px;font-weight:500;color:var(--primary-color)}.summary-section{margin-top:24px;padding:32px 32px 24px;border:1px solid #f0f0f0;border-radius:12px;background:#fff;font-size:14px;word-break:break-all;white-space:normal;overflow-x:visible}.summary-section h3{margin-bottom:8px;font-size:14px;font-weight:500}.summary-items{display:flex;flex-direction:column;word-break:break-all;white-space:normal}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;min-height:32px;border-bottom:1px solid #f0f0f0;word-break:break-all;white-space:normal}.summary-description{flex:3;text-align:left;font-size:13px;word-break:break-all;white-space:normal}.items-section{margin-top:24px}.disabled-item{opacity:.5;cursor:not-allowed}.gantt-chart{background:#fff;border:1px solid #f0f0f0;border-radius:6px;overflow-x:auto;min-height:300px}.gantt-header{display:flex;border-bottom:2px solid #f0f0f0;background:#fafafa;position:sticky;top:0;z-index:10}.gantt-task-column{min-width:300px;width:300px;padding:12px 16px;font-weight:600;border-right:1px solid #f0f0f0;background:#fafafa}.gantt-timeline{flex:1;position:relative;background:#fafafa}.timeline-scale{display:flex;height:40px;border-bottom:1px solid #f0f0f0}.month-label{min-width:60px;padding:8px 12px;text-align:center;font-size:12px;font-weight:500;border-right:1px solid #e6f7ff;background:linear-gradient(180deg,#e6f7ff,#bae7ff)}.gantt-row{display:flex;border-bottom:1px solid #f0f0f0;transition:background-color .2s}.gantt-row:hover{background-color:#f5f5f5}.gantt-task-info{min-width:300px;width:300px;padding:12px 16px;border-right:1px solid #f0f0f0;background:#fff}.task-name{font-weight:600;font-size:14px;margin-bottom:4px;color:#262626}.task-dates{font-size:12px;color:#8c8c8c;margin-bottom:8px}.gantt-timeline-row{flex:1;position:relative;height:60px;background:#fff;overflow:hidden}.task-bar{position:absolute;height:24px;top:50%;transform:translateY(-50%);border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0000001a;min-width:20px}.task-bar:hover{transform:translateY(-50%) scale(1.05);box-shadow:0 4px 8px #00000026}.task-progress{height:100%;background:#ffffff4d;border-radius:12px;transition:width .3s ease}.task-not-started{background:linear-gradient(135deg,#d9d9d9,#bfbfbf)}.task-in-progress{background:linear-gradient(135deg,#1890ff,#096dd9)}.task-completed{background:linear-gradient(135deg,#52c41a,#389e0d)}.task-overdue{background:linear-gradient(135deg,#f5222d,#cf1322);animation:pulse 2s infinite}.task-on-hold{background:linear-gradient(135deg,#faad14,#d48806)}@keyframes pulse{0%{box-shadow:0 2px 4px #f5222d33}50%{box-shadow:0 4px 8px #f5222d66}to{box-shadow:0 2px 4px #f5222d33}}@media (max-width: 768px){.gantt-task-column,.gantt-task-info{min-width:250px;width:250px}.task-name{font-size:13px}.month-label{min-width:50px;font-size:11px}}.ant-table-tbody>tr.ant-table-row-selected>td{background:#e6f7ff}.ant-table-tbody>tr:hover>td{background:#f5f5f5}.ant-progress-line{margin-bottom:4px}.ant-progress-inner{background-color:#f5f5f5;border-radius:4px}.ant-tag{border-radius:4px;font-size:11px;padding:2px 6px}.ant-card{border-radius:8px;box-shadow:0 1px 2px #00000008;border:1px solid #f0f0f0}.ant-btn-primary:hover{background:#40a9ff;border-color:#40a9ff}.gantt-chart .ant-empty{margin:40px 0}.gantt-chart .ant-empty-image{margin-bottom:16px}.ant-slider{margin:8px 0}.ant-slider-track{background-color:#1890ff}.ant-slider-handle{border-color:#1890ff}.ant-slider-handle:hover{border-color:#40a9ff}.milestone-tag{margin:4px;padding:8px 12px;border-radius:6px;font-weight:500}.ant-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;transition:all .3s ease}.gantt-chart::-webkit-scrollbar{height:8px}.gantt-chart::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.gantt-chart::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.gantt-chart::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.calendar-cell{position:relative;min-height:60px;padding:4px}.task-item{cursor:pointer;padding:2px 6px;border-radius:4px;font-size:11px;display:inline-block;margin:1px 0;transition:all .2s ease;background:#1890ff1a;border:1px solid rgba(24,144,255,.3)}.task-item:hover{background:#1890ff33;transform:scale(1.05)}.task-item.completed{background:#52c41a1a;border-color:#52c41a4d;text-decoration:line-through;opacity:.7}.task-item.pending{background:#faad141a;border-color:#faad144d}.add-task-btn{position:absolute;bottom:2px;right:2px;font-size:10px;color:#1890ff;cursor:pointer;padding:2px 4px;border-radius:2px;background:#1890ff1a;border:1px dashed #1890ff;opacity:0;transition:all .2s ease}.calendar-cell:hover .add-task-btn{opacity:1}.add-task-btn:hover{background:#1890ff33}.ant-picker-calendar{background:#fff;border-radius:8px}.ant-picker-calendar-header{padding:8px 0;border-bottom:1px solid #f0f0f0}.ant-picker-cell{position:relative}.ant-picker-cell-in-view .ant-picker-cell-inner{position:relative;z-index:1}.ant-picker-cell:hover{background:#f5f5f5}.ant-badge-status-dot{width:8px;height:8px}.ant-badge-status-text{margin-left:6px;font-size:11px}.ant-list-item{padding:12px 16px;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.ant-list-item:hover{background-color:#f5f5f5}.ant-list-item-action{margin-left:8px}.ant-list-item-action>li{padding:0 4px}.ant-card{border-radius:8px;box-shadow:0 1px 2px #00000008;border:1px solid #f0f0f0;transition:all .3s ease}.ant-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.ant-card-head{border-bottom:1px solid #f0f0f0}.ant-card-head-title{font-weight:600}.ant-card-body{padding:16px}.ant-progress-circle{display:flex;flex-direction:column;align-items:center}.ant-progress-text{color:#52c41a;font-weight:700}.ant-tag{border-radius:4px;font-size:11px;padding:2px 6px;margin:2px}.ant-modal-header{border-bottom:1px solid #f0f0f0}.ant-modal-title{font-weight:600}.ant-modal-body{padding:20px 24px}.ant-form-item{margin-bottom:16px}.ant-form-item-label>label{font-weight:500}.ant-btn{border-radius:6px;font-weight:500;transition:all .2s ease}.ant-btn-primary{background:#1890ff;border-color:#1890ff;box-shadow:0 2px #0000000b}.ant-btn-primary:hover{background:#40a9ff;border-color:#40a9ff;transform:translateY(-1px);box-shadow:0 4px 8px #1890ff4d}.ant-btn-text:hover{background:#0000000a}@media (max-width: 768px){.calendar-cell{min-height:40px;padding:2px}.task-item{font-size:10px;padding:1px 4px}.add-task-btn{font-size:9px;padding:1px 3px}.ant-card-body{padding:12px}.ant-list-item{padding:8px 12px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ant-card,.ant-list-item{animation:fadeIn .3s ease-out}.ant-list::-webkit-scrollbar{width:6px}.ant-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.ant-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.ant-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.ant-picker-cell-selected .ant-picker-cell-inner{background:#1890ff;color:#fff}.ant-picker-cell-today .ant-picker-cell-inner{border:1px solid #1890ff;font-weight:700}.priority-indicator{width:4px;height:100%;position:absolute;left:0;top:0;border-radius:2px 0 0 2px}.priority-high .priority-indicator{background:#f5222d}.priority-medium .priority-indicator{background:#faad14}.priority-low .priority-indicator{background:#52c41a}.buying-list-container{padding:20px;background:#f5f5f5;min-height:100vh}.buying-list-header{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 8px #0000001a}.buying-list-table{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.buying-list-table .ant-table-thead>tr>th{background-color:#f0f2f5;font-weight:600;border-bottom:2px solid #d9d9d9}.buying-list-table .ant-table-tbody>tr:hover>td{background-color:#f5f5f5}.item-image{border-radius:4px;border:1px solid #d9d9d9;transition:transform .2s}.item-image:hover{transform:scale(1.05)}.item-description{font-weight:600;color:#262626;margin-bottom:4px}.specification-text{white-space:pre-wrap;word-break:break-word;line-height:1.4;color:#595959}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.modal-form{margin-top:20px}.upload-preview{margin-top:10px;padding:10px;border:1px dashed #d9d9d9;border-radius:6px;text-align:center}.upload-preview img{border-radius:4px;box-shadow:0 2px 8px #0000001a}.image-filename{margin:4px 0;color:#666;font-size:12px;font-style:italic}.add-item-btn{box-shadow:0 2px 4px #1890ff33}.add-item-btn:hover{box-shadow:0 4px 8px #1890ff4d;transform:translateY(-1px)}.table-pagination{padding:16px;text-align:center;background:#fff}.empty-state{text-align:center;padding:40px;color:#8c8c8c}.empty-state .anticon{font-size:48px;margin-bottom:16px}@media (max-width: 768px){.buying-list-container{padding:10px}.action-buttons{flex-direction:column}.action-buttons .ant-btn{width:100%}}:root{--primary-color: #499292;--primary-hover: #3a7a7a;--primary-active: #2d6060;--primary-light: rgba(73, 144, 144, .1);--primary-outline: rgba(73, 144, 144, .2);--success-color: #52c41a;--warning-color: #faad14;--error-color: #ff4d4f;--info-color: #13c2c2;--text-primary: #262626;--text-secondary: #595959;--text-tertiary: #8c8c8c;--text-disabled: #bfbfbf;--bg-primary: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f5f5f5;--bg-layout: #f0f2f5;--border-primary: #d9d9d9;--border-secondary: #f0f0f0;--border-light: #fafafa;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 30px;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .03);--shadow-base: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--radius-sm: 4px;--radius-base: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 2000;--z-popover: 1060;--z-tooltip: 1070;--z-header: 100;--z-sider: 90}html{font-size:16px;line-height:1.5;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--text-primary);background-color:var(--bg-layout);overflow-x:hidden}h1,h2,h3,h4,h5,h6{margin:0 0 var(--spacing-md) 0;font-weight:600;line-height:var(--line-height-tight);color:var(--text-primary)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-base)}h6{font-size:var(--font-size-sm)}p{margin:0 0 var(--spacing-md) 0;color:var(--text-secondary)}a{color:var(--primary-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-hover)}.btn,.ant-btn{display:inline-flex;align-items:center;justify-content:center;padding:0 20px;height:40px;font-size:16px;font-weight:500;border-radius:6px;border:1.5px solid var(--primary-color);background:#fff;color:#333;transition:all var(--transition-fast);box-shadow:none}.btn-primary,.ant-btn-primary{background:var(--primary-color);color:#fff;border:1.5px solid var(--primary-color)}.btn-primary:hover,.ant-btn-primary:hover,.btn-primary:focus,.ant-btn-primary:focus{background:var(--primary-hover);border-color:var(--primary-hover);color:#fff}.btn-outline,.ant-btn-default{background:#fff;color:#333;border:1.5px solid var(--primary-color)}.btn-outline:hover,.ant-btn-default:hover,.btn-outline:focus,.ant-btn-default:focus{background:var(--primary-light);color:#333;border-color:var(--primary-hover)}.btn-icon,.ant-btn-icon-only{width:32px;height:32px;padding:0;border-radius:6px;background:#fff;color:#333;border:1.5px solid var(--primary-color);display:inline-flex;align-items:center;justify-content:center;font-size:18px;transition:all var(--transition-fast)}.btn-icon:hover,.ant-btn-icon-only:hover{background:var(--primary-light);color:#333;border-color:var(--primary-hover)}.btn[disabled],.ant-btn[disabled]{background:var(--primary-light);color:var(--text-disabled);border-color:var(--border-primary);cursor:not-allowed;opacity:.7}.sidebar .nav-item{display:flex;align-items:center;padding:0 18px;height:44px;font-size:15px;font-weight:500;border-radius:6px;color:var(--text-secondary);background:#fff;border-left:3px solid transparent;margin:4px 8px;transition:all var(--transition-fast)}.sidebar .nav-item.active{color:var(--primary-color);background:#fff;border-left:3px solid var(--primary-color);font-weight:600}.sidebar .nav-item:hover{color:var(--primary-hover);background:var(--primary-light);border-left:3px solid var(--primary-hover)}.sidebar .nav-item .anticon{font-size:19px;color:var(--primary-color);opacity:1}.sidebar .nav-item.active .anticon{color:var(--primary-color)}.sidebar .nav-item:hover .anticon{color:var(--primary-hover)}.sidebar .nav-item.logout .anticon{color:var(--primary-color)!important;opacity:1!important}.btn-table,.ant-btn-table{width:32px;height:32px;padding:0;border-radius:6px;background:#fff;color:var(--primary-color);border:1.5px solid var(--primary-color);display:inline-flex;align-items:center;justify-content:center;font-size:18px;transition:all var(--transition-fast)}.btn-table:hover,.ant-btn-table:hover{background:var(--primary-light);color:var(--primary-hover);border-color:var(--primary-hover)}.card,.ant-card,.table-container,.ant-table-wrapper{border-radius:6px;box-shadow:var(--shadow-base);background:#fff;border:1px solid var(--border-secondary);overflow:hidden}.card-body,.ant-card-body{padding:20px 24px}input,.ant-input,.form-input{border-radius:6px;height:40px;font-size:15px;padding:0 12px}.rounded{border-radius:6px!important}.shadow{box-shadow:var(--shadow-base)!important}.text-primary{color:var(--primary-color)!important}.text-secondary{color:var(--text-secondary)!important}.bg-primary{background:var(--bg-primary)!important}.bg-secondary{background:var(--bg-secondary)!important}@media (max-width: 768px){html{font-size:15px}.btn,.ant-btn{min-height:44px;padding:var(--spacing-md) var(--spacing-lg)}.card,.ant-card,.table-container,.ant-table-wrapper{border-radius:var(--radius-base)}}@media (max-width: 480px){html{font-size:14px}.btn,.ant-btn{min-height:40px;padding:var(--spacing-sm) var(--spacing-md)}.card,.ant-card,.table-container,.ant-table-wrapper{border-radius:var(--radius-sm)}}.page-container{padding:var(--spacing-lg);background:var(--bg-primary);min-height:calc(100vh - 56px);border-radius:var(--radius-md);margin:var(--spacing-md);box-shadow:var(--shadow-base)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-secondary)}.page-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--text-primary);margin:0}.page-subtitle{font-size:var(--font-size-sm);color:var(--text-tertiary);margin:var(--spacing-xs) 0 0 0}.card-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-secondary);background:var(--bg-secondary)}.card-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-secondary);background:var(--bg-secondary)}.table-container{background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-secondary);overflow:hidden;box-shadow:var(--shadow-sm)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--text-primary);font-size:var(--font-size-sm)}@media (max-width: 768px){:root{--font-size-base: 16px}.page-container{margin:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-base)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.btn{min-height:44px;padding:var(--spacing-md) var(--spacing-lg)}}@media (max-width: 480px){.page-container{margin:var(--spacing-xs);padding:var(--spacing-sm)}.card-header,.card-body,.card-footer{padding:var(--spacing-md)}}.ant-btn-primary{background-color:var(--primary-color)!important;border-color:var(--primary-color)!important;box-shadow:var(--shadow-sm)!important}.ant-btn-primary:hover,.ant-btn-primary:focus{background-color:var(--primary-hover)!important;border-color:var(--primary-hover)!important;box-shadow:var(--shadow-md)!important}.ant-btn-primary:active{background-color:var(--primary-active)!important;border-color:var(--primary-active)!important}.ant-table-wrapper{border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.ant-table-thead>tr>th{background:var(--bg-secondary)!important;border-bottom:1px solid var(--border-secondary)!important;font-weight:600!important;color:var(--text-primary)!important}.ant-table-tbody>tr>td{border-bottom:1px solid var(--border-light)!important}.ant-table-tbody>tr:hover>td{background:var(--bg-tertiary)!important}.ant-input:focus,.ant-input-focused{border-color:var(--primary-color)!important;box-shadow:0 0 0 2px var(--primary-outline)!important}.ant-select-focused .ant-select-selector{border-color:var(--primary-color)!important;box-shadow:0 0 0 2px var(--primary-outline)!important}.ant-modal-content{border-radius:var(--radius-lg)!important;overflow:hidden!important}.ant-modal-header{border-bottom:1px solid var(--border-secondary)!important;background:var(--bg-secondary)!important}.ant-modal-footer{border-top:1px solid var(--border-secondary)!important;background:var(--bg-secondary)!important}.grid{display:grid;gap:var(--spacing-md)}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 768px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.btn-sm,.ant-btn-sm,.btn-long,.ant-btn-long{font-size:15px;height:36px;padding:0 14px;border-radius:6px}.ant-btn-text{border:none!important;background:transparent!important;box-shadow:none!important}.ant-btn-text:hover{background:#4990901a!important;border:none!important}.ant-btn-text:focus{background:#4990901a!important;border:none!important;box-shadow: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)}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}
