@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&family=Open+Sans:wght@400;600&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #1b1b1b;--primary-hover: #333333;--secondary-color: #64748b;--success-color: #10b981;--danger-color: #ef4444;--warning-color: #f59e0b;--warning-bg: #fef3c7;--info-color: #3b82f6;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--sidebar-width: 250px;--sidebar-collapsed-width: 0px;--header-height: 60px;--border-radius: 6px;--box-shadow: 0 1px 3px rgba(0, 0, 0, .1);--box-shadow-lg: 0 4px 6px rgba(0, 0, 0, .1);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--gray-900);background-color:var(--gray-50)}.app-container{display:flex;min-height:100vh}.app-header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background-color:#1b1b1b;border-bottom:none;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;z-index:100;box-shadow:0 2px 8px #0000004d}#headerBackSlot .btn{font-size:.85rem;padding:.3rem .75rem}.app-header h1{font-family:Playfair Display,serif;font-size:var(--font-size-xl);font-weight:700;color:#fff;display:flex;align-items:center;gap:.6rem}.app-header h1 img{height:32px;width:32px;filter:invert(1)}.app-sidebar{position:fixed;left:0;top:var(--header-height);bottom:0;width:var(--sidebar-width);background-color:#fff;border-right:1px solid var(--gray-200);overflow-y:auto;padding:1rem 0;transition:width .25s ease,transform .25s ease;z-index:90}.sidebar-toggle{position:fixed;top:var(--header-height);left:var(--sidebar-width);width:24px;height:40px;background:#fff;border:1px solid var(--gray-200);border-left:none;border-radius:0 4px 4px 0;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:91;transition:left .25s ease;color:var(--gray-500);font-size:.75rem;padding:0;margin-top:8px}.sidebar-toggle:hover{background:var(--gray-100);color:var(--primary-color)}.sidebar-collapsed .app-sidebar{width:var(--sidebar-collapsed-width);overflow:hidden}.sidebar-collapsed .sidebar-toggle{left:var(--sidebar-collapsed-width)}.sidebar-collapsed .app-main{margin-left:var(--sidebar-collapsed-width);width:calc(100% - var(--sidebar-collapsed-width))}.menu-expand-toggle{display:flex;align-items:center;gap:.4rem;padding:.15rem 1rem;cursor:pointer;font-size:.75rem;color:var(--gray-500);transition:color .2s;-webkit-user-select:none;user-select:none;line-height:1}.menu-expand-toggle:hover{color:var(--primary-color)}.expand-toggle-icon{font-size:.6rem;letter-spacing:-2px}.sidebar-nav{list-style:none}.sidebar-nav li{margin:0}.menu-section-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;color:var(--gray-900);font-weight:600;font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;-webkit-user-select:none;user-select:none;background-color:var(--gray-50);border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);margin-top:.5rem}.menu-section-header:first-child{margin-top:0}.menu-section-header:hover{background-color:var(--gray-100)}.menu-section-header .section-icon{font-size:.875rem;transition:transform .2s}.menu-section.collapsed .section-icon{transform:rotate(-90deg)}.menu-section-content{display:block;overflow:hidden;transition:max-height .3s ease}.menu-section.collapsed .menu-section-content{display:none}.sidebar-nav a{display:block;padding:.75rem 1.5rem .75rem 2.5rem;color:var(--gray-700);text-decoration:none;transition:all .2s;font-size:var(--font-size-sm)}.sidebar-nav a:hover{background-color:var(--gray-100);color:var(--primary-color)}.sidebar-nav a.active{background-color:var(--primary-color);color:#fff;font-weight:500;border-left:3px solid var(--primary-hover)}.menu-subgroup{margin:0}.menu-subgroup-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem .6rem 2.5rem;color:var(--gray-700);font-weight:500;font-size:.8rem;cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--gray-100)}.menu-subgroup-header:hover{background-color:var(--gray-100);color:var(--primary-color)}.menu-subgroup-header .subgroup-label{display:flex;align-items:center;gap:.5rem}.menu-subgroup-header .subgroup-icon{font-size:.65rem;color:var(--gray-400);transition:transform .2s}.menu-subgroup.collapsed .subgroup-icon{transform:rotate(-90deg)}.menu-subgroup-content{display:block;overflow:hidden;background-color:var(--gray-50)}.menu-subgroup.collapsed .menu-subgroup-content{display:none}.menu-subgroup-content a{padding-left:3.5rem;font-size:.85rem}.menu-subgroup-content a:hover{background-color:var(--gray-100)}.app-main{margin-left:var(--sidebar-width);margin-top:var(--header-height);padding:2rem;flex:1;width:calc(100% - var(--sidebar-width));transition:margin-left .25s ease,width .25s ease}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h2{font-size:var(--font-size-2xl);font-weight:600;color:var(--gray-900)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:var(--font-size-base);font-weight:500;border:none;border-radius:var(--border-radius);cursor:pointer;transition:all .2s;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover)}.btn-secondary{background-color:var(--gray-500);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--gray-600)}.btn-success{background-color:var(--success-color);color:#fff}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-sm{padding:.375rem .75rem;font-size:var(--font-size-sm)}.card{background-color:#fff;border:1px solid var(--gray-200);border-radius:var(--border-radius);box-shadow:var(--box-shadow);margin-bottom:1.5rem}.card-header{padding:1rem 1.5rem;border-bottom:1px solid var(--gray-200);font-weight:600;font-size:var(--font-size-lg)}.card-body{padding:1.5rem}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse;background-color:#fff}.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--gray-200)}.table th{background-color:var(--gray-50);font-weight:600;color:var(--gray-700);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em}.table tbody tr:hover{background-color:var(--gray-50)}.table-actions{display:flex;gap:.5rem}.form-group{margin-bottom:1.25rem}.form-group.form-inline{display:flex;align-items:center;gap:.75rem}.form-group.form-inline>.form-label{min-width:110px;margin-bottom:0;white-space:nowrap}.form-group.form-inline>.form-input,.form-group.form-inline>.form-select,.form-group.form-inline>.form-textarea{flex:1}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--gray-700);font-size:var(--font-size-sm)}.form-filter-label{padding-right:.5rem;margin-bottom:.5rem;font-weight:500;color:var(--gray-700);font-size:var(--font-size-sm)}.form-label.required:after{content:" *";color:var(--danger-color)}.form-input,.form-select,.form-textarea{width:100%;padding:.5rem .75rem;font-size:var(--font-size-base);border:1px solid var(--gray-300);border-radius:var(--border-radius);transition:border-color .2s}.form-filter-input,.form-filter-select,.form-filter-textarea{padding:.5rem .75rem;margin-right:5px;font-size:var(--font-size-base);border:1px solid var(--gray-300);border-radius:var(--border-radius);transition:border-color .2s}.filter-checkbox{display:flex;align-items:center;min-height:2.375rem}.filter-row{gap:1rem;align-items:flex-end}.filter-input-wide{min-width:200px}.col-expand,.col-lineno,.col-seq{width:40px}.col-pct{width:60px}.col-actions-sm{width:80px}.header-action-row{position:relative}.spec-header-row{margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--gray-200)}.spec-empty{padding:1.5rem}.spec-picker-help{margin:0 0 .75rem}.tab-content-padded{padding:1rem 0}.m-0{margin:0}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--danger-color)}.form-error{margin-top:.25rem;font-size:var(--font-size-sm);color:var(--danger-color)}.form-help{margin-top:0;font-size:var(--font-size-sm);color:var(--gray-500)}.form-checkbox{display:flex;align-items:center;gap:.5rem}.form-checkbox input{width:1.125rem;height:1.125rem;cursor:pointer}.form-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--gray-200)}.form-row{display:flex;gap:1rem;margin-bottom:1.25rem}.form-row .form-group{flex:1;margin-bottom:0}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--gray-200);background-color:var(--gray-50);border-radius:0 0 var(--border-radius) var(--border-radius)}.badge{display:inline-block;padding:.25rem .625rem;font-size:var(--font-size-sm);font-weight:500;border-radius:9999px;line-height:1}.badge-success{background-color:#d1fae5;color:#065f46}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-secondary{background-color:var(--gray-200);color:var(--gray-700)}.badge-primary{background-color:#dbeafe;color:#1e40af}.badge-info{background-color:#e0f2fe;color:#0369a1}.badge-warning{background-color:#fef3c7;color:#92400e}.modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:1000;align-items:center;justify-content:center}.modal-overlay.active{display:flex}.modal{background-color:#fff;border-radius:var(--border-radius);box-shadow:var(--box-shadow-lg);max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{padding:1.5rem;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center}.modal-header h3{font-size:var(--font-size-xl);font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--gray-400);padding:0;width:2rem;height:2rem}.modal-close:hover{color:var(--gray-600)}.alert{padding:1rem;border-radius:var(--border-radius);margin-bottom:1.5rem}.alert-success{background-color:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.alert-error{background-color:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.alert-info{background-color:#dbeafe;color:#1e40af;border:1px solid #93c5fd}.loading{display:none;text-align:center;padding:2rem;color:var(--gray-500)}.loading.active{display:block}.spinner{border:3px solid var(--gray-200);border-top-color:var(--primary-color);border-radius:50%;width:2rem;height:2rem;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:3rem 1rem;color:var(--gray-500)}.empty-state-icon{font-size:3rem;margin-bottom:1rem}.empty-state-title{font-size:var(--font-size-lg);font-weight:600;color:var(--gray-700);margin-bottom:.5rem}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--gray-500)}.text-primary{color:var(--primary-color)}.text-success{color:var(--success-color)}.text-danger{color:var(--danger-color)}.text-warning{color:var(--warning-color)}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.row-clickable{cursor:pointer}.row-clickable:hover{background:var(--gray-50)}.mt-0{margin-top:0}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pb-3{padding-bottom:.75rem}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.grid{display:grid}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 1.5rem}.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}.col-span-full{grid-column:1 / -1}.w-full{width:100%}.w-auto{width:auto}.border-t{border-top:1px solid var(--gray-200)}.border-b{border-bottom:1px solid var(--gray-200)}.bg-light{background:var(--gray-50)}.bg-muted{background:var(--gray-100)}.rounded{border-radius:var(--border-radius)}.section-break{border-top:1px solid var(--gray-200);margin-top:.75rem;padding-top:.75rem}.footer-split{display:flex;justify-content:space-between;width:100%}.footer-end{display:flex;justify-content:flex-end;gap:.5rem;width:100%}.hidden{display:none!important}.p-0{padding:0}.p-12{padding:3rem}.ml-4{margin-left:1rem}.pl-10{padding-left:2.5rem}.my-4{margin-top:1rem;margin-bottom:1rem}.my-6{margin-top:1.5rem;margin-bottom:1.5rem}.gap-8{gap:2rem}.page-narrow{max-width:480px}.font-medium{font-weight:500}.text-mini{font-size:.8rem}.pre-wrap{white-space:pre-wrap}.text-uppercase{text-transform:uppercase}.text-gray-700{color:var(--gray-700)}.icon-3xl{font-size:3rem}.icon-2xl{font-size:2rem}.icon-xl{font-size:1.5rem}.icon-lg{font-size:1.1rem}.relative{position:relative}.flex-shrink-0{flex-shrink:0}.bg-warning-soft{background:#fff8e1}.btn-xs{padding:.1rem .3rem;font-size:.75rem}.filter-select-sm{max-width:180px}.filter-input-md{max-width:300px}.filter-input-lg{min-width:200px}.select-auto{width:auto}.form-label-sm{min-width:90px}.form-label-md{min-width:110px}.col-50{width:50px}.col-60{width:60px}.col-80{width:80px}.col-100{width:100px}.col-110{width:110px}.col-160{width:160px}.col-180{width:180px}.col-date{width:110px}.col-status{width:100px}.col-amount{width:160px}.section-break-xl{border-top:1px solid var(--gray-200);margin:1.5rem 0;padding-top:.75rem}.flex-header-divider{margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--gray-200)}.product-main-layout{display:flex;gap:2rem}.product-sidebar{width:280px;flex-shrink:0;border-left:1px solid var(--gray-200);padding-left:1.5rem}.dg-fields-grid{display:grid;gap:.5rem}.form-grid-120{display:grid;grid-template-columns:120px 1fr;gap:.6rem 1rem;align-items:center}.input-postcode{flex:0 0 150px}.form-group-title{flex:0 0 100px}.roles-rights-panel{max-height:320px;overflow-y:auto}.roles-category-label{text-transform:uppercase;margin:.4rem 0 .2rem}.activity-types-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.4rem}.activity-type-label{display:flex;align-items:center;gap:.4rem;font-size:.9rem}.activity-type-picker{display:flex;flex-direction:column;gap:.5rem}.activity-type-group{border:1px solid var(--gray-200);border-radius:var(--border-radius)}.activity-type-group-header{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;background:var(--gray-50);border:none;border-radius:var(--border-radius);cursor:pointer;font-weight:600;font-size:.9rem;color:var(--gray-700)}.activity-type-group-caret{font-size:.7rem;color:var(--gray-500)}.activity-type-group-name{flex:1;text-align:left}.activity-type-group .activity-types-grid{padding:.5rem .75rem}.note-card{border:1px solid var(--gray-200);background:#fff}.note-card.highlighted{background:var(--warning-bg, #fff8e1)}.note-card.completed{opacity:.6}.note-card.completed .note-title{text-decoration:line-through}.note-card-meta{font-size:.8rem}.note-card-actions{margin-left:1rem;flex-shrink:0}.note-created-info{padding:.5rem .75rem;font-size:.85rem;color:var(--gray-600)}.doc-card-deleted{opacity:.5;text-decoration:line-through}.doc-icon-sm{font-size:1.1rem}.doc-icon-md{font-size:1.5rem}.doc-icon-lg{font-size:2rem}.doc-file-name{font-weight:500}.doc-file-size{font-size:.8rem}.form-group-horizontal{display:grid;grid-template-columns:150px 1fr;gap:1rem;align-items:start;margin-bottom:1.5rem;padding-left:40px}.form-group-horizontal .form-label{text-align:left;padding-top:.5rem;font-weight:500}.form-group-horizontal .form-input,.form-group-horizontal .form-select,.form-group-horizontal .form-textarea{width:100%;max-width:500px}.form-group-horizontal .form-checkbox,.form-group-horizontal input[type=checkbox]{justify-self:start;margin-top:10px}.form-group-inline{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}.form-group-inline .form-label{font-weight:500;white-space:nowrap;margin-bottom:0}.form-group-inline .form-input,.form-group-inline .form-select,.form-group-inline .form-textarea{flex:1}.form-group-inline .form-text{display:block;margin-top:.25rem}.section-divider{border-top:2px solid #ddd;margin:2rem 0;padding-top:2rem}.section-divider h4{margin-bottom:1.5rem;color:#333;font-size:1.1rem}h4{font-size:1rem;margin-bottom:1rem;color:var(--gray-900);font-weight:600}.expand-icon:hover{cursor:pointer}.info-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:.4rem 1.5rem;font-size:.875rem}.tab-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.form-input-readonly{background-color:#f5f5f5}.form-label-top{align-self:start;padding-top:.5rem}.tabs{display:flex;border-bottom:2px solid var(--gray-200);gap:.5rem;padding:0 1rem;background-color:var(--gray-50)}.tab-button{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:var(--font-size-base);font-weight:500;color:var(--gray-600);transition:all .2s;margin-bottom:-2px}.tab-button:hover{color:var(--primary-color);background-color:var(--gray-100)}.tab-button.active{color:var(--primary-color);border-bottom-color:var(--primary-color);background-color:#fff}.tab-content{display:none}.tab-content.active{display:block}.modal{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;max-width:none;background-color:#00000080;z-index:10000;overflow-y:auto}.modal.hidden{display:none!important}.modal-content{background-color:#fff;border-radius:var(--border-radius);box-shadow:0 10px 25px #0000004d;width:90%;max-width:600px;max-height:85vh;overflow-y:auto;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--gray-200)}.modal-header h3{margin:0;font-size:var(--font-size-xl);color:var(--gray-900)}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--gray-500);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background-color:var(--gray-100);color:var(--gray-700)}.modal-body{padding:1.5rem}.alert.alert-info{background-color:#e0f2fe;color:#0369a1;border-left:4px solid var(--info-color)}.document-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.document-card{border:1px solid var(--gray-200);border-radius:var(--border-radius-lg);padding:1rem;transition:all .2s;background:#fff;display:flex;flex-direction:column}.document-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.doc-type-icon{font-size:2.5rem;margin-bottom:.5rem;display:block}.doc-type-icon.pdf{color:#dc3545}.doc-type-icon.word{color:#06c}.doc-type-icon.excel{color:#198754}.doc-type-icon.image{color:#6f42c1}.doc-type-icon.generic{color:var(--gray-500)}.document-title{font-weight:600;margin-bottom:.25rem;color:var(--gray-900);font-size:.95rem;word-break:break-word}.document-meta{font-size:.8rem;color:var(--gray-500);margin-bottom:.5rem}.document-meta div{margin-bottom:.125rem}.document-notes{font-size:.8rem;color:var(--gray-600);margin-top:.5rem;line-height:1.4;text-align:left}.document-actions{margin-top:.75rem;display:flex;justify-content:center;gap:.35rem}.document-actions .btn-icon{width:30px;height:30px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;line-height:1;border-radius:var(--border-radius)}.document-filters{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.document-filters .form-input,.document-filters .form-select{min-width:150px}.auth-loading{display:flex;justify-content:center;align-items:center;height:100vh}.file-drop-zone{border:2px dashed var(--gray-300);border-radius:var(--border-radius-lg);padding:2rem;text-align:center;transition:all .2s;cursor:pointer;background:var(--gray-50)}.file-drop-zone:hover,.file-drop-zone.drag-over{border-color:var(--primary);background:#3b82f60d}.file-drop-zone .drop-icon{font-size:3rem;color:var(--gray-400);margin-bottom:1rem}.file-drop-zone p{margin:0;color:var(--gray-600)}.file-drop-zone .browse-link{color:var(--primary);cursor:pointer;text-decoration:underline}.document-card-header{display:flex;align-items:flex-start;gap:.75rem;text-align:left;margin-bottom:.75rem}.document-icon{font-size:2rem;line-height:1;flex-shrink:0}.document-info{flex:1;min-width:0}.document-card-body{text-align:left;padding-top:.75rem;border-top:1px solid var(--gray-100)}.document-details{display:grid;grid-template-columns:1fr 1fr;gap:.25rem 1rem;font-size:.8rem}.document-card-actions{display:flex;gap:.35rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--gray-100);justify-content:center}.document-card-actions .btn-icon{width:30px;height:30px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;line-height:1;border-radius:var(--border-radius)}.line-row.expanded{background-color:var(--gray-50)}.line-row .expand-btn{padding:0;border:none;background:transparent;cursor:pointer;font-size:.9rem;color:var(--gray-600);width:24px;height:24px}.line-row .expand-btn:hover{color:var(--primary)}.spec-details-row td{padding:0!important;background-color:var(--gray-50)}.spec-details-container{padding:1rem 1.5rem;border-top:1px solid var(--gray-200)}.spec-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--gray-200)}.spec-header h4{margin:0;font-size:1rem;color:var(--gray-800)}.spec-category{margin-bottom:1.5rem}.spec-category h5{margin:0 0 .75rem;font-size:.9rem;color:var(--primary);text-transform:uppercase;letter-spacing:.5px}.spec-params-table{width:100%;border-collapse:collapse;font-size:.85rem}.spec-params-table th,.spec-params-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--gray-100)}.spec-params-table th{background-color:var(--gray-100);font-weight:600;color:var(--gray-700);font-size:.8rem}.spec-params-table tr:hover{background-color:var(--gray-50)}.spec-params-table tr.acceptance-criterion{background-color:#f59e0b0d}.spec-params-table tr.acceptance-criterion:hover{background-color:#f59e0b1a}.spec-params-table .btn{padding:.2rem .5rem;font-size:.75rem}.btn-expand{background:none;border:none;cursor:pointer;padding:.25rem .5rem;font-size:.75rem;color:var(--gray-500);transition:color .2s}.btn-expand:hover{color:var(--primary-color)}.inventory-row.expanded{background-color:var(--gray-50)}.inventory-row.expanded td{border-bottom:none}.group-row{cursor:pointer;background-color:#fff}.group-row:hover{background-color:var(--gray-50)}.group-row.expanded{background-color:#e3f2fd}.group-row .expand-icon{display:inline-block;width:1rem;text-align:center;font-size:.8rem}.batches-row{background-color:var(--gray-50)}.batches-row.hidden{display:none}.batch-row{cursor:pointer;background-color:#fff}.batch-row:hover{background-color:#f0f7ff}.batch-row.expanded{background-color:#e8f4fd}.batch-row .expand-icon{display:inline-block;width:1rem;text-align:center}.expand-cell{width:40px;text-align:center}.movements-row{background-color:var(--gray-50)}.movements-row.hidden{display:none}.movements-cell{padding:0!important}.movements-container{padding:1rem 1.5rem 1.5rem 3rem;border-bottom:2px solid var(--gray-200)}.movements-header{margin-bottom:.75rem;color:var(--gray-700)}.movements-count{color:var(--gray-500);font-weight:400;font-size:.85rem;margin-left:.5rem}.movements-table{width:100%;border-collapse:collapse;font-size:.85rem;background-color:#fff;border-radius:var(--border-radius);overflow:hidden;box-shadow:0 1px 3px #0000001a}.movements-table th{background-color:var(--gray-100);padding:.5rem .75rem;text-align:left;font-weight:600;color:var(--gray-700);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px}.movements-table td{padding:.5rem .75rem;border-bottom:1px solid var(--gray-100)}.movements-table tr:last-child td{border-bottom:none}.movements-table tr:hover{background-color:var(--gray-50)}.movement-date{color:var(--gray-600);white-space:nowrap}.movement-direction{font-weight:500}.movement-quantity{text-align:right;font-weight:600;font-family:monospace}td.movement-in,.movement-in .movement-quantity{color:var(--success-color)}.movement-in .movement-quantity:before{content:"+"}td.movement-out,.movement-out .movement-quantity{color:var(--danger-color)}.movement-out .movement-quantity:before{content:"-"}.movement-adj .movement-quantity{color:var(--warning-color)}.movements-loading,.movements-empty,.movements-error{padding:1rem;text-align:center;color:var(--gray-500)}.movements-error{color:var(--danger-color)}.leg-parent-row{cursor:pointer;background-color:var(--gray-100)}.leg-parent-row:hover{background-color:var(--gray-200)}.leg-parent-row.expanded{background-color:var(--gray-50);border-bottom:2px solid var(--primary-color)}.leg-parent-row td{font-weight:600}.leg-toggle{display:inline-block;width:1.25rem;text-align:center;margin-right:.25rem}.leg-child-row{background-color:var(--gray-50)}.leg-child-row.hidden{display:none}.leg-child-row td:first-child{border-left:3px solid var(--primary-color);padding-left:1.5rem}.leg-route{font-size:.875rem;color:var(--gray-600)}.leg-activity-count{font-size:.75rem;color:var(--gray-500);margin-left:.5rem}.leg-date-range{font-size:.75rem;color:var(--gray-500)}.activity-toggle{display:inline-block;padding:2px 3px;font-size:.8em;background:transparent;border:1px solid var(--gray-300);cursor:pointer;transition:all .2s;border-radius:3px}.activity-toggle:hover{background-color:var(--gray-100);border-color:var(--gray-400)}.activity-action-row{background-color:#fafafa;border-left:3px solid #90caf9}.activity-action-row td{font-size:.95em;padding:8px 12px}.action-batch-row{background-color:#f5f5f5;border-left:3px solid #c5cae9}.action-batch-row td{font-size:.9em;padding:6px 12px;color:#555}.activity-action-row.hidden,.action-batch-row.hidden{display:none}.sequence-position-selector{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--gray-50);border-radius:var(--border-radius);border:1px solid var(--gray-200)}.sequence-position-selector .form-check{display:flex;align-items:center;gap:.5rem;margin:0}.sequence-position-selector .form-check input[type=radio]{margin:0;flex-shrink:0}.sequence-position-selector .form-check label{margin:0;font-weight:400;white-space:nowrap}.sequence-position-selector .form-check select{flex:1;min-width:150px;padding:.25rem .5rem;font-size:.875rem}.sequence-position-selector .form-check select:disabled{background-color:var(--gray-100);cursor:not-allowed}.standalone-activity-row{background-color:#fff}.standalone-activity-row:hover{background-color:var(--gray-50)}.popup{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:9999;align-items:center;justify-content:center;animation:fadeIn .2s ease-in-out}.popup.active{display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.popup-content{background:#fff;border-radius:var(--border-radius-lg);box-shadow:0 10px 40px #0000004d;max-width:600px;width:90%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.popup-header{padding:1.2rem 1.5rem;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;cursor:move;-webkit-user-select:none;user-select:none}.popup-header h3{margin:0;font-size:var(--font-size-xl);color:var(--gray-900)}.popup-close{background:none;border:none;font-size:1.5rem;color:var(--gray-500);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;padding:0}.popup-close:hover{background-color:var(--gray-100);color:var(--gray-700)}.popup-body{padding:1.5rem;overflow-y:auto;flex:1;min-height:0}.popup-footer{padding:1rem 1.5rem;border-top:1px solid var(--gray-200);display:flex;justify-content:flex-end;gap:.5rem;flex-shrink:0}.transit-row{background-color:#fefefe}.transit-row.expanded{background-color:#f0f9ff}.transit-details-row{background-color:#f8fafc}.transit-details-row.hidden{display:none}.transit-details-cell{padding:0!important}.transit-details-container{padding:1rem;background-color:#f8fafc}.transit-details-header{font-weight:600;margin-bottom:1rem;font-size:var(--font-size-lg);color:var(--gray-800)}.transit-details-loading,.transit-details-empty,.transit-details-error{padding:1rem;text-align:center;color:var(--gray-500)}.transit-details-error{color:var(--danger-color)}.activity-detail-popup{max-width:90%!important;width:90%!important;height:90vh;display:flex;flex-direction:column}.activity-detail-popup .popup-body{display:flex;flex-direction:column;overflow:hidden;flex:1;padding:1rem 1.5rem}.activity-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:.4rem 1.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--gray-200);margin-bottom:0}.activity-detail-grid .form-group-inline{margin-bottom:0}.activity-detail-grid .form-group-inline label{min-width:110px;font-size:var(--font-size-sm)}.activity-detail-grid .full-span{grid-column:1 / -1}.activity-detail-tabs{display:flex;flex-direction:column;flex:1;overflow:hidden;margin-top:.5rem}.activity-detail-tabs .tabs{display:flex;border-bottom:2px solid var(--gray-200);flex-shrink:0}.activity-detail-tabs .tab-button{padding:.5rem 1.25rem;font-size:var(--font-size-sm)}.activity-detail-tabs .tab-content{flex:1;overflow-y:auto;padding:.75rem 0;display:none}.activity-detail-tabs .tab-content.active{display:block}.actions-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.actions-table th{text-align:left;padding:.5rem .75rem;background:var(--gray-50);border-bottom:2px solid var(--gray-200);font-weight:600;color:var(--gray-600)}.actions-table td{padding:.5rem .75rem;border-bottom:1px solid var(--gray-100)}.actions-table .action-row{cursor:pointer;transition:background .15s}.actions-table .action-row:hover{background:var(--gray-50)}.actions-table .action-sub-rows{display:none}.actions-table .action-sub-rows.expanded{display:table-row}.actions-table .sub-row-cell{padding:.5rem .75rem .5rem 2rem;background:#f8fafc}.sub-section-title{font-weight:600;font-size:var(--font-size-xs);color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.sub-item{display:flex;align-items:center;gap:.5rem;padding:.25rem 0;font-size:var(--font-size-sm)}.sub-item .btn{padding:.15rem .5rem;font-size:var(--font-size-xs)}.losses-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.losses-table th{text-align:left;padding:.5rem .75rem;background:var(--gray-50);border-bottom:2px solid var(--gray-200);font-weight:600;color:var(--gray-600)}.losses-table td{padding:.5rem .75rem;border-bottom:1px solid var(--gray-100)}.activity-doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem;margin-top:.5rem}.activity-doc-card{border:1px solid var(--gray-200);border-radius:var(--border-radius-lg);padding:.75rem;background:#fff;display:flex;flex-direction:column;gap:.25rem;transition:all .2s}.activity-doc-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.activity-doc-card .doc-title{font-weight:600;font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-doc-card .doc-meta{font-size:var(--font-size-xs);color:var(--gray-500)}.activity-doc-card .doc-actions{display:flex;gap:.25rem;margin-top:.25rem}.doc-source-badge{display:inline-block;padding:.1rem .4rem;border-radius:var(--border-radius-sm);font-size:10px;font-weight:600;text-transform:uppercase;background:var(--gray-100);color:var(--gray-600)}.activity-upload-zone{border:2px dashed var(--gray-300);border-radius:var(--border-radius-lg);padding:1.5rem;text-align:center;cursor:pointer;transition:all .2s;color:var(--gray-500);margin-bottom:.75rem}.activity-upload-zone:hover,.activity-upload-zone.drag-over{border-color:var(--primary-color);background:#3b82f60a;color:var(--primary-color)}.picture-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;margin-top:.5rem}.picture-thumbnail{position:relative;aspect-ratio:1;border-radius:var(--border-radius-lg);overflow:hidden;cursor:pointer;border:1px solid var(--gray-200);transition:all .2s}.picture-thumbnail:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.picture-thumbnail img{width:100%;height:100%;object-fit:cover}.picture-thumbnail .pic-delete{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#ef4444e6;color:#fff;border:none;cursor:pointer;display:none;align-items:center;justify-content:center;font-size:14px;line-height:1}.picture-thumbnail:hover .pic-delete{display:flex}.lightbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;cursor:pointer}.lightbox-overlay img{max-width:90%;max-height:90%;object-fit:contain;border-radius:var(--border-radius-lg)}.vehicle-map-popup .popup-content{max-width:800px;width:90%}.activity-tab-empty{text-align:center;padding:2rem;color:var(--gray-400);font-style:italic}.loss-type-badge{display:inline-block;padding:.15rem .5rem;border-radius:var(--border-radius-sm);font-size:var(--font-size-xs);font-weight:600}.loss-type-badge.SPILLAGE{background:#fef3c7;color:#92400e}.loss-type-badge.EVAPORATION{background:#dbeafe;color:#1e40af}.loss-type-badge.CONTAMINATION{background:#fce7f3;color:#9d174d}.loss-type-badge.THEFT{background:#fee2e2;color:#991b1b}.loss-type-badge.DAMAGE{background:#ffedd5;color:#9a3412}.loss-type-badge.OTHER{background:var(--gray-100);color:var(--gray-600)}.batch-color-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:4px;vertical-align:middle}.batch-color-dot.color-red{background-color:#ef4444}.batch-color-dot.color-blue{background-color:#3b82f6}.batch-color-dot.color-green{background-color:#22c55e}.batch-color-dot.color-orange{background-color:#f97316}.batch-color-dot.color-purple{background-color:#a855f7}.batch-color-dot.color-yellow{background-color:#eab308}.batch-color-dot.color-pink{background-color:#ec4899}.batch-color-dot.color-teal{background-color:#14b8a6}.batch-color-dot.color-brown{background-color:#a16207}.batch-color-dot.color-grey{background-color:#6b7280}.doc-view-toggle{display:flex;gap:2px;margin-left:auto}.btn-toggle{background:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-300);padding:.25rem .5rem;font-size:1rem;line-height:1;cursor:pointer;transition:all .15s}.btn-toggle:first-child{border-radius:var(--border-radius) 0 0 var(--border-radius)}.btn-toggle:last-child{border-radius:0 var(--border-radius) var(--border-radius) 0}.btn-toggle.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.document-list{width:100%;border-collapse:collapse}.document-list th,.document-list td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--gray-200);font-size:.875rem}.document-list th{background:var(--gray-50);font-weight:600;color:var(--gray-700);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.document-list tbody tr:hover{background:var(--gray-50)}.document-list .doc-list-title{font-weight:500;display:flex;align-items:center;gap:.5rem}.document-list .doc-list-actions{display:flex;gap:.25rem;justify-content:flex-end}.doc-ai-spinner{cursor:default;opacity:.7}.doc-spin-icon{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.highlighted-notes-flyout{position:absolute;top:100%;right:0;width:350px;max-height:400px;overflow-y:auto;background:#fff;border:1px solid var(--gray-200);border-radius:var(--border-radius);box-shadow:0 4px 12px #00000026;z-index:100}.flyout-header{padding:.75rem 1rem;font-weight:600;font-size:.875rem;border-bottom:1px solid var(--gray-200);background:var(--gray-50)}.flyout-body{padding:.5rem}.flyout-item{padding:.6rem .75rem;border-radius:var(--border-radius);cursor:pointer;border-left:3px solid var(--warning-color);margin-bottom:.4rem;background:#fffdf5}.flyout-item:hover{background:var(--gray-100)}.flyout-item-button{display:block;width:100%;text-align:left;font:inherit;color:inherit}.flyout-item-title{font-weight:600;font-size:.85rem;margin-bottom:.2rem}.flyout-item-body{font-size:.8rem;color:var(--gray-600);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.btn-star{color:var(--warning-color);font-size:1.1rem}.so-dropdown{min-width:160px;font-size:.875rem}.so-dropdown-cell{min-width:180px}.so-alloc-subrow{background:#f9fafb}.so-alloc-subrow td{padding-top:.25rem;padding-bottom:.25rem;font-size:.875rem;color:#6b7280}.so-alloc-subrow .form-input{width:120px;font-size:.875rem}.so-filter-bar{background:#eff6ff;padding:.75rem 1rem;border-radius:4px;border-left:4px solid #3b82f6;margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}.so-filter-bar label{font-weight:500;color:#1e40af;white-space:nowrap}.so-filter-bar select{flex:1;min-width:200px}.so-filter-bar .so-filter-reset{margin-left:auto;align-self:flex-end}.invoice-col-qty{width:100px}.invoice-col-price{width:120px}.invoice-col-amount{width:140px}.qe-header-grid{display:grid;grid-template-columns:1fr 1fr;gap:.4rem 1.5rem;margin-top:1rem;margin-bottom:.75rem}.qe-header-grid .form-group-inline{margin-bottom:0}.qe-header-grid .form-group-inline .form-label{min-width:90px}.qe-col-full{grid-column:1 / -1}.qe-col-left{grid-column:1}.qe-row-right{justify-content:flex-end}.qe-row-right .form-label{min-width:auto}.qe-status-display{font-weight:600}.qe-lines-container{max-height:250px;overflow-y:auto}.qe-totals-bar{margin-top:1rem;padding:.75rem 1rem;background:var(--gray-50);border-radius:var(--border-radius);text-align:right;font-weight:600}.qe-totals-bar.qe-totals-split{display:flex;justify-content:space-between;font-weight:400;text-align:left}.qe-mark-sent-area{margin-top:1rem;padding:1rem;background:var(--info-bg, #e8f4fd);border-radius:var(--border-radius);display:flex;align-items:center;justify-content:space-between}.qe-mark-sent-area .btn+.btn{margin-left:.5rem}.qe-save-first-overlay{padding:2rem;text-align:center}.qe-subtab-content.hidden,.qe-tab-content.hidden{display:none}.qe-footer-row{display:flex;justify-content:space-between;align-items:center;width:100%;gap:.75rem}.qe-footer-left,.qe-footer-right{display:flex;gap:.5rem}.qe-values-section{margin-top:.75rem;padding-top:.75rem;border-top:2px solid var(--gray-200)}.qe-values-section h4{margin:0 0 .5rem;font-size:.9rem;color:var(--gray-600)}.qe-inline-actions{display:flex;gap:.5rem;align-items:center}.qe-readonly-input{background:var(--gray-100)}.qe-tab-heading{display:flex;justify-content:space-between;align-items:center;margin:1rem 0 .5rem}.qe-tab-heading h4{margin:0}.qe-status-select{width:auto;min-width:150px}.table-foot-total tr{font-weight:600;background:var(--gray-100)}.menu-section-header[role=button],.menu-subgroup-header[role=button]{cursor:pointer}.app-header .header-right{display:flex;align-items:center;gap:1.25rem;color:#e1dfdb;font-family:Open Sans,sans-serif;font-size:.85rem}.app-header .header-user{color:#fff;font-weight:600}.app-header .header-link{color:#a0a0a0;text-decoration:none;background:none;border:0;cursor:pointer;font-size:.85rem;font-family:Open Sans,sans-serif;padding:0}.app-header .header-link:hover{color:#fff}.app-header .header-link-btn{text-transform:none}.sidebar-nav .menu-section-content>a{display:block;padding:.55rem 1.5rem .55rem 2.5rem;color:var(--gray-700);text-decoration:none;font-size:var(--font-size-sm);transition:all .2s}.sidebar-nav .menu-section-content>a:hover{background-color:var(--gray-100);color:var(--primary-color)}.sidebar-nav .menu-section-content>a.active{background-color:var(--primary-color);color:#fff;font-weight:500;border-left:3px solid var(--primary-hover)}.page-header-right{display:flex;gap:.5rem;align-items:center}.public-page{background:#1b1b1b;min-height:100vh;display:flex;align-items:center;justify-content:center;margin:0;font-family:Open Sans,sans-serif;color:#e1dfdb}.login-container{text-align:center;width:100%;max-width:420px;padding:2rem}.login-brand{color:#e1dfdb;margin-bottom:2.5rem}.login-brand img{width:80px;height:80px;margin-bottom:1.25rem}.login-brand h1{font-family:Playfair Display,serif;font-size:2.2rem;font-weight:700;letter-spacing:.08em;margin:0 0 .4rem;color:#fff}.login-brand p{font-size:.85rem;opacity:.6;margin:0;letter-spacing:.15em;text-transform:uppercase}.login-card{background:#303033;border-radius:6px;box-shadow:0 10px 40px #0006;padding:2rem;text-align:left}.login-card h2{margin:0 0 1.5rem;font-family:Playfair Display,serif;font-size:1.2rem;color:#fff;font-weight:400;text-align:center}.login-card label{display:block;text-align:left;font-size:.8rem;font-weight:600;color:#a0a0a0;margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.05em}.login-card input{width:100%;padding:.65rem .75rem;font-size:.95rem;font-family:Open Sans,sans-serif;border:1px solid #4a4a4d;border-radius:4px;margin-bottom:1.25rem;background:#1b1b1b;color:#e1dfdb;box-sizing:border-box}.login-card input:focus{outline:none;border-color:#fff;box-shadow:0 0 0 2px #ffffff1a}.login-card .field-row{display:flex;gap:.5rem;margin-bottom:1.25rem}.login-card .field-row input{margin-bottom:0}.login-btn{width:100%;padding:.75rem;font-size:.9rem;font-weight:600;font-family:Open Sans,sans-serif;color:#1b1b1b;background:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s,color .2s;text-transform:uppercase;letter-spacing:.08em}.login-btn.secondary{background:transparent;color:#a0a0a0;border:1px solid #4a4a4d}.login-btn:hover{background:#e1dfdb}.login-btn.secondary:hover{background:#4a4a4d;color:#fff}.login-btn:disabled{background:#4a4a4d;color:#7a7a7a;cursor:not-allowed}.login-error{color:#ef4444;font-size:.85rem;margin-top:.75rem;padding:.5rem .75rem;background:#ef44441a;border-radius:4px}.login-help{color:#a0a0a0;font-size:.85rem;text-align:center;margin-top:1rem}.login-help a{color:#93c5fd;text-decoration:none}.login-help a:hover{text-decoration:underline}.field-error{color:#ef4444;font-size:.75rem;margin:-.75rem 0 .75rem}.login-notice{font-size:.9rem;margin-bottom:1rem;color:#e1dfdb}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:1000}.modal-popup{position:fixed;background:#fff;border-radius:8px;box-shadow:0 10px 40px #0006;display:flex;flex-direction:column;max-height:80vh;overflow:hidden;font-family:var(--font-family, system-ui, sans-serif)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.25rem;background:#1b1b1b;color:#fff;cursor:move;-webkit-user-select:none;user-select:none;border-radius:8px 8px 0 0}.modal-header h3{margin:0;font-family:Playfair Display,serif;font-size:1.1rem;font-weight:400;color:#fff}.modal-close{background:none;border:none;color:#a0a0a0;font-size:1.6rem;line-height:1;cursor:pointer;padding:0}.modal-close:hover{color:#fff}.modal-body{padding:1.25rem 1.5rem;overflow-y:auto;flex:1 1 auto;min-height:0}.modal-footer{padding:.85rem 1.25rem;border-top:1px solid var(--gray-200, #e5e7eb);display:flex;justify-content:flex-end;gap:.5rem;background:var(--gray-50, #f9fafb);border-radius:0 0 8px 8px}.modal-body .field{margin-bottom:.85rem}.modal-body .field label{display:block;margin-bottom:.3rem;font-size:.85rem;color:var(--gray-700, #374151);font-weight:600}.modal-body .field input,.modal-body .field select,.modal-body .field textarea{width:100%;padding:.45rem .55rem;font-size:.9rem;border:1px solid var(--gray-300, #d1d5db);border-radius:4px;box-sizing:border-box;font-family:inherit}.modal-body .check-list{max-height:220px;overflow-y:auto;border:1px solid var(--gray-300, #d1d5db);border-radius:4px;padding:.5rem .75rem;background:var(--gray-50, #f9fafb)}.modal-body .check-list label{display:block;font-size:.85rem;font-weight:400;margin-bottom:.25rem}.modal-body .form-error{color:var(--danger-color, #ef4444);background:#fef2f2;padding:.5rem .75rem;border-radius:4px;font-size:.85rem;margin-bottom:.75rem}
