.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:var(--background-color)}.auth-form-wrapper{background-color:var(--white-color);padding:2.5rem;border-radius:8px;box-shadow:0 4px 12px #0000001a;width:100%;max-width:400px}.auth-form-wrapper h2{text-align:center;margin-bottom:2rem;color:var(--text-color);font-size:1.75rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--secondary-color)}.form-group input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #007bff40}.auth-button{width:100%;padding:.85rem;border:none;border-radius:4px;background-color:var(--primary-color);color:var(--white-color);font-size:1.1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.auth-button:hover{background-color:var(--primary-hover-color)}.auth-switch-text{text-align:center;margin-top:1.5rem;font-size:.9rem}.auth-switch-text a{color:var(--primary-color);text-decoration:none;font-weight:600}.auth-switch-text a:hover{text-decoration:underline}.modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:var(--white-color);padding:2rem;border-radius:8px;box-shadow:0 5px 15px #0000004d;width:100%;max-width:600px;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;border-bottom:1px solid var(--border-color);padding-bottom:1rem;position:relative}.modal-header h2{margin:0;font-size:1.5rem}.modal-close-btn{position:absolute;top:50%;right:0;transform:translateY(-25%);background:transparent;border:none;font-size:2rem;cursor:pointer;color:var(--secondary-color);line-height:1}.modal-form .form-group{margin-bottom:1.5rem}.modal-actions{text-align:right;margin-top:2rem}.save-btn{padding:.75rem 1.5rem;border:none;border-radius:4px;background-color:var(--primary-color);color:var(--white-color);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.save-btn:hover{background-color:var(--primary-hover-color)}.files-section{margin-top:2rem;padding-top:1.5rem;border-top:1px dashed var(--border-color)}.files-placeholder{display:flex;justify-content:center;align-items:center;height:150px;background-color:var(--background-color);border:2px dashed var(--border-color);border-radius:8px;color:var(--secondary-color)}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color, #e0e0e0)}.action-btn-secondary{padding:.75rem 1.5rem;border:1px solid var(--secondary-color);border-radius:4px;background-color:transparent;color:var(--secondary-color);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.action-btn-secondary:hover{background-color:var(--secondary-color);color:var(--white-color)}.action-btn-danger{padding:.75rem 1.5rem;border:none;border-radius:4px;background-color:#dc3545;color:var(--white-color);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.action-btn-danger:hover{background-color:#c82333}.modal-content .modal-close-btn{position:absolute;top:1rem;right:1.5rem;transform:translateY(0);background:transparent;border:none;font-size:2rem;cursor:pointer;color:var(--secondary-color);line-height:1;transition:color .2s}.modal-content .modal-close-btn:hover{color:#dc3545}.bulk-upload-modal .modal-content{max-width:700px}.upload-dropzone{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2.5rem;border:2px dashed var(--border-color);border-radius:8px;background-color:var(--background-color);color:var(--secondary-color);text-align:center;cursor:pointer;transition:border-color .2s,background-color .2s}.upload-dropzone.drag-over{border-color:var(--primary-color);background-color:#e9f5ff}.upload-dropzone p{margin:.5rem 0}.upload-dropzone .upload-icon{width:50px;height:50px;margin-bottom:1rem;color:var(--primary-color)}.upload-dropzone .browse-link{color:var(--primary-hover-color);font-weight:600;text-decoration:none}.file-display-area{margin-top:1.5rem;padding:1rem;border:1px solid var(--border-color);border-radius:8px;background-color:#f8f9fa;display:flex;justify-content:space-between;align-items:center}.file-info{display:flex;align-items:center;gap:1rem}.file-info svg{width:24px;height:24px;color:var(--primary-color);flex-shrink:0}.file-name{font-weight:600;word-break:break-all}.remove-file-btn{background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:var(--secondary-color);transition:color .2s}.remove-file-btn:hover{color:#dc3545}.processing-indicator{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem 0}.spinner{width:40px;height:40px;border:4px solid rgba(0,0,0,.1);border-left-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1.5rem}.processing-indicator p{font-size:1.1rem;color:var(--text-color);margin:0}.processing-indicator .sub-text{font-size:.9rem;color:var(--secondary-color);margin-top:.5rem}.upload-result-modal .modal-content{max-width:800px}.result-summary{background-color:#f8f9fa;border:1px solid var(--border-color);border-radius:8px;padding:1rem;margin-bottom:1.5rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;text-align:center}.result-summary div h4{margin-bottom:.5rem;font-size:1rem;color:var(--secondary-color)}.result-summary div p{font-size:1.5rem;font-weight:600}.result-summary .success-count{color:#28a745}.result-summary .error-count{color:#dc3545}.error-details-list{max-height:40vh;overflow-y:auto;border:1px solid var(--border-color);border-radius:8px;padding:1rem}.error-item{padding:1rem;border-bottom:1px solid var(--border-color)}.error-item:last-child{border-bottom:none}.error-item-header{font-weight:600;margin-bottom:.5rem}.error-item-header span{background-color:#ffe6e6;color:#c82333;padding:.2rem .5rem;border-radius:4px;font-size:.85rem}.error-message{margin-bottom:.75rem;color:#c82333}.error-data-preview{font-family:monospace;font-size:.85rem;background-color:#f8f9fa;padding:.5rem;border-radius:4px;white-space:pre-wrap;word-break:break-all}.cost-breakdown-modal{max-width:900px;width:95%;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.cost-summary{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background-color:var(--background-color, #f5f5f5);border-radius:6px;margin-bottom:1.5rem}.summary-label{font-size:1rem;font-weight:600;color:var(--text-color, #333)}.summary-amount{font-size:1.5rem;font-weight:700;color:var(--primary-color, #007bff)}.entries-container{flex:1;overflow-y:auto;overflow-x:hidden;min-height:200px;max-height:400px}.entries-placeholder{display:flex;justify-content:center;align-items:center;height:150px;color:var(--secondary-color, #6c757d);font-size:1rem}.entries-list{display:flex;flex-direction:column;gap:1rem}.entry-card{background-color:var(--white-color, #fff);border:1px solid var(--border-color, #dee2e6);border-radius:8px;padding:1rem;transition:box-shadow .2s}.entry-card:hover{box-shadow:0 2px 8px #0000001a}.entry-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color, #dee2e6)}.entry-meta{display:flex;flex-direction:column;gap:.25rem}.entry-datetime{font-size:.875rem;font-weight:600;color:var(--text-color, #333)}.entry-addedby{font-size:.75rem;color:var(--secondary-color, #6c757d)}.entry-amount{font-family:Roboto Mono,monospace;font-size:1.25rem;font-weight:700;color:var(--primary-color, #007bff)}.entry-notes-section{margin-bottom:.75rem}.notes-label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--secondary-color, #6c757d);letter-spacing:.5px;margin-bottom:.5rem}.entry-actions{display:flex;gap:.5rem;justify-content:flex-end}.notes-display{display:block;white-space:pre-wrap;word-wrap:break-word;word-break:break-word;overflow-wrap:break-word;line-height:1.5;padding:.75rem;background-color:var(--background-color, #f8f9fa);border-radius:4px;min-height:60px;font-size:.875rem;color:var(--text-color, #333)}.no-notes{color:var(--secondary-color, #6c757d);font-style:italic}.notes-textarea{width:100%;min-height:80px;padding:.75rem;border:2px solid var(--primary-color, #007bff);border-radius:4px;font-family:inherit;font-size:.875rem;resize:vertical;line-height:1.5;box-sizing:border-box}.notes-textarea:focus{outline:none;border-color:var(--primary-color, #007bff);box-shadow:0 0 0 3px #007bff33}.btn-edit,.btn-save,.btn-cancel{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-edit{background-color:var(--primary-color, #007bff);color:var(--white-color, #fff)}.btn-edit:hover{background-color:var(--primary-hover-color, #0056b3)}.btn-save{background-color:#28a745;color:var(--white-color, #fff)}.btn-save:hover{background-color:#218838}.btn-save:disabled{background-color:#6c757d;cursor:not-allowed}.btn-cancel{background-color:transparent;border:1px solid var(--secondary-color, #6c757d);color:var(--secondary-color, #6c757d)}.btn-cancel:hover{background-color:var(--secondary-color, #6c757d);color:var(--white-color, #fff)}@media(max-width:768px){.cost-breakdown-modal{max-width:100%;width:100%;height:100vh;max-height:100vh;border-radius:0}.entries-container{max-height:none}.entry-header{flex-direction:column;gap:.5rem}.entry-amount{font-size:1.5rem}.entry-actions{justify-content:stretch}.btn-edit,.btn-save,.btn-cancel{flex:1}}.categories-list{display:grid;gap:1.5rem}.category-tile{border-radius:12px;border:1px solid var(--border-color);transition:all .2s ease-in-out;overflow:hidden;border-bottom:1px solid #adb5bd}.tile-positive{background-color:var(--success-bg);border-color:var(--success-border)}.tile-negative{background-color:var(--danger-bg);border-color:var(--danger-border)}.tile-neutral{background-color:var(--white-color)}.category-header{display:flex;align-items:center;padding:1rem 1.5rem;cursor:pointer;gap:1.5rem}.category-header:hover{background-color:#00000008}.category-name{flex-basis:30%;min-width:0;display:flex;align-items:center;gap:.75rem}.category-name-text{font-size:1.2rem;font-weight:600;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rebuild-tag{background-color:#fd7e14;color:var(--white-color);padding:.2rem .6rem;border-radius:4px;font-size:.8rem;font-weight:700;flex-shrink:0}.expand-icon{transition:transform .3s ease;flex-shrink:0}.expand-icon.expanded{transform:rotate(90deg)}.category-financials{flex-grow:1;display:grid;grid-template-columns:repeat(6,1fr);gap:1rem}.financial-item{min-width:0;text-align:center}.financial-item .value{font-weight:500;font-size:1.1rem;color:var(--text-color)}.tile-positive .financial-item .surplus-value{color:#155724}.tile-negative .financial-item .surplus-value{color:#721c24}.category-actions{display:flex;gap:.75rem;margin-left:auto}.category-action-btn{background:none;border:none;cursor:pointer;padding:.25rem;color:var(--secondary-color);border-radius:4px;transition:all .2s}.category-action-btn:hover{background-color:#0000001a;color:var(--text-color)}.category-action-btn svg{width:20px;height:20px}.tile-positive .category-action-btn{color:#218838}.tile-negative .category-action-btn{color:#c82333}.products-container{margin-left:1.5rem;border-left:2px solid #adb5bd;padding:0 1.5rem 1.5rem}.product-list-header,.product-row{display:grid;grid-template-columns:2.5fr 1.3fr 1.5fr 1.5fr 1.5fr 1.2fr 1.3fr 1fr 100px;align-items:center;gap:0em;padding:.75rem}.product-list-header{font-weight:600;color:var(--secondary-color);border-bottom:2px solid var(--text-color);margin-bottom:.5rem;font-size:.9rem}.product-row{border-radius:4px;font-size:.95rem;border-bottom:1px solid var(--border-color)}.product-row:last-child{border-bottom:none}.product-row span,.product-row input.product-input[name=name]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-name{font-weight:600}.product-actions{display:flex;gap:.5rem;justify-content:flex-end}.product-row.editing{border:1px solid var(--primary-color);box-shadow:0 0 5px #007bff4d}.product-input{width:100%;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.95rem}.product-action-btn{padding:.4rem .6rem;border-radius:4px;border:1px solid var(--secondary-color);background:gray;cursor:pointer;color:#fff}.clickable-cost{position:relative;padding:.25rem .5rem;border-radius:4px;transition:background-color .2s,color .2s}.clickable-cost:hover{background-color:var(--primary-color, #007bff);color:var(--white-color, #fff)}@media(max-width:1100px){.category-header{align-items:flex-start}.category-financials{grid-template-columns:repeat(3,1fr);text-align:left}}@media(max-width:900px){.category-header{flex-direction:column;align-items:stretch;gap:1rem}.category-financials{grid-template-columns:repeat(2,1fr)}.category-actions{margin-left:0;justify-content:flex-end}}.add-category-btn-wrapper{margin-top:1.5rem;text-align:center}.add-category-btn{padding:.75rem 2rem;border:1px dashed var(--primary-color);border-radius:8px;background-color:transparent;color:var(--primary-color);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.add-category-btn:hover{background-color:#007bff0d;border-style:solid}.add-category-form-tile{background-color:var(--white-color);border:2px solid var(--primary-color);border-radius:8px;padding:1.5rem;margin-top:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem}.add-category-form-tile .form-content{flex-grow:1;display:flex;align-items:center;gap:1.5rem}.add-category-input{width:100%;flex-grow:1;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1.1rem}.rebuild-checkbox-wrapper{display:flex;align-items:center;gap:.75rem;font-weight:600}.rebuild-checkbox-wrapper input[type=checkbox]{width:20px;height:20px;cursor:pointer}.add-category-form-tile .form-actions{display:flex;gap:1rem}.btn-cancel,.btn-save{width:120px;padding:.75rem 0;text-align:center;border-radius:4px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel{border:1px solid var(--secondary-color);background:transparent;color:var(--secondary-color)}.btn-save{border:none;background:#28a745;color:var(--white-color)}.btn-save:hover{background:#218838}.btn-save:disabled{background-color:var(--secondary-color);cursor:not-allowed}.add-product-btn-wrapper{padding:1rem 0;text-align:center}.add-product-btn{padding:.75rem 2rem;border:1px dashed var(--secondary-color);border-radius:4px;background:transparent;color:var(--secondary-color);cursor:pointer;transition:all .2s;font-size:1.1rem;font-weight:700}.add-product-btn:hover{background-color:#0000000d;color:var(--text-color);border-style:solid}.tile-positive .category-action-btn{color:#155724}.tile-positive .category-action-btn:hover{background-color:#1557241a}.tile-negative .category-action-btn{color:#721c24}.tile-negative .category-action-btn:hover{background-color:#721c241a}.product-row.view-mode{cursor:pointer;transition:background-color .2s}.product-row.view-mode:hover{background-color:#f0f0f0}.category-drag-wrapper{transition:opacity .2s ease}.category-drag-wrapper.drag-over-indicator{border-top:3px solid var(--primary-color);margin-top:-3px}.category-drag-wrapper[draggable=true]{cursor:grab!important}.category-drag-wrapper[draggable=true]:active{cursor:grabbing!important}.product-drag-wrapper{transition:opacity .2s ease}.product-drag-wrapper.product-drag-over{border-top:2px solid #adb5bd;margin-top:-2px}.product-drag-wrapper[draggable=true]{cursor:grab!important}.product-drag-wrapper[draggable=true]:active{cursor:grabbing!important}[draggable=true]{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.log-modal .modal-content{max-width:800px}.log-list-container{max-height:60vh;overflow-y:auto;border:1px solid var(--border-color);border-radius:8px;background-color:#f8f9fa}.log-item{padding:1rem;border-bottom:1px solid var(--border-color)}.log-item:last-child{border-bottom:none}.log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.log-action-user{font-weight:600;font-size:1.1rem}.log-action-user .action-tag{font-size:.8rem;padding:.2rem .6rem;border-radius:12px;color:var(--white-color);margin-right:.5rem;text-transform:uppercase}.action-tag.created{background-color:#28a745}.action-tag.updated{background-color:#007bff}.action-tag.deleted{background-color:#dc3545}.action-tag.reordered{background-color:#ffc107;color:#000}.log-timestamp{font-size:.9rem;color:var(--secondary-color)}.log-details-grid{display:grid;grid-template-columns:1fr 2fr 2fr;gap:.5rem 1rem;font-size:.95rem;padding-left:1rem}.log-details-grid .grid-header{font-weight:600;color:var(--secondary-color);border-bottom:1px solid var(--border-color);padding-bottom:.25rem}.log-details-grid .field-name{font-weight:500;white-space:nowrap}.log-details-grid .old-value{color:#dc3545;text-decoration:line-through}.log-details-grid .new-value{color:#28a745}.log-created-message{padding-left:1rem;font-style:italic;color:var(--secondary-color)}.log-placeholder{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--secondary-color);font-size:1.1rem}.log-modal .modal-close-btn{transform:translateY(-25%)}.toggle-switch-container{display:flex;align-items:center;gap:12px}.toggle-switch{position:relative;display:inline-block;width:50px;height:26px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.3s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}input:checked+.toggle-slider{background-color:var(--primary-color, #142536)}input:focus+.toggle-slider{box-shadow:0 0 1px var(--primary-color, #142536)}input:checked+.toggle-slider:before{transform:translate(24px)}input:disabled+.toggle-slider{cursor:not-allowed;opacity:.6}.toggle-label{cursor:pointer;font-size:14px;color:var(--text-color, #333);-webkit-user-select:none;-moz-user-select:none;user-select:none}input:disabled~.toggle-label{cursor:not-allowed;opacity:.6}.project-detail-header{background-color:var(--white-color);padding:1.5rem 2rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 8px 25px #0001011a}.project-title-bar{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:1.5rem;margin-bottom:1.5rem}.project-title-group h1{margin:0 0 .5rem;font-size:2.25rem}.project-actions{display:flex;gap:1rem}.project-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}@media(max-width:900px){.project-summary{grid-template-columns:repeat(2,1fr)}}.summary-card{background-color:#f8f9fa;border:1px solid var(--border-color);border-radius:8px;padding:1.25rem}.summary-card h3{margin:0 0 .5rem;font-size:.9rem;color:var(--secondary-color);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.summary-card p{margin:0;font-size:1.75rem;font-weight:600;color:var(--text-color)}.summary-card .surplus-positive{color:#28a745}.summary-card .surplus-negative{color:#dc3545}@media(max-width:1100px){.project-summary{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.project-summary{grid-template-columns:repeat(2,1fr)}.project-title-bar{flex-direction:column;align-items:stretch;gap:1.5rem}}@media(max-width:600px){.project-summary{grid-template-columns:1fr}.project-sub-header{flex-direction:column;gap:.5rem;align-items:flex-start}}.upload-btn{background-color:var(--primary-color);color:var(--white-color);width:auto;padding:.75rem 1.5rem}.upload-btn:hover{opacity:.9}.upload-btn:disabled{background-color:var(--secondary-color);cursor:not-allowed}.project-page-modal .modal-close-btn{top:1rem;right:1.5rem;transform:translateY(-25%)}.breakdown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.breakdown-header h2{font-size:1.5rem;color:var(--text-color);margin:0}.breakdown-actions{display:flex;align-items:center;gap:1.5rem}.project-bulk-upload-modal .modal-close-btn,.project-category-edit-modal .modal-close-btn,.project-delete-modal .modal-close-btn{transform:translateY(-30%)}.unsaved-changes-badge{display:inline-flex;align-items:center;background:#fef3c7;color:#92400e;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;margin-left:8px}.unsaved-changes-badge .dot{width:6px;height:6px;background:#f59e0b;border-radius:50%;margin-right:6px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.project-tile-link{text-decoration:none;color:inherit;display:block}.project-tile{display:grid;grid-template-columns:60px 1.5fr 2fr 1fr 2.5fr;align-items:center;gap:1rem;background-color:#fdfdfd;border:1px solid var(--border-color);border-radius:8px;padding:1.25rem 1.5rem;transition:all .2s ease-in-out;box-shadow:0 1px 3px #0000000a}.project-tile:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 8px #00000014}.tile-serial-number{text-align:center;font-weight:600;color:var(--secondary-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tile-project-name{font-weight:600;color:var(--text-color)}.tile-client-name,.tile-value{color:var(--secondary-color)}.tile-location-wrapper{display:flex;justify-content:space-between;align-items:center;gap:1rem;min-width:0;color:var(--secondary-color)}.project-arrow{flex-shrink:0;font-size:1.5rem;color:var(--secondary-color)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.dashboard-header h1{font-size:2rem;color:var(--text-color)}.create-project-btn{padding:.75rem 1.5rem;border:none;border-radius:4px;background-color:var(--primary-color);color:var(--white-color);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.create-project-btn:hover{background-color:var(--primary-hover-color)}.projects-table-wrapper{width:100%;overflow-x:auto}.projects-list-header{display:grid;grid-template-columns:60px 1.5fr 2fr 1.5fr 2.5fr;align-items:center;gap:1.5rem;padding:0 1.5rem .75rem;margin-bottom:.75rem;color:var(--secondary-color);font-size:.9rem;font-weight:600;border-bottom:2px solid var(--border-color);min-width:850px}.projects-list{display:grid;gap:1rem;min-width:800px}.loading-text,.error-text,.no-projects-text{text-align:center;font-size:1.2rem;color:var(--secondary-color);margin-top:4rem}.dashboard-create-project-modal .modal-close-btn{transform:translateY(-25%)}.search-bar-container{position:relative;width:100%;max-width:400px}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #007bff40}:root{--sidebar-width-expanded: 260px;--sidebar-width-collapsed: 80px;--content-margin: 15px;--border-radius: 12px;--transition-speed: .4s;--transition-timing: cubic-bezier(.25, 1, .5, 1)}body{margin:0;font-family:var(--font-family-sans-serif);background-color:var(--primary-color);color:var(--text-color);overflow:hidden}.app-container{display:flex}.sidebar{background-color:var(--primary-color);height:100vh;position:fixed;top:0;left:0;display:flex;flex-direction:column;padding:20px 0;z-index:100;transition:width var(--transition-speed) var(--transition-timing),transform var(--transition-speed) var(--transition-timing);overflow-x:hidden;overflow-y:hidden;scrollbar-width:none}.sidebar.expanded{width:var(--sidebar-width-expanded);transition:width var(--transition-speed) var(--transition-timing),overflow-y 0s .8s;overflow-y:auto;scrollbar-width:thin}.sidebar::-webkit-scrollbar{width:0}.sidebar.expanded::-webkit-scrollbar{width:6px}.sidebar.expanded::-webkit-scrollbar-track{background:#ffffff0d}.sidebar.expanded::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar.expanded::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.sidebar.collapsed{overflow-y:hidden}.sidebar-header{padding:0 25px 30px;font-size:24px;font-weight:700;color:var(--white-color);text-align:center;white-space:nowrap}.sidebar-nav{list-style:none;padding:0;margin:0;flex-grow:1;position:relative}.sidebar-nav li{position:relative;margin:0 15px}.nav-link{display:flex;align-items:center;gap:16px;color:var(--white-color);opacity:.7;text-decoration:none;padding:16px 25px;height:57px;font-size:15px;font-weight:500;position:relative;z-index:2;transition:all .25s ease-in-out;white-space:nowrap}.nav-link:not(.active):hover{opacity:1;font-weight:700}nav.sidebar .sidebar-nav .nav-link.active{color:var(--text-color)!important;opacity:1;font-weight:700}.nav-icon{flex-shrink:0;width:24px;height:24px;transition:opacity .3s ease}.nav-text{transition:opacity .3s ease,width .3s ease}#nav-tracker{position:absolute;left:0;width:100%;height:57px;background-color:var(--background-color);z-index:1;border-top-left-radius:var(--border-radius);border-bottom-left-radius:var(--border-radius);transition:top var(--transition-speed) var(--transition-timing)}#nav-tracker:before,#nav-tracker:after{content:"";position:absolute;right:0;width:15px;height:15px}#nav-tracker:before{top:-15px;border-bottom-right-radius:var(--border-radius);box-shadow:5px 5px 0 5px var(--background-color)}#nav-tracker:after{bottom:-15px;border-top-right-radius:var(--border-radius);box-shadow:5px -5px 0 5px var(--background-color)}.sidebar-footer{padding:15px;border-top:1px solid rgba(255,255,255,.1);transition:opacity .3s ease-in-out;display:flex;flex-direction:column;gap:10px}.sidebar-footer.hidden{opacity:0;pointer-events:none}.logout-button{width:100%;padding:12px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background-color:#ffffff1a;color:#fffc;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.logout-button:hover{background-color:#fff3;border-color:#ffffff4d;color:var(--white-color)}.switch-company-btn{width:100%;padding:10px;border:1px dashed rgba(255,255,255,.4);border-radius:8px;background-color:transparent;color:var(--secondary-color);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.switch-company-btn:hover{border-color:var(--white-color);color:var(--white-color);background-color:#ffffff0d}.user-profile{display:flex;align-items:center;padding:10px 5px;border-radius:var(--border-radius);gap:10px;cursor:pointer}.user-details{flex-grow:1;min-width:0}.user-name{color:var(--white-color);font-weight:500;word-wrap:break-word}.user-role-display{display:block;font-size:.8rem;color:var(--secondary-color);opacity:.8}.gear-icon{flex-shrink:0;color:var(--white-color);opacity:.7;width:24px;height:24px;transition:transform .3s ease-in-out}.user-profile:hover .gear-icon{transform:rotate(90deg)}.main-content-wrapper{position:absolute;top:var(--content-margin);right:var(--content-margin);bottom:var(--content-margin);background-color:var(--background-color);border-radius:var(--border-radius);overflow:hidden;transition:left var(--transition-speed) var(--transition-timing)}.main-content{width:100%;height:100%;overflow-y:auto;padding:2rem;scrollbar-gutter:stable}.hamburger-menu{display:none;position:fixed;top:10px;left:10px;z-index:101;background:var(--primary-color);color:var(--white-color);border:1px solid rgba(255,255,255,.2);border-radius:8px;width:40px;height:40px;cursor:pointer}.hamburger-menu svg{width:20px;height:20px}.main-content-wrapper.full-screen-mode{top:0;right:0;bottom:0;border-radius:0;background-color:#f3f4f6}.main-content.no-padding{padding:0!important;overflow:hidden}@media(min-width:769px){.sidebar~.main-content-wrapper.full-screen-mode{left:var(--sidebar-width-expanded)}.sidebar.collapsed~.main-content-wrapper.full-screen-mode{left:var(--sidebar-width-collapsed)}.sidebar.collapsed{width:var(--sidebar-width-collapsed)}.sidebar.collapsed .nav-link{justify-content:center;padding:16px 0}.sidebar.collapsed .nav-text{opacity:0;width:0;pointer-events:none}.sidebar.collapsed .switch-company-btn{display:none}.sidebar~.main-content-wrapper{left:calc(var(--sidebar-width-expanded) + var(--content-margin))}.sidebar.collapsed~.main-content-wrapper{left:calc(var(--sidebar-width-collapsed) + var(--content-margin))}}@media(max-width:768px){.hamburger-menu{display:grid;place-items:center}.sidebar{transform:translate(-100%);width:var(--sidebar-width-expanded)}.sidebar.mobile-open{transform:translate(0);box-shadow:0 0 50px #0000004d}.main-content-wrapper{inset:0;border-radius:0;height:100vh}}.procurement-summary-header{background-color:var(--white-color);padding:1.5rem 2rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 8px 25px #0101011a}.procurement-summary-header h1{font-size:1.75rem;margin:0 0 .75rem;word-break:break-word}.procurement-summary-details{display:flex;flex-wrap:wrap;gap:1rem 2.5rem;color:var(--secondary-color);font-size:1rem}.procurement-summary-details span{font-weight:600;word-break:break-word}.loading-text,.error-text{text-align:center;font-size:1.2rem;color:var(--secondary-color);margin-top:4rem}.procurement-workspace{background-color:var(--white-color);padding:2rem;border-radius:12px;box-shadow:0 4px 12px #00000012}.procurement-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1.5rem}.search-bar-container{position:relative;width:100%;max-width:450px}.search-icon{position:absolute;top:50%;left:1rem;transform:translateY(-50%);color:var(--secondary-color);width:20px;height:20px}.search-input{width:100%;padding:.75rem 1rem .75rem 3rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #14253640}.add-item-btn{padding:.75rem 1.5rem;border:none;border-radius:4px;background-color:var(--primary-color);color:var(--white-color);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.add-item-btn:hover{background-color:var(--primary-hover-color)}.items-table-wrapper{position:relative;width:100%;overflow-x:auto}.items-table{width:100%;min-width:1600px}.items-table-header,.item-row{display:grid;grid-template-columns:60px 2.5fr 1.5fr 1.4fr 1.5fr .5fr 1.5fr 1.7fr 1.2fr 1.2fr 1.2fr 1.9fr 1.2fr 50px;align-items:center;gap:1.5rem;padding:.9rem .5rem}.items-table-header{font-weight:600;color:var(--secondary-color);border-bottom:2px solid var(--text-color);padding-bottom:1rem;margin-bottom:.5rem;font-size:.85rem}.serial-number-cell{text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-row{font-size:.95rem;border-bottom:1px solid var(--border-color)}.items-table>.item-row:last-child{border-bottom:none}.item-cell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-actions{display:flex;gap:.75rem;justify-content:flex-end}.add-item-modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.add-item-modal-content{background-color:var(--white-color);border-radius:8px;box-shadow:0 5px 15px #0003;width:100%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.add-item-modal-content form{display:flex;flex-direction:column;height:100%;overflow:hidden}.add-item-modal-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;position:relative;flex-shrink:0}.add-item-modal-header h2{margin:0;font-size:1.5rem}.add-item-modal-body{padding:2rem;overflow-y:auto;flex:1;min-height:0}.add-item-form-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2rem 1.5rem}.form-group.description{grid-column:span 2}.form-group.note{grid-column:span 3}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:var(--secondary-color);font-size:.9rem}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem}.add-item-modal-footer{padding:1.5rem 2rem;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.btn-add-to-project{background-color:#142536;color:var(--white-color);border:none;border-radius:4px;padding:.85rem 2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-add-to-project:hover{opacity:.9}.btn-add-to-project:disabled{background-color:var(--secondary-color);cursor:not-allowed}@media(max-width:1200px){.add-item-form-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.add-item-form-grid{grid-template-columns:repeat(2,1fr)}.form-group.description,.form-group.note{grid-column:span 2}}@media(max-width:600px){.add-item-form-grid{grid-template-columns:1fr}.form-group.description,.form-group.note{grid-column:span 1}}.searchable-dropdown{position:relative}.dropdown-options{position:absolute;top:100%;left:0;right:0;background-color:var(--white-color);border:1px solid var(--border-color);border-top:none;border-radius:0 0 4px 4px;list-style:none;margin:0;padding:0;max-height:150px;overflow-y:auto;z-index:1001}.dropdown-options li{padding:.75rem;cursor:pointer}.dropdown-options li:hover{background-color:var(--background-color)}.keep-open-slider{display:flex;align-items:center;gap:.75rem}.keep-open-slider .switch{position:relative;display:inline-block;width:50px;height:28px}.keep-open-slider .switch input{opacity:0;width:0;height:0}.keep-open-slider .slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:28px}.keep-open-slider .slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}.keep-open-slider input:checked+.slider{background-color:#28a745}.keep-open-slider input:checked+.slider:before{transform:translate(22px)}.add-item-modal-footer{justify-content:space-between;align-items:center}.auto-suggest-wrapper{position:relative}.suggestions-list{position:absolute;top:100%;left:0;right:0;background-color:var(--white-color);border:1px solid var(--border-color);border-top:none;border-radius:0 0 4px 4px;list-style:none;margin:0;padding:0;max-height:200px;overflow-y:auto;z-index:1002;box-shadow:0 4px 8px #0000001a}.suggestions-list li{padding:.75rem;cursor:pointer;font-size:.95rem}.suggestions-list li:hover{background-color:var(--background-color)}.item-row.delay-alert{background-color:#fff3cd;border-left:4px solid #ffc107;border-right:4px solid #ffc107}.clickable-cell{cursor:pointer;-webkit-text-decoration:underline dashed;text-decoration:underline dashed;text-decoration-thickness:1px;text-underline-offset:3px}.clickable-cell:hover{color:var(--primary-color)}.full-text-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1010}.full-text-modal-content{background-color:var(--white-color);padding:2rem;border-radius:8px;max-width:600px;width:90%;box-shadow:0 5px 15px #0000004d;position:relative}.full-text-modal-content h3{margin-top:0;margin-bottom:1.5rem;border-bottom:1px solid var(--border-color);padding-bottom:1rem}.full-text-modal-content p{margin:0;white-space:pre-wrap;word-break:break-word;max-height:60vh;overflow-y:auto}.item-row.selected-for-edit{background-color:var(--success-bg)}.edit-form-container{grid-column:1 / -1;padding:1.5rem;background-color:#f8f9fa;border-bottom:1px solid var(--border-color);animation:slideDownFade .3s ease-out forwards;transform-origin:top}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.edit-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.edit-form-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}.scroll-indicator-popup{position:absolute;bottom:20px;right:20px;background-color:var(--primary-color);color:var(--white-color);padding:.75rem 1.25rem;border-radius:8px;box-shadow:0 4px 15px #0003;z-index:10;font-size:.9rem;font-weight:500;opacity:0;transform:translateY(10px);animation:fadeInOut 5s ease-in-out forwards}@keyframes fadeInOut{0%{opacity:0;transform:translateY(10px)}15%{opacity:1;transform:translateY(0)}85%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(10px)}}.floating-scroller-wrapper{position:sticky;bottom:0;left:0;width:100%;height:12px;background-color:#f0f0f0e6;padding:0;overflow-x:auto;scrollbar-width:thin;scrollbar-color:#888 #f1f1f1}.floating-scroller-wrapper::-webkit-scrollbar{height:12px}.floating-scroller-wrapper::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.floating-scroller-wrapper::-webkit-scrollbar-thumb{background:#888;border-radius:10px}.floating-scroller-wrapper::-webkit-scrollbar-thumb:hover{background:#555}.floating-scroller-content{height:1px}.toolbar-actions{display:flex;align-items:center;gap:1rem}.bulk-upload-btn{padding:.75rem 1.5rem;border:1px solid var(--primary-color);border-radius:4px;background-color:transparent;color:var(--primary-color);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.bulk-upload-btn:hover{background-color:var(--primary-color);color:var(--white-color)}.procurement-add-item-modal .modal-close-btn{transform:translateY(-25%);right:1.5rem}.procurement-bulk-upload-modal .modal-close-btn,.procurement-upload-result-modal .modal-close-btn{transform:translateY(-25%)}.procurement-full-text-modal .modal-close-btn{top:1rem;right:1rem}.procurement-delete-modal .modal-close-btn{transform:translateY(-25%)}.hub-header{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--border-color);padding-bottom:1.5rem;margin-bottom:2rem;flex-wrap:wrap;gap:1.5rem}.project-title-group{flex:1;min-width:0}.project-title-group h1{margin:0 0 .5rem;font-size:2.25rem;word-break:break-word}.project-sub-header{display:flex;flex-wrap:wrap;gap:1rem 2rem;color:var(--secondary-color);font-size:1.1rem;margin-top:.75rem}.project-sub-header span{word-break:break-word}.contract-value-display{font-weight:600;color:var(--text-color)}.project-actions{display:flex;gap:1rem;flex-shrink:0}.action-btn{display:flex;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 0;width:120px;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.action-btn svg{width:18px;height:18px}.edit-btn{background-color:var(--secondary-color);color:var(--white-color)}.edit-btn:hover{background-color:#5a6268}.delete-btn{background-color:#dc3545;color:var(--white-color)}.delete-btn:hover{background-color:#c82333}.project-hub-delete-modal .modal-close-btn{transform:translateY(-25%)}.tools-container h2{font-size:1.5rem;color:var(--text-color);margin-bottom:1.5rem}.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.tool-card{background-color:var(--white-color);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:2rem;text-align:center;text-decoration:none;color:inherit;box-shadow:0 4px 12px #0000000d;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out}.tool-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px #0000001a}.tool-icon{width:48px;height:48px;color:var(--primary-color);margin-bottom:1rem}.tool-card h3{font-size:1.25rem;margin:0 0 .5rem}.tool-card p{color:var(--secondary-color);font-size:.95rem;line-height:1.5}.hub-project-edit-modal .modal-close-btn{transform:translateY(-25%)}.page-header{margin-bottom:2rem}.page-header h1{margin:0 0 5px;font-size:2rem}.page-breadcrumb{font-size:1rem;color:var(--secondary-color);margin:0}.tabs-container{display:flex;border-bottom:2px solid var(--border-color);margin-bottom:2rem}.tab-button{padding:.75rem 1.5rem;border:none;background-color:transparent;cursor:pointer;font-size:1rem;font-weight:600;color:var(--secondary-color);position:relative;bottom:-2px;transition:color .2s ease-in-out}.tab-button:hover{color:var(--primary-color)}.tab-button.active{color:var(--primary-color);border-bottom:2px solid var(--primary-color)}.company-selection-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f4f6f8;padding:2rem}.company-selection-header{text-align:center;margin-bottom:3rem}.company-selection-header h1{font-size:2rem;color:var(--primary-color);margin-bottom:.5rem}.company-selection-header p{color:var(--secondary-color);font-size:1.1rem}.company-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;width:100%;max-width:1000px}.company-card{background-color:#fff;border:1px solid var(--border-color);border-radius:8px;padding:2rem;cursor:pointer;transition:all .2s ease-in-out;display:flex;flex-direction:column;align-items:flex-start;box-shadow:0 2px 4px #0000000d}.company-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a;border-color:var(--primary-color)}.company-card h3{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-color)}.company-role-badge{display:inline-block;padding:.25rem .75rem;background-color:#e9ecef;color:var(--secondary-color);border-radius:16px;font-size:.85rem;font-weight:600;margin-bottom:1rem}.company-card-footer{margin-top:auto;width:100%;display:flex;justify-content:flex-end}.select-btn{background:transparent;color:var(--primary-color);border:none;font-weight:600;font-size:.95rem;cursor:pointer}.select-btn:hover{text-decoration:underline}.loading-container{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;color:var(--secondary-color)}.logout-footer-btn{margin-top:3rem;background:transparent;border:1px solid var(--secondary-color);color:var(--secondary-color);padding:.6rem 2rem;border-radius:4px;cursor:pointer;font-weight:600;transition:all .2s}.logout-footer-btn:hover{border-color:var(--primary-color);color:var(--primary-color);background-color:#1425360d}.roles-page-container{padding-bottom:2rem}.roles-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1.5rem}.roles-header h1{margin:0;font-size:2rem;color:var(--text-color)}.roles-actions{display:flex;gap:1rem;align-items:center;flex-grow:1;justify-content:flex-end}.create-role-btn{padding:.75rem 1.5rem;border:none;border-radius:4px;background-color:var(--primary-color);color:var(--white-color);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;white-space:nowrap}.create-role-btn:hover{background-color:var(--primary-hover-color)}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.role-tile{background-color:var(--white-color);border:1px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;overflow:hidden;height:300px;box-shadow:0 2px 8px #0000000d;transition:transform .2s,box-shadow .2s}.role-tile:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a}.role-tile-header{padding:1.25rem;border-bottom:1px solid var(--border-color);background-color:#f8f9fa}.role-tile-header h3{margin:0;font-size:1.25rem;color:var(--primary-color);word-break:break-word}.role-tile-body{flex-grow:1;padding:1rem;overflow-y:auto;background-color:var(--white-color)}.permission-tags{display:flex;flex-wrap:wrap;gap:.5rem}.perm-tag{background-color:#e9ecef;color:var(--secondary-color);padding:.25rem .6rem;border-radius:4px;font-size:.85rem;font-family:monospace;word-break:break-all}.role-tile-footer{padding:1rem;border-top:1px solid var(--border-color);background-color:var(--white-color)}.edit-role-btn{width:100%;padding:.75rem;background-color:var(--secondary-color);color:var(--white-color);border:none;border-radius:4px;font-weight:600;cursor:pointer;transition:background-color .2s}.edit-role-btn:hover{background-color:#5a6268}.roles-modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.roles-modal-content{background-color:var(--white-color);border-radius:8px;width:100%;max-width:900px;height:85vh;display:flex;flex-direction:column;box-shadow:0 10px 25px #0003;position:relative}.roles-modal .modal-close-btn{top:1.5rem;right:1.5rem;font-size:2rem;color:var(--secondary-color);background:none;border:none;cursor:pointer;position:absolute}.roles-modal-header{padding:2rem;border-bottom:1px solid var(--border-color)}.roles-modal-header h2{margin:0 0 1rem}.role-name-input{width:100%;padding:.75rem;font-size:1.1rem;border:1px solid var(--border-color);border-radius:4px}.roles-modal-body{flex-grow:1;overflow-y:auto;padding:2rem;background-color:#f8f9fa}.permission-category-group{margin-bottom:2rem;background-color:var(--white-color);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem}.permission-category-group h3{margin:0 0 1rem;color:var(--primary-color);border-bottom:2px solid #e9ecef;padding-bottom:.5rem}.permission-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid #f1f3f5}.permission-item:last-child{border-bottom:none}.perm-info{flex-grow:1;padding-right:1rem}.perm-name{font-weight:600;color:var(--text-color);display:block;margin-bottom:.25rem}.perm-desc{font-size:.85rem;color:var(--secondary-color)}.switch{position:relative;display:inline-block;width:50px;height:28px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:34px}.slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:var(--primary-color)}input:checked+.slider:before{transform:translate(22px)}.roles-modal-footer{padding:1.5rem 2rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;background-color:var(--white-color)}.save-role-btn{padding:.75rem 2.5rem;background-color:#28a745;color:#fff;border:none;border-radius:4px;font-weight:600;font-size:1rem;cursor:pointer}.save-role-btn:disabled{background-color:var(--secondary-color);cursor:not-allowed}@media(max-width:600px){.roles-header{flex-direction:column;align-items:stretch}.roles-actions{flex-direction:column-reverse}.permission-item{flex-direction:column;align-items:flex-start;gap:1rem}.switch{align-self:flex-end}}.resources-hub-container{padding:2rem;max-width:1200px;margin:0 auto}.hub-header{margin-bottom:3rem;text-align:center}.hub-header h1{font-size:2.5rem;color:var(--text-color);margin-bottom:.5rem}.hub-header p{color:var(--secondary-color);font-size:1.1rem}.resource-tiles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;justify-items:center}.resource-hub-tile{background-color:var(--white-color);border:1px solid var(--border-color);border-radius:12px;padding:3rem 2rem;width:100%;max-width:350px;aspect-ratio:1 / 1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:inherit;box-shadow:0 4px 12px #0000000d;transition:transform .2s,box-shadow .2s;cursor:pointer}.resource-hub-tile:hover{transform:translateY(-8px);box-shadow:0 12px 24px #0000001a;border-color:var(--primary-color)}.hub-icon-large{width:80px;height:80px;color:var(--primary-color);margin-bottom:1.5rem}.resource-hub-tile h2{font-size:1.5rem;margin:0 0 .5rem}.resource-hub-tile p{text-align:center;color:var(--secondary-color)}@media(max-width:768px){.resource-hub-tile{max-width:100%;aspect-ratio:auto;height:200px}}.member-modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.member-modal-content{background-color:var(--white-color);width:100%;max-width:900px;height:90vh;border-radius:8px;display:flex;flex-direction:column;position:relative;overflow:hidden;box-shadow:0 10px 25px #0003}.member-modal-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.member-modal-header h2{margin:0;font-size:1.5rem}.member-modal .modal-close-btn{font-size:2rem;background:none;border:none;cursor:pointer;color:var(--secondary-color);padding:0;line-height:1}.member-modal-body{flex:1;overflow-y:auto;padding:2rem}.form-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #f1f3f5}.form-section h3{color:var(--primary-color);margin-bottom:1.5rem;font-size:1.1rem;text-transform:uppercase;letter-spacing:.5px}.full-width{grid-column:1 / -1}.input-group label{font-weight:500;font-size:.9rem;color:var(--secondary-color)}.input-group input,.input-group select{padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem}.member-modal-footer{padding:1.5rem 2rem;border-top:1px solid var(--border-color);background-color:#f8f9fa;display:flex;justify-content:flex-end;flex-shrink:0}.save-btn{padding:.75rem 3rem;background-color:#28a745;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer}.save-btn:disabled{background-color:var(--secondary-color);cursor:not-allowed}.project-pills-container{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.project-pill{background-color:#e9ecef;border:1px solid #dee2e6;border-radius:16px;padding:.25rem .75rem;font-size:.9rem;display:flex;align-items:center;gap:.5rem}.pill-remove{cursor:pointer;color:#dc3545;font-weight:700;display:flex;align-items:center}.pill-remove:hover{color:#a71d2a}@media(max-width:768px){.form-grid{grid-template-columns:1fr}}.people-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.people-header h1{font-size:2rem;color:var(--text-color);margin:0}.add-member-btn{padding:.75rem 1.5rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer;white-space:nowrap}.add-member-btn:hover{background-color:var(--primary-hover-color)}.people-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.member-card{background-color:var(--white-color);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;cursor:pointer;transition:border-color .2s;position:relative}.member-card:hover{border-color:var(--primary-color)}.member-type-badge{position:absolute;top:1rem;right:1rem;font-size:.75rem;padding:.2rem .5rem;border-radius:4px;font-weight:700;text-transform:uppercase}.badge-real{background-color:#e3f2fd;color:#0d47a1}.badge-ghost{background-color:#f3e5f5;color:#7b1fa2}.member-name{font-size:1.2rem;font-weight:600;margin-bottom:.25rem}.member-role{color:var(--secondary-color);font-size:.9rem;margin-bottom:1rem;display:block}.member-details p{margin:.25rem 0;font-size:.9rem;display:flex;align-items:center;gap:.5rem;color:var(--text-color)}.member-details svg{color:var(--secondary-color)}.member-modal .modal-close-btn{top:2.5rem;right:1.5rem}.company-modal-content{max-width:800px;max-height:90vh;overflow-y:auto;padding:2rem}.form-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e0e0e0}.form-section:last-of-type{border-bottom:none;padding-bottom:0}.form-section h3{font-size:1.1rem;font-weight:600;color:var(--primary-color, #142536);margin-bottom:1rem}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.input-group{display:flex;flex-direction:column}.input-group label{font-size:.9rem;font-weight:500;color:#333;margin-bottom:.5rem}.input-group textarea{resize:vertical;font-family:inherit}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}.action-btn-primary,.action-btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .2s}.action-btn-primary{background-color:var(--primary-color, #142536);color:#fff}.action-btn-primary:hover:not(:disabled){background-color:var(--primary-hover-color, #0f1e2a)}.action-btn-primary:disabled{opacity:.6;cursor:not-allowed}.action-btn-secondary{background-color:#f5f5f5;color:#333}.action-btn-secondary:hover:not(:disabled){background-color:#e0e0e0}.action-btn-secondary:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.company-modal-content{padding:1.5rem;max-height:95vh}.form-grid{grid-template-columns:1fr;gap:1rem}.input-group[style*=grid-column]{grid-column:1!important}.modal-actions{flex-direction:column}.action-btn-primary,.action-btn-secondary{width:100%}}.companies-page{padding:2rem;background-color:#f8f9fa;min-height:100vh}.companies-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.companies-header h1{font-size:2rem;font-weight:600;color:var(--primary-color, #142536);margin:0}.add-company-btn{padding:.75rem 1.5rem;background-color:var(--primary-color, #142536);color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer;transition:background-color .2s}.add-company-btn:hover{background-color:var(--primary-hover-color, #0f1e2a)}.type-filter{padding:.75rem 1rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem;cursor:pointer;background-color:#fff}.type-filter:focus{outline:none;border-color:var(--primary-color, #142536)}.loading-text{text-align:center;padding:3rem;font-size:1.1rem;color:#666}.empty-state{text-align:center;padding:4rem 2rem;background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.empty-state p{font-size:1.1rem;color:#666;margin:0}.companies-table-container{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.companies-table{width:100%;border-collapse:collapse;table-layout:fixed}.companies-table thead{background-color:#f5f5f5}.companies-table th{padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.companies-table th.sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.companies-table th.sortable:hover{background-color:#ececec}.companies-table td{padding:1rem;border-bottom:1px solid #f0f0f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-sr-no{width:60px;text-align:center}.col-name{width:180px}.col-contact-person{width:150px}.col-phone,.col-company-number{width:130px}.col-email{width:180px}.col-work-scope{width:200px}.col-type{width:100px}.col-actions{width:80px;text-align:center}.type-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;text-transform:uppercase}.badge-client{background-color:#e3f2fd;color:#1976d2}.badge-associate{background-color:#f3e5f5;color:#7b1fa2}.delete-btn{background:none;border:none;cursor:pointer;color:#d32f2f;padding:.25rem;transition:color .2s}.delete-btn:hover{color:#b71c1c}.companies-page .modal-close-btn{position:absolute;right:1.5rem;top:1.5rem;background:none;border:none;font-size:1.75rem;cursor:pointer;color:#666;line-height:1;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.companies-page .modal-close-btn:hover{color:#333}@media(max-width:1400px){.companies-table{min-width:1200px}}@media(max-width:768px){.companies-page{padding:1rem}.companies-header{flex-direction:column;align-items:flex-start;gap:1rem}.companies-header>div{width:100%;flex-direction:column}.search-bar-container{width:100%!important}.type-filter,.add-company-btn{width:100%}.companies-table-container{overflow-x:scroll}.companies-table{min-width:1200px}}.equipments-page{padding:2rem;background-color:#f8f9fa;min-height:100vh}.equipments-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.equipments-header h1{font-size:2rem;font-weight:600;color:var(--primary-color, #142536);margin:0}.header-actions{display:flex;gap:1rem;align-items:center}.add-equipment-btn{padding:.75rem 1.5rem;background-color:var(--primary-color, #142536);color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer;transition:background-color .2s;white-space:nowrap}.add-equipment-btn:hover{background-color:var(--primary-hover-color, #0f1e2a)}.ownership-filter{padding:.75rem 1rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem;cursor:pointer;background-color:#fff}.ownership-filter:focus{outline:none;border-color:var(--primary-color, #142536)}.equipments-table-container{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.equipments-table{width:100%;border-collapse:collapse;table-layout:fixed}.equipments-table thead{background-color:#f5f5f5}.equipments-table th{padding:1rem .75rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.9rem}.equipments-table th.sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.equipments-table th.sortable:hover{background-color:#ececec}.equipments-table td{padding:.875rem .75rem;border-bottom:1px solid #f0f0f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.9rem}.clickable-row{cursor:pointer;transition:background-color .2s}.clickable-row:hover{background-color:#f9f9f9}.equipments-table .col-sr-no{width:60px;text-align:center}.equipments-table .col-name{width:160px}.equipments-table .col-plate{width:100px}.equipments-table .col-company{width:120px}.equipments-table .col-reg-no{width:100px}.equipments-table .col-type{width:120px}.equipments-table .col-insurance,.equipments-table .col-fc,.equipments-table .col-green-tax{width:110px}.equipments-table .col-ownership{width:90px}.equipments-table .col-actions{width:120px;text-align:center}.ownership-badge{display:inline-block;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.badge-owned{background-color:#e8f5e9;color:#2e7d32}.badge-rented{background-color:#e3f2fd;color:#1976d2}.badge-other{background-color:#f5f5f5;color:#616161}.action-buttons{display:flex;gap:.5rem;justify-content:center}.action-btn{background:none;border:none;cursor:pointer;padding:.35rem;border-radius:4px;transition:background-color .2s,color .2s;display:flex;align-items:center;justify-content:center}.action-btn.edit-btn{color:#1976d2}.action-btn.edit-btn:hover{background-color:#e3f2fd}.action-btn.logs-btn{color:#7b1fa2}.action-btn.logs-btn:hover{background-color:#f3e5f5}.action-btn.delete-btn{color:#d32f2f}.action-btn.delete-btn:hover{background-color:#ffebee}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding:1rem}.pagination-btn{padding:.5rem 1rem;background-color:var(--primary-color, #142536);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.pagination-btn:disabled{background-color:#ccc;cursor:not-allowed}.pagination-btn:not(:disabled):hover{background-color:var(--primary-hover-color, #0f1e2a)}.pagination-info{font-size:.9rem;color:#666}.equipment-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.equipment-modal-content{background:#fff;border-radius:8px;width:90%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;position:relative}.equipment-modal-content .modal-header{padding:1.5rem;border-bottom:1px solid #e0e0e0;position:relative}.equipment-modal-content .modal-header h2{margin:0;font-size:1.5rem;color:var(--primary-color, #142536);padding-right:2rem}.equipment-modal-content .modal-close-btn{position:absolute;right:1.5rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.75rem;cursor:pointer;color:#666;line-height:1;padding:0}.equipment-modal-content .modal-close-btn:hover{color:#333}.equipment-modal-content form{overflow-y:auto;padding:1.5rem;flex:1}.form-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #f0f0f0}.form-section:last-of-type{border-bottom:none;margin-bottom:0}.form-section h3{font-size:1rem;font-weight:600;color:var(--primary-color, #142536);margin:0 0 1rem;text-transform:uppercase;letter-spacing:.5px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-size:.9rem;font-weight:500;color:#555}.input-group input,.input-group select,.input-group textarea{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem;transition:border-color .2s}.input-group input:focus,.input-group select:focus,.input-group textarea:focus{outline:none;border-color:var(--primary-color, #142536)}.input-group textarea{resize:vertical;min-height:80px}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #e0e0e0;background:#fafafa}.action-btn-primary{padding:.75rem 1.5rem;background-color:var(--primary-color, #142536);color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer}.action-btn-primary:hover{background-color:var(--primary-hover-color, #0f1e2a)}.action-btn-primary:disabled{background-color:#ccc;cursor:not-allowed}.action-btn-secondary{padding:.75rem 1.5rem;background-color:#f5f5f5;color:#333;border:1px solid #ddd;border-radius:4px;font-weight:600;cursor:pointer}.action-btn-secondary:hover{background-color:#e0e0e0}.maintenance-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.maintenance-modal-content{background:#fff;border-radius:8px;width:95%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;position:relative}.maintenance-modal-content .modal-header{padding:1.5rem;border-bottom:1px solid #e0e0e0;position:relative}.maintenance-modal-content .modal-header h2{margin:0;font-size:1.25rem;color:var(--primary-color, #142536);padding-right:2rem}.maintenance-modal-content .modal-close-btn{position:absolute;right:1.5rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.75rem;cursor:pointer;color:#666;line-height:1;padding:0}.maintenance-modal-body{overflow-y:auto;padding:1.5rem;flex:1}.logs-actions{display:flex;justify-content:flex-end;margin-bottom:1rem}.add-log-btn{padding:.6rem 1.25rem;background-color:#2e7d32;color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer}.add-log-btn:hover{background-color:#1b5e20}.logs-table-container{overflow-x:auto}.logs-table{width:100%;border-collapse:collapse;font-size:.85rem}.logs-table thead{background-color:#2e7d32;color:#fff}.logs-table th{padding:.75rem .5rem;text-align:left;font-weight:600;white-space:nowrap}.logs-table td{padding:.75rem .5rem;border-bottom:1px solid #f0f0f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.log-row{cursor:pointer;transition:background-color .2s}.log-row:hover{background-color:#f5f5f5}.log-row.expanded{background-color:#e8f5e9}.log-actions{display:flex;gap:.25rem}.expanded-row{background-color:#f9f9f9}.expanded-details{padding:1rem;display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.detail-item{background:#fff;padding:.75rem;border-radius:4px;border:1px solid #e0e0e0}.detail-item strong{display:block;color:#555;font-size:.8rem;margin-bottom:.25rem}.detail-item p{margin:0;color:#333;white-space:pre-wrap;word-break:break-word}.log-form{background:#fafafa;padding:1.5rem;border-radius:8px}.log-form h3{margin:0 0 1.5rem;font-size:1.1rem;color:var(--primary-color, #142536)}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e0e0e0}@media(max-width:1400px){.equipments-table{min-width:1200px}}@media(max-width:768px){.equipments-page{padding:1rem}.equipments-header{flex-direction:column;align-items:flex-start;gap:1rem}.header-actions{width:100%;flex-direction:column}.search-bar-container{width:100%!important}.ownership-filter,.add-equipment-btn{width:100%}.equipments-table-container{overflow-x:scroll}.equipment-modal-content{width:95%;max-height:95vh}.form-grid{grid-template-columns:1fr}.maintenance-modal-content{width:98%;max-height:95vh}.expanded-details{grid-template-columns:1fr}}.cost-project-tile-link{text-decoration:none;color:inherit;display:block}.cost-project-tile{display:grid;grid-template-columns:60px 2fr 2fr 1.5fr 1.5fr 120px;align-items:center;gap:1rem;background-color:#fdfdfd;border:1px solid var(--border-color);border-radius:8px;padding:1.25rem 1.5rem;transition:all .2s ease-in-out;box-shadow:0 1px 3px #0000000a}.cost-project-tile:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 8px #00000014}.tile-item{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.tile-sr-no{text-align:center;font-weight:600;color:var(--secondary-color)}.tile-main-text{font-weight:600;color:var(--text-color)}.tile-sub-text{color:var(--secondary-color);font-size:.95rem}.tile-meta{display:flex;flex-direction:column;font-size:.85rem;color:var(--secondary-color)}.tile-actions{display:flex;justify-content:flex-end;gap:.5rem}.tile-action-btn{padding:.4rem;border-radius:4px;border:1px solid transparent;background-color:transparent;color:var(--secondary-color);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.tile-action-btn:hover{background-color:#0000000d;color:var(--primary-color);border-color:var(--border-color)}.tile-action-btn.edit-btn:hover{color:var(--primary-hover-color);background-color:#2890e41a;border-color:var(--primary-hover-color)}.tile-action-btn.clone-btn:hover{color:#28a745;background-color:#28a7451a;border-color:#28a745}.tile-action-btn.delete-btn:hover{color:#dc3545;background-color:#ffe6e6;border-color:#ffc2c2}.cost-dashboard-container{padding-bottom:2rem}.cost-projects-header{display:grid;grid-template-columns:60px 2fr 2fr 1.5fr 1.5fr 120px;align-items:center;gap:1rem;padding:0 1.5rem .75rem;margin-bottom:.75rem;color:var(--secondary-color);font-size:.9rem;font-weight:600;border-bottom:2px solid var(--border-color);min-width:900px}.cost-projects-list{display:grid;gap:1rem;min-width:900px}.cost-table-wrapper{width:100%;overflow-x:auto}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }.\!container{width:100%!important}.container{width:100%}@media(min-width:640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media(min-width:768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media(min-width:1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media(min-width:1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media(min-width:1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}#cost-estimator-root .pointer-events-none{pointer-events:none}#cost-estimator-root .visible{visibility:visible}#cost-estimator-root .collapse{visibility:collapse}#cost-estimator-root .fixed{position:fixed}#cost-estimator-root .absolute{position:absolute}#cost-estimator-root .relative{position:relative}#cost-estimator-root .sticky{position:sticky}#cost-estimator-root .inset-0{inset:0}#cost-estimator-root .bottom-full{bottom:100%}#cost-estimator-root .left-0{left:0}#cost-estimator-root .left-\[100\%\]{left:100%}#cost-estimator-root .right-0{right:0}#cost-estimator-root .right-2{right:.5rem}#cost-estimator-root .top-0{top:0}#cost-estimator-root .top-1\/2{top:50%}#cost-estimator-root .-z-10{z-index:-10}#cost-estimator-root .z-20{z-index:20}#cost-estimator-root .z-30{z-index:30}#cost-estimator-root .z-50{z-index:50}#cost-estimator-root .z-\[100\]{z-index:100}#cost-estimator-root .z-\[9999\]{z-index:9999}#cost-estimator-root .col-span-2{grid-column:span 2 / span 2}#cost-estimator-root .mx-auto{margin-left:auto;margin-right:auto}#cost-estimator-root .my-2{margin-top:.5rem;margin-bottom:.5rem}#cost-estimator-root .my-auto{margin-top:auto;margin-bottom:auto}#cost-estimator-root .-mt-2{margin-top:-.5rem}#cost-estimator-root .mb-1{margin-bottom:.25rem}#cost-estimator-root .mb-2{margin-bottom:.5rem}#cost-estimator-root .mb-3{margin-bottom:.75rem}#cost-estimator-root .mb-4{margin-bottom:1rem}#cost-estimator-root .mb-6{margin-bottom:1.5rem}#cost-estimator-root .ml-2{margin-left:.5rem}#cost-estimator-root .ml-4{margin-left:1rem}#cost-estimator-root .mt-0\.5{margin-top:.125rem}#cost-estimator-root .mt-1{margin-top:.25rem}#cost-estimator-root .mt-2{margin-top:.5rem}#cost-estimator-root .mt-6{margin-top:1.5rem}#cost-estimator-root .block{display:block}#cost-estimator-root .inline-block{display:inline-block}#cost-estimator-root .inline{display:inline}#cost-estimator-root .flex{display:flex}#cost-estimator-root .inline-flex{display:inline-flex}#cost-estimator-root .table{display:table}#cost-estimator-root .grid{display:grid}#cost-estimator-root .contents{display:contents}#cost-estimator-root .hidden{display:none}#cost-estimator-root .h-10{height:2.5rem}#cost-estimator-root .h-12{height:3rem}#cost-estimator-root .h-32{height:8rem}#cost-estimator-root .h-4{height:1rem}#cost-estimator-root .h-6{height:1.5rem}#cost-estimator-root .h-full{height:100%}#cost-estimator-root .h-px{height:1px}#cost-estimator-root .max-h-40{max-height:10rem}#cost-estimator-root .max-h-\[90vh\]{max-height:90vh}#cost-estimator-root .max-h-full{max-height:100%}#cost-estimator-root .min-h-full{min-height:100%}#cost-estimator-root .w-0{width:0px}#cost-estimator-root .w-11{width:2.75rem}#cost-estimator-root .w-4{width:1rem}#cost-estimator-root .w-48{width:12rem}#cost-estimator-root .w-6{width:1.5rem}#cost-estimator-root .w-64{width:16rem}#cost-estimator-root .w-8{width:2rem}#cost-estimator-root .w-\[110px\]{width:110px}#cost-estimator-root .w-full{width:100%}#cost-estimator-root .min-w-0{min-width:0px}#cost-estimator-root .max-w-2xl{max-width:42rem}#cost-estimator-root .max-w-full{max-width:100%}#cost-estimator-root .max-w-md{max-width:28rem}#cost-estimator-root .flex-1{flex:1 1 0%}#cost-estimator-root .flex-shrink-0{flex-shrink:0}#cost-estimator-root .border-collapse{border-collapse:collapse}#cost-estimator-root .origin-top{transform-origin:top}#cost-estimator-root .-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}#cost-estimator-root .translate-x-1{--tw-translate-x: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}#cost-estimator-root .translate-x-6{--tw-translate-x: 1.5rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}#cost-estimator-root .rotate-90{--tw-rotate: 90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}#cost-estimator-root .scale-100{--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}#cost-estimator-root .transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(360deg)}}#cost-estimator-root .animate-spin{animation:spin 1s linear infinite}#cost-estimator-root .cursor-not-allowed{cursor:not-allowed}#cost-estimator-root .cursor-pointer{cursor:pointer}#cost-estimator-root .select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}#cost-estimator-root .resize{resize:both}#cost-estimator-root .grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}#cost-estimator-root .grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}#cost-estimator-root .grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}#cost-estimator-root .grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}#cost-estimator-root .grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}#cost-estimator-root .grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}#cost-estimator-root .grid-cols-\[30px_60px_1fr_140px_30px\]{grid-template-columns:30px 60px 1fr 140px 30px}#cost-estimator-root .flex-col{flex-direction:column}#cost-estimator-root .items-start{align-items:flex-start}#cost-estimator-root .items-end{align-items:flex-end}#cost-estimator-root .items-center{align-items:center}#cost-estimator-root .justify-end{justify-content:flex-end}#cost-estimator-root .justify-center{justify-content:center}#cost-estimator-root .justify-between{justify-content:space-between}#cost-estimator-root .gap-1{gap:.25rem}#cost-estimator-root .gap-2{gap:.5rem}#cost-estimator-root .gap-3{gap:.75rem}#cost-estimator-root .gap-4{gap:1rem}#cost-estimator-root :is(.space-y-1>:not([hidden])~:not([hidden])){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}#cost-estimator-root :is(.space-y-3>:not([hidden])~:not([hidden])){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}#cost-estimator-root :is(.space-y-4>:not([hidden])~:not([hidden])){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}#cost-estimator-root :is(.space-y-6>:not([hidden])~:not([hidden])){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}#cost-estimator-root :is(.divide-y>:not([hidden])~:not([hidden])){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}#cost-estimator-root :is(.divide-gray-50>:not([hidden])~:not([hidden])){--tw-divide-opacity: 1;border-color:rgb(249 250 251 / var(--tw-divide-opacity, 1))}#cost-estimator-root .overflow-auto{overflow:auto}#cost-estimator-root .overflow-hidden{overflow:hidden}#cost-estimator-root .overflow-y-auto{overflow-y:auto}#cost-estimator-root .truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#cost-estimator-root .text-ellipsis{text-overflow:ellipsis}#cost-estimator-root .whitespace-nowrap{white-space:nowrap}#cost-estimator-root .rounded{border-radius:.25rem}#cost-estimator-root .rounded-full{border-radius:9999px}#cost-estimator-root .rounded-lg{border-radius:.5rem}#cost-estimator-root .rounded-md{border-radius:.375rem}#cost-estimator-root .rounded-xl{border-radius:.75rem}#cost-estimator-root .rounded-b-md{border-bottom-right-radius:.375rem;border-bottom-left-radius:.375rem}#cost-estimator-root .rounded-l-none{border-top-left-radius:0;border-bottom-left-radius:0}#cost-estimator-root .rounded-r{border-top-right-radius:.25rem;border-bottom-right-radius:.25rem}#cost-estimator-root .rounded-r-md{border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}#cost-estimator-root .border{border-width:1px}#cost-estimator-root .border-2{border-width:2px}#cost-estimator-root .border-b{border-bottom-width:1px}#cost-estimator-root .border-l{border-left-width:1px}#cost-estimator-root .border-l-0{border-left-width:0px}#cost-estimator-root .border-l-2{border-left-width:2px}#cost-estimator-root .border-r{border-right-width:1px}#cost-estimator-root .border-t{border-top-width:1px}#cost-estimator-root .border-dashed{border-style:dashed}#cost-estimator-root .border-blue-200{--tw-border-opacity: 1;border-color:rgb(191 219 254 / var(--tw-border-opacity, 1))}#cost-estimator-root .border-gray-100{--tw-border-opacity: 1;border-color:rgb(243 244 246 / var(--tw-border-opacity, 1))}#cost-estimator-root .border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}#cost-estimator-root .border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}#cost-estimator-root .border-gray-50{--tw-border-opacity: 1;border-color:rgb(249 250 251 / var(--tw-border-opacity, 1))}#cost-estimator-root .border-green-100{--tw-border-opacity: 1;border-color:rgb(220 252 231 / var(--tw-border-opacity, 1))}#cost-estimator-root .border-green-200{--tw-border-opacity: 1;border-color:rgb(187 247 208 / var(--tw-border-opacity, 1))}#cost-estimator-root .border-primary{--tw-border-opacity: 1;border-color:rgb(20 37 54 / var(--tw-border-opacity, 1))}#cost-estimator-root .border-primary\/10{border-color:#1425361a}#cost-estimator-root .border-red-200{--tw-border-opacity: 1;border-color:rgb(254 202 202 / var(--tw-border-opacity, 1))}#cost-estimator-root .border-red-500{--tw-border-opacity: 1;border-color:rgb(239 68 68 / var(--tw-border-opacity, 1))}#cost-estimator-root .border-transparent{border-color:transparent}#cost-estimator-root .bg-black\/40{background-color:#0006}#cost-estimator-root .bg-black\/50{background-color:#00000080}#cost-estimator-root .bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}#cost-estimator-root .bg-blue-50\/30{background-color:#eff6ff4d}#cost-estimator-root .bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}#cost-estimator-root .bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}#cost-estimator-root .bg-gray-300{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}#cost-estimator-root .bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}#cost-estimator-root .bg-gray-800{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}#cost-estimator-root .bg-green-50{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity, 1))}#cost-estimator-root .bg-green-50\/50{background-color:#f0fdf480}#cost-estimator-root .bg-primary{--tw-bg-opacity: 1;background-color:rgb(20 37 54 / var(--tw-bg-opacity, 1))}#cost-estimator-root .bg-primary\/5{background-color:#1425360d}#cost-estimator-root .bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}#cost-estimator-root .bg-red-600{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity, 1))}#cost-estimator-root .bg-transparent{background-color:transparent}#cost-estimator-root .bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}#cost-estimator-root .object-contain{-o-object-fit:contain;object-fit:contain}#cost-estimator-root .p-1{padding:.25rem}#cost-estimator-root .p-1\.5{padding:.375rem}#cost-estimator-root .p-10{padding:2.5rem}#cost-estimator-root .p-2{padding:.5rem}#cost-estimator-root .p-3{padding:.75rem}#cost-estimator-root .p-4{padding:1rem}#cost-estimator-root .p-5{padding:1.25rem}#cost-estimator-root .p-6{padding:1.5rem}#cost-estimator-root .px-2{padding-left:.5rem;padding-right:.5rem}#cost-estimator-root .px-3{padding-left:.75rem;padding-right:.75rem}#cost-estimator-root .px-4{padding-left:1rem;padding-right:1rem}#cost-estimator-root .px-6{padding-left:1.5rem;padding-right:1.5rem}#cost-estimator-root .py-0\.5{padding-top:.125rem;padding-bottom:.125rem}#cost-estimator-root .py-1{padding-top:.25rem;padding-bottom:.25rem}#cost-estimator-root .py-1\.5{padding-top:.375rem;padding-bottom:.375rem}#cost-estimator-root .py-2{padding-top:.5rem;padding-bottom:.5rem}#cost-estimator-root .py-3{padding-top:.75rem;padding-bottom:.75rem}#cost-estimator-root .py-4{padding-top:1rem;padding-bottom:1rem}#cost-estimator-root .pb-20{padding-bottom:5rem}#cost-estimator-root .pb-3{padding-bottom:.75rem}#cost-estimator-root .pl-2{padding-left:.5rem}#cost-estimator-root .pr-2{padding-right:.5rem}#cost-estimator-root .pr-3{padding-right:.75rem}#cost-estimator-root .pt-2{padding-top:.5rem}#cost-estimator-root .pt-4{padding-top:1rem}#cost-estimator-root .text-center{text-align:center}#cost-estimator-root .text-right{text-align:right}#cost-estimator-root .font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}#cost-estimator-root .font-sans{font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji"}#cost-estimator-root .text-2xl{font-size:1.5rem;line-height:2rem}#cost-estimator-root .text-\[10px\]{font-size:10px}#cost-estimator-root .text-base{font-size:1rem;line-height:1.5rem}#cost-estimator-root .text-lg{font-size:1.125rem;line-height:1.75rem}#cost-estimator-root .text-sm{font-size:.875rem;line-height:1.25rem}#cost-estimator-root .text-xl{font-size:1.25rem;line-height:1.75rem}#cost-estimator-root .text-xs{font-size:.75rem;line-height:1rem}#cost-estimator-root .font-bold{font-weight:700}#cost-estimator-root .font-extrabold{font-weight:800}#cost-estimator-root .font-medium{font-weight:500}#cost-estimator-root .uppercase{text-transform:uppercase}#cost-estimator-root .italic{font-style:italic}#cost-estimator-root .tracking-wide{letter-spacing:.025em}#cost-estimator-root .tracking-wider{letter-spacing:.05em}#cost-estimator-root .text-blue-500{--tw-text-opacity: 1;color:rgb(59 130 246 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-blue-700{--tw-text-opacity: 1;color:rgb(29 78 216 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-green-700{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-primary{--tw-text-opacity: 1;color:rgb(20 37 54 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-red-700{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}#cost-estimator-root .text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}#cost-estimator-root .underline{text-decoration-line:underline}#cost-estimator-root .opacity-0{opacity:0}#cost-estimator-root .shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}#cost-estimator-root .shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}#cost-estimator-root .shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}#cost-estimator-root .shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}#cost-estimator-root .shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}#cost-estimator-root .outline-none{outline:2px solid transparent;outline-offset:2px}#cost-estimator-root .filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}#cost-estimator-root .backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}#cost-estimator-root .transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}#cost-estimator-root .transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}#cost-estimator-root .transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}#cost-estimator-root .transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}#cost-estimator-root .transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}#cost-estimator-root .duration-200{transition-duration:.2s}#cost-estimator-root .duration-300{transition-duration:.3s}#cost-estimator-root .ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}#cost-estimator-root .ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}#cost-estimator-root .\[appearance\:textfield\]{-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}#cost-estimator-root{font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5}#cost-estimator-root *,#cost-estimator-root :before,#cost-estimator-root :after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}.cost-estimator-delete-modal .modal-content{border-radius:8px!important;padding:0!important;overflow:hidden!important;max-width:500px!important;background:#fff!important;box-shadow:0 4px 15px #0003!important;border:1px solid #e5e7eb!important}.cost-estimator-delete-modal .modal-header{padding:1.25rem 1.5rem!important;border-bottom:1px solid #e5e7eb!important;display:flex!important;justify-content:space-between!important;align-items:center!important;margin:0!important}.cost-estimator-delete-modal .modal-header h2{font-size:1.25rem!important;font-weight:700!important;color:#1f2937!important;margin:0!important}.cost-estimator-delete-modal .modal-close-btn{position:static!important;transform:none!important;font-size:1.5rem!important;color:#9ca3af!important;background:transparent!important;border:none!important;cursor:pointer!important;padding:0!important;line-height:1!important}.cost-estimator-delete-modal .modal-close-btn:hover{color:#4b5563!important}.cost-estimator-delete-modal p{padding:1.5rem!important;color:#4b5563!important;font-size:1rem!important;line-height:1.5!important;margin:0!important}.cost-estimator-delete-modal .modal-actions{padding:1rem 1.5rem!important;display:flex!important;justify-content:flex-end!important;gap:1rem!important;background-color:#fff!important;margin-top:0!important}.cost-estimator-delete-modal .action-btn-secondary{background-color:#fff!important;border:1px solid #d1d5db!important;color:#374151!important;padding:.5rem 1rem!important;border-radius:4px!important;font-weight:600!important;cursor:pointer!important;font-size:.95rem!important}.cost-estimator-delete-modal .action-btn-secondary:hover{background-color:#f3f4f6!important;border-color:#9ca3af!important}.cost-estimator-delete-modal .action-btn-danger{background-color:#dc3545!important;border:1px solid #dc3545!important;color:#fff!important;padding:.5rem 1.25rem!important;border-radius:4px!important;font-weight:600!important;cursor:pointer!important;font-size:.95rem!important}.cost-estimator-delete-modal .action-btn-danger:hover{background-color:#b02a37!important;border-color:#b02a37!important}#cost-estimator-root .last\:border-0:last-child{border-width:0px}#cost-estimator-root .hover\:border-blue-600:hover{--tw-border-opacity: 1;border-color:rgb(37 99 235 / var(--tw-border-opacity, 1))}#cost-estimator-root .hover\:border-gray-200:hover{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}#cost-estimator-root .hover\:border-primary:hover{--tw-border-opacity: 1;border-color:rgb(20 37 54 / var(--tw-border-opacity, 1))}#cost-estimator-root .hover\:bg-blue-50:hover{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}#cost-estimator-root .hover\:bg-blue-600:hover{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}#cost-estimator-root .hover\:bg-gray-100:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}#cost-estimator-root .hover\:bg-gray-200:hover{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}#cost-estimator-root .hover\:bg-gray-300:hover{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}#cost-estimator-root .hover\:bg-gray-50:hover{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}#cost-estimator-root .hover\:bg-green-100:hover{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}#cost-estimator-root .hover\:bg-primary-light:hover{--tw-bg-opacity: 1;background-color:rgb(40 144 228 / var(--tw-bg-opacity, 1))}#cost-estimator-root .hover\:bg-primary\/90:hover{background-color:#142536e6}#cost-estimator-root .hover\:bg-red-100:hover{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}#cost-estimator-root .hover\:bg-red-50:hover{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}#cost-estimator-root .hover\:bg-red-700:hover{--tw-bg-opacity: 1;background-color:rgb(185 28 28 / var(--tw-bg-opacity, 1))}#cost-estimator-root .hover\:bg-white:hover{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}#cost-estimator-root .hover\:text-blue-600:hover{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}#cost-estimator-root .hover\:text-gray-600:hover{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}#cost-estimator-root .hover\:text-primary:hover{--tw-text-opacity: 1;color:rgb(20 37 54 / var(--tw-text-opacity, 1))}#cost-estimator-root .hover\:text-primary-light:hover{--tw-text-opacity: 1;color:rgb(40 144 228 / var(--tw-text-opacity, 1))}#cost-estimator-root .hover\:text-red-600:hover{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}#cost-estimator-root .hover\:text-red-700:hover{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}#cost-estimator-root .hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}#cost-estimator-root .focus\:border-transparent:focus{border-color:transparent}#cost-estimator-root .focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}#cost-estimator-root .focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}#cost-estimator-root .focus\:ring-primary:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(20 37 54 / var(--tw-ring-opacity, 1))}#cost-estimator-root .focus\:ring-primary\/50:focus{--tw-ring-color: rgb(20 37 54 / .5)}#cost-estimator-root .focus\:ring-red-200:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(254 202 202 / var(--tw-ring-opacity, 1))}#cost-estimator-root .disabled\:cursor-not-allowed:disabled{cursor:not-allowed}#cost-estimator-root .disabled\:opacity-70:disabled{opacity:.7}#cost-estimator-root :is(.group:hover .group-hover\:block){display:block}#cost-estimator-root :is(.group:hover .group-hover\:text-primary){--tw-text-opacity: 1;color:rgb(20 37 54 / var(--tw-text-opacity, 1))}#cost-estimator-root :is(.group:hover .group-hover\:opacity-100){opacity:1}@media(min-width:640px){#cost-estimator-root .sm\:inline{display:inline}#cost-estimator-root .sm\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}#cost-estimator-root .sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}#cost-estimator-root .sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}#cost-estimator-root .sm\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}#cost-estimator-root .sm\:p-6{padding:1.5rem}#cost-estimator-root .sm\:p-8{padding:2rem}}@media(min-width:768px){#cost-estimator-root .md\:left-\[50\%\]{left:50%}#cost-estimator-root .md\:flex{display:flex}#cost-estimator-root .md\:w-1\/2{width:50%}}@media(min-width:1024px){#cost-estimator-root .lg\:left-\[45\%\]{left:45%}#cost-estimator-root .lg\:w-\[45\%\]{width:45%}}#cost-estimator-root .\[\&\:\:-webkit-inner-spin-button\]\:appearance-none::-webkit-inner-spin-button{-webkit-appearance:none;appearance:none}#cost-estimator-root .\[\&\:\:-webkit-outer-spin-button\]\:appearance-none::-webkit-outer-spin-button{-webkit-appearance:none;appearance:none}.bids-view-container{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.bids-list-header,.bid-row-card{display:grid;grid-template-columns:50px 2fr 1fr 1.25fr 1.25fr 1fr 1fr 1.25fr;align-items:center;gap:1.5rem;width:100%;min-width:1100px}.bids-list-header{padding:0 1.5rem .75rem;color:var(--secondary-color);font-size:.9rem;font-weight:600;border-bottom:2px solid var(--border-color)}.bid-row-card{padding:1.25rem 1.5rem;background-color:#fdfdfd;border:1px solid var(--border-color);border-radius:8px;margin-bottom:.75rem;transition:all .2s ease}.bid-row-card:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #0000000d}.bids-list-header.no-actions,.bid-row-card.no-actions{grid-template-columns:50px 2fr 1fr 1.25fr 1.25fr 1fr 1fr}.bid-row-card span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-badge{padding:4px 10px;border-radius:20px;font-size:.8rem;font-weight:600;text-align:center;text-transform:uppercase;white-space:nowrap}.status-won{background-color:#e6f4ea;color:#1e7e34}.status-lost{background-color:#fce8e8;color:#d93025}.status-submitted{background-color:#e8f0fe;color:#1a73e8}.status-not-submitted{background-color:#f1f3f4;color:#5f6368}.bid-actions{display:flex;justify-content:center;align-items:center;gap:8px}.status-quick-select{padding:4px 8px;border-radius:4px;border:1px solid var(--border-color);font-size:.8rem;cursor:pointer;background:#fff;max-width:120px}.icon-btn{background:transparent;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;transition:opacity .2s}.icon-btn svg{width:18px;height:18px}.edit-icon{color:var(--secondary-color)}.delete-icon{color:#dc3545}.icon-btn:hover{opacity:.7}.bids-form-modal{width:95%;max-width:800px!important;max-height:90vh;display:flex;flex-direction:column;padding:0!important;overflow:hidden}.bids-form-modal .bid-form{display:flex;flex-direction:column;flex-grow:1;height:100%;overflow:hidden}.bids-form-modal .modal-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.bids-form-modal .modal-actions-sticky{padding:1.25rem 2rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:1rem;background:#f9f9f9;flex-shrink:0}.bids-form-modal .modal-body-scroll{padding:1.5rem 2rem;overflow-y:auto;flex-grow:1}.submit-bid-btn{width:auto!important;min-width:140px}.bid-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.bid-form .full-width{grid-column:span 2}.bids-modal-overlay .modal-close-btn{top:1.5rem;right:1.5rem;transform:translateY(0)}.modal-body-scroll::-webkit-scrollbar{width:6px}.modal-body-scroll::-webkit-scrollbar-track{background:#f1f1f1}.modal-body-scroll::-webkit-scrollbar-thumb{background:#ccc;border-radius:10px}.time-select-container{display:flex;align-items:center;gap:.5rem;width:100%;padding:0;border:1px solid var(--border-color);border-radius:4px;background-color:#fff;transition:border-color .2s,box-shadow .2s}.time-select-container:focus-within{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #007bff40}.time-select-container select{flex-grow:1;width:50%;padding:.6rem;border:none;background-color:transparent;font-size:.95rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-align:center}.time-select-container select:focus{outline:none}.time-select-container .time-separator{font-weight:700;color:var(--secondary-color)}.bid-detail-popup{max-width:500px!important;border-top:5px solid var(--primary-color)}.detail-title{font-size:1.25rem;color:var(--text-color)}.bid-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;padding:1rem 0}.detail-row label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--secondary-color);margin-bottom:4px;font-weight:700}.detail-value{font-size:1rem;color:var(--text-color);font-weight:500}.highlighted-name{font-size:1.2rem;font-weight:700;color:var(--primary-color)}.value-text{color:#28a745;font-weight:700}.detail-row.full-width{grid-column:span 2}.bid-details-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:2000;padding:1rem}.bid-details-modal{background-color:var(--white-color, #ffffff);width:100%;max-width:1200px;height:90vh;border-radius:8px;display:flex;flex-direction:column;position:relative;overflow:hidden;box-shadow:0 10px 30px #0000004d}.bid-details-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border-color, #e0e0e0);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background-color:var(--primary-color, #142536);color:#fff;position:relative}.bid-details-header h2{margin:0;font-size:1.5rem}.bid-details-subtitle{margin:.25rem 0 0;font-size:.9rem;opacity:.9}.bid-details-tabs{display:flex;gap:.5rem;padding:0 2rem;background-color:#f8f9fa;border-bottom:2px solid var(--border-color, #e0e0e0);flex-shrink:0}.tab-btn{padding:1rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;font-weight:500;color:#6c757d;transition:all .2s;margin-bottom:-2px}.tab-btn:hover{color:var(--primary-color, #142536)}.tab-btn.active{color:var(--primary-color, #142536);border-bottom-color:var(--primary-color, #142536)}.bid-details-content{flex:1;overflow-y:auto;padding:2rem;background-color:#fafafa}.contact-lists-tab{display:flex;flex-direction:column;gap:1.5rem}.tab-header{display:flex;justify-content:space-between;align-items:center}.tab-header h3{margin:0;font-size:1.3rem;color:var(--secondary-color, #333)}.create-bundle-btn{padding:.75rem 1.5rem;background-color:var(--primary-color, #142536);color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.create-bundle-btn:hover{background-color:var(--primary-hover-color, #0f1e2a)}.tab-loading,.tab-error{text-align:center;padding:3rem;font-size:1.1rem;color:#6c757d}.tab-error{color:#dc3545}.bundle-table-container{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.bundle-table{width:100%;min-width:900px;border-collapse:collapse}.bundle-table-header{display:grid;grid-template-columns:60px 180px 1fr 1fr 100px;gap:1rem;padding:1rem 1.5rem;background-color:var(--primary-color, #142536);color:#fff;font-weight:600;font-size:.85rem;text-transform:uppercase;min-width:900px}.bundle-table-body{min-height:200px;min-width:900px}.bundle-table-row{display:grid;grid-template-columns:60px 180px 1fr 1fr 100px;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color, #f0f0f0);align-items:center;transition:background-color .2s;min-height:60px;min-width:900px}.bundle-table-row:hover{background-color:#f9f9f9}.bundle-table-row:last-child{border-bottom:none}.bundle-serial{font-weight:500;color:#666;text-align:center}.bundle-name{font-weight:600;color:var(--secondary-color, #333);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bundle-contacts{display:flex;align-items:center;overflow:hidden;flex-wrap:wrap;gap:.5rem}.contact-capsules{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.contact-capsule{background-color:#e9ecef!important;border:1px solid #dee2e6!important;font-size:.8rem!important;padding:.2rem .5rem!important;white-space:nowrap}.no-contacts-text{color:#adb5bd;font-style:italic;font-size:.9rem}.more-contacts-btn{background-color:var(--primary-color, #142536);color:#fff;border:none;border-radius:12px;padding:.2rem .6rem;font-size:.8rem;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.more-contacts-btn:hover{background-color:var(--primary-hover-color, #0f1e2a)}.bundle-actions{display:flex;gap:.5rem;justify-content:center}.no-bundles-message{text-align:center;padding:3rem;color:#6c757d;font-size:1rem}.bundle-modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:3000;padding:1rem}.bundle-modal-content{background-color:#fff;width:100%;max-width:1000px;height:85vh;border-radius:8px;display:flex;flex-direction:column;position:relative;overflow:hidden;box-shadow:0 10px 30px #0000004d}.bundle-modal-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border-color, #e0e0e0);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background-color:var(--primary-color, #142536);color:#fff;position:relative}.bundle-modal-header h2{margin:0;font-size:1.5rem;color:#fff}.bundle-modal-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:2rem}.form-field{margin-bottom:1.5rem}.form-field label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--secondary-color, #333)}.bundle-name-input{width:100%;padding:.75rem;border:1px solid var(--border-color, #dee2e6);border-radius:6px;font-size:1rem}.bundle-name-input:focus{outline:none;border-color:var(--primary-color, #142536);box-shadow:0 0 0 3px #1425361a}.selected-pills-container{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem;padding:.75rem;background-color:#f8f9fa;border-radius:6px;min-height:50px}.bundle-modal-footer{padding:1.5rem 2rem;border-top:1px solid var(--border-color, #e0e0e0);display:flex;justify-content:flex-end;gap:1rem;flex-shrink:0}.cancel-btn,.save-btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.cancel-btn{background-color:#e9ecef;color:#495057}.cancel-btn:hover{background-color:#dee2e6}.save-btn{background-color:var(--primary-color, #142536);color:#fff}.save-btn:hover{background-color:var(--primary-hover-color, #0f1e2a)}.save-btn:disabled,.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.infinite-dropdown-container{display:flex;flex-direction:column;gap:.5rem}.dropdown-wrapper{position:relative}.dropdown-search-input{width:100%;padding:.75rem;border:1px solid var(--border-color, #dee2e6);border-radius:6px;font-size:1rem}.dropdown-search-input:focus{outline:none;border-color:var(--primary-color, #142536);box-shadow:0 0 0 3px #1425361a}.dropdown-backdrop{position:fixed;inset:0;z-index:9998}.dropdown-results{max-height:200px;overflow-y:auto;background-color:#fff;border:1px solid var(--border-color, #dee2e6);border-radius:6px;box-shadow:0 8px 24px #0003;z-index:9999}.dropdown-item{padding:.75rem 1rem;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #f1f3f5;display:flex;flex-direction:column;gap:.25rem}.dropdown-item:hover{background-color:#f8f9fa}.dropdown-item:last-child{border-bottom:none}.dropdown-item-name{font-weight:600;color:var(--secondary-color, #333)}.dropdown-item-email{font-size:.9rem;color:#6c757d}.dropdown-item-badge{display:inline-block;padding:.25rem .5rem;background-color:#e9ecef;border-radius:4px;font-size:.75rem;font-weight:600;color:#495057;text-transform:uppercase;margin-top:.25rem}.dropdown-loading,.dropdown-loading-more,.dropdown-no-results{padding:1rem;text-align:center;color:#6c757d;font-size:.9rem}.dropdown-loading-more{border-top:1px solid #f1f3f5}.contact-popup-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:4000;padding:1rem}.contact-popup-content{background-color:#fff;width:100%;max-width:600px;max-height:80vh;border-radius:8px;display:flex;flex-direction:column;position:relative;overflow:hidden;box-shadow:0 10px 30px #0000004d}.contact-popup-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border-color, #e0e0e0);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background-color:var(--primary-color, #142536);color:#fff}.contact-popup-header h3{margin:0;font-size:1.3rem}.popup-close-btn{font-size:2rem;background:none;border:none;cursor:pointer;color:#fff;padding:0;line-height:1}.popup-close-btn:hover{opacity:.8}.contact-popup-body{flex:1;overflow-y:auto;padding:1.5rem 2rem}.contact-section{margin-bottom:2rem}.contact-section:last-child{margin-bottom:0}.contact-section h4{margin:0 0 1rem;color:var(--secondary-color, #333);font-size:1.1rem;text-transform:uppercase;letter-spacing:.5px}.contact-list{display:flex;flex-direction:column;gap:.75rem}.contact-item{padding:.75rem 1rem;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px}.contact-name{font-weight:600;color:var(--secondary-color, #333);margin-bottom:.25rem}.contact-email{font-size:.9rem;color:#6c757d}.no-contacts{text-align:center;padding:2rem;color:#adb5bd;font-style:italic}.icon-btn{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-btn svg{width:20px;height:20px}.icon-btn.edit-icon{color:var(--secondary-color, #333)}.icon-btn.edit-icon:hover{background-color:#1425361a}.icon-btn.details-icon{color:#6c757d}.icon-btn.details-icon:hover{background-color:#6c757d1a}.icon-btn.delete-icon{color:#dc3545}.icon-btn.delete-icon:hover{background-color:#dc35451a}.modal-close-btn{position:absolute;top:1.5rem;right:2rem;font-size:2rem;font-weight:300;background:none;border:none;color:#fff;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;z-index:1;transition:color .2s,opacity .2s}.modal-close-btn:hover{color:#dc3545;opacity:.8}@media(max-width:768px){.bid-details-modal{max-width:100%;height:100vh;border-radius:0}.bundle-table-container{overflow-x:scroll}.bundle-table-header,.bundle-table-row,.bundle-table-body{min-width:900px}.bundle-modal-content{max-width:100%}.tab-header{flex-direction:column;gap:1rem;align-items:flex-start}.create-bundle-btn{width:100%}}.calendar-view-container{animation:fadeIn .3s ease-in-out}.calendar-wrapper{background:#fff;padding:1.5rem;border-radius:12px;border:1px solid var(--border-color);position:relative}.calendar-loader{position:absolute;top:10px;right:20px;font-size:.75rem;color:var(--primary-color);z-index:5;font-weight:600}.fc-event{background:none!important;border:none!important;padding:0!important;margin:2px 4px!important}.bid-calendar-capsule{background-color:#f8f9fa;padding:4px 8px;border-radius:4px;display:flex;gap:8px;align-items:center;box-shadow:0 1px 3px #0000001a;cursor:pointer;overflow:hidden;transition:transform .1s ease}.bid-calendar-capsule:hover{transform:scale(1.02);background-color:#fff}.bid-capsule-time{font-weight:700;font-size:.75rem;color:var(--text-color);flex-shrink:0}.bid-capsule-title{font-size:.75rem;color:var(--secondary-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fc-toolbar-title{font-size:1.25rem!important;font-weight:700!important;color:var(--text-color)}.fc-button-primary{background-color:var(--primary-color)!important;border-color:var(--primary-color)!important}.fc-button-primary:disabled{background-color:#ccc!important;border-color:#ccc!important}:root{--primary-color: #142536;--primary-hover-color: #2890e4;--secondary-color: #6c757d;--background-color: #f8f9fa;--text-color: #343a40;--border-color: #dee2e6;--white-color: #ffffff;--success-bg: #e6ffed;--success-border: #b7e9c7;--danger-bg: #ffe6e6;--danger-border: #ffc2c2;--font-family-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family-sans-serif);background-color:var(--background-color);color:var(--text-color);line-height:1.5}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--border-color)}::-webkit-scrollbar-thumb{background-color:var(--secondary-color);border-radius:10px;border:2px solid var(--border-color)}::-webkit-scrollbar-thumb:hover{background-color:#5a6268}
