/* ==================================================
   SCOPE OF WORK PAGE STYLES
   Extracted from reference: Scope of work orginal code for refrence .html
   ================================================== */

/* Wrapper: single root so #page-content has one child; stacks toast, page, FABs */
.sow-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    position: relative;
}

/* Scope of Work uses .page-container for A4 layout (210mm x 297mm) - matches Products, Cover, Company Intro */
#page-content > .sow-wrapper > .sow-page-container,
#page-content > .sow-page-container.page-container {
    width: 210mm;
    max-width: 210mm;
    height: 297mm;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding: 15px;
    box-shadow: 0 3px 15px rgba(0,0,0,0.08);
    border: 1px solid var(--brand-primary, #e5e7eb);
    border-radius: 5px;
    margin: 30px auto 0 auto;
    transform-origin: top center;
    position: relative;
    box-sizing: border-box;
}

.sow-page-container table.sow-print-container,
.scope-of-work-page table.sow-print-container,
.objectives-page table.sow-print-container,
.objectives-page table.obj-print-container {
    display: flex;
    flex-direction: column;
    flex: 1 1 0;
    height: 100%;
    width: 100%;
    border-collapse: collapse;
    padding: 0;
    box-sizing: border-box;
    min-height: 0;
}

.sow-page-container table.sow-print-container thead,
.scope-of-work-page table.sow-print-container thead,
.objectives-page table.sow-print-container thead,
.objectives-page table.obj-print-container thead {
    display: block;
    flex-shrink: 0;
    position: relative;
    min-height: 0;
    width: 100%;
}

.sow-page-container table.sow-print-container thead tr,
.scope-of-work-page table.sow-print-container thead tr,
.objectives-page table.sow-print-container thead tr,
.objectives-page table.obj-print-container thead tr {
    display: block;
    width: 100%;
}

.sow-page-container table.sow-print-container thead tr th,
.scope-of-work-page table.sow-print-container thead tr th,
.objectives-page table.sow-print-container thead tr th,
.objectives-page table.obj-print-container thead tr th {
    display: block;
    width: 100%;
    padding: 0;
    border: none;
    min-height: 0;
    box-sizing: border-box;
}

.sow-page-container table.sow-print-container tbody,
.scope-of-work-page table.sow-print-container tbody,
.objectives-page table.sow-print-container tbody,
.objectives-page table.obj-print-container tbody {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    overflow: hidden;
    min-height: 0;
    margin-top: 4px;
    margin-bottom: 12px;
    width: 100%;
}

.sow-page-container table.sow-print-container tbody tr,
.scope-of-work-page table.sow-print-container tbody tr,
.objectives-page table.sow-print-container tbody tr,
.objectives-page table.obj-print-container tbody tr {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    min-height: 0;
    width: 100%;
}

.sow-page-container table.sow-print-container tbody td,
.scope-of-work-page table.sow-print-container tbody td,
.objectives-page table.sow-print-container tbody td,
.objectives-page table.obj-print-container tbody td {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    width: 100%;
    vertical-align: top;
    padding: 0;
    overflow: hidden;
    min-height: 0;
    box-sizing: border-box;
}

.sow-page-container table.sow-print-container tfoot,
.scope-of-work-page table.sow-print-container tfoot,
.objectives-page table.sow-print-container tfoot,
.objectives-page table.obj-print-container tfoot {
    display: block;
    flex-shrink: 0;
    margin-top: 0;
    min-height: 0;
    width: 100%;
    border-top: none;
}

.sow-page-container table.sow-print-container tfoot tr,
.scope-of-work-page table.sow-print-container tfoot tr,
.objectives-page table.sow-print-container tfoot tr,
.objectives-page table.obj-print-container tfoot tr {
    display: block;
    width: 100%;
}

.sow-page-container table.sow-print-container tfoot tr td,
.scope-of-work-page table.sow-print-container tfoot tr td,
.objectives-page table.sow-print-container tfoot tr td,
.objectives-page table.obj-print-container tfoot tr td {
    display: block;
    width: 100%;
    min-height: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Header block: relative position container */
.sow-page-container .sow-header-block,
.scope-of-work-page .sow-header-block,
.objectives-page .sow-header-block,
.objectives-page .obj-header-block,
#page-content .sow-page-container .sow-header-block {
    position: relative !important;
    width: 100% !important;
    min-height: 90px !important;
    padding: 8px !important;
    background-color: #ffffff !important;
    text-align: center !important;
}

/* Line below header content – push down so it never goes under the logo (logo is absolute, so hr needs margin-top) */
.sow-page-container .sow-header-block hr,
.scope-of-work-page .sow-header-block hr,
.objectives-page .sow-header-block hr {
    margin: 100px 0 0 0;
    border: none;
    border-top: 1px solid #dee2e6;
}

/* Logo: top-left, above the line (like Product List) – no strip over the header line */
.sow-page-container .sow-logo-container,
.scope-of-work-page .sow-logo-container,
.objectives-page .sow-logo-container,
.objectives-page .obj-logo-container {
    display: inline-block;
    position: absolute;
    top: 8px;
    left: 8px;
    padding: 0;
    margin: 0;
    z-index: 10;
}

/* Logo: same size as Products, Price Summary */
.sow-page-container .sow-logo,
.scope-of-work-page .sow-logo,
.objectives-page .sow-logo,
.objectives-page .obj-logo {
    max-width: var(--header-logo-max-width, 140px);
    max-height: var(--header-logo-max-height, 90px);
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
}

/* Title: absolute center - FORCE with !important */
#page-content .sow-page-container .sow-header-block h3.sow-title,
#page-content .scope-of-work-page .sow-header-block h3.sow-title,
#page-content .objectives-page .sow-header-block h3.sow-title,
.sow-page-container .sow-header-block h3.sow-title,
.scope-of-work-page .sow-header-block h3.sow-title,
.objectives-page .sow-header-block h3.sow-title,
.sow-page-container h3.sow-title,
.scope-of-work-page h3.sow-title,
.objectives-page h3.sow-title {
    position: absolute !important;
    top: 45px !important;
    left: 50% !important;
    right: auto !important;
    transform: translate(-50%, -50%) !important;
    -webkit-transform: translate(-50%, -50%) !important;
    -moz-transform: translate(-50%, -50%) !important;
    -ms-transform: translate(-50%, -50%) !important;
    margin: 0 auto !important;
    padding: 0 !important;
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    text-align: center !important;
    color: #1a202c !important;
    white-space: nowrap !important;
    display: block !important;
    width: auto !important;
}

/* Customer name: bottom-right, closer to the header line */
.sow-page-container .sow-customer-name-container,
.scope-of-work-page .sow-customer-name-container,
.objectives-page .sow-customer-name-container,
.objectives-page .obj-customer-name-container,
#page-content .sow-page-container .sow-customer-name-container {
    position: absolute !important;
    bottom: 4px !important;
    right: 8px !important;
    left: auto !important;
    top: auto !important;
    text-align: right !important;
}

.sow-page-container .sow-customer-name,
.scope-of-work-page .sow-customer-name,
.objectives-page .sow-customer-name,
.objectives-page .obj-customer-name {
    font-weight: bold;
    font-size: 14px;
    margin: 0;
    text-align: right;
    color: #333;
    display: block;
    white-space: nowrap;
}

/* Editor area: extend outside the inner padding so it sits against the page border; stop above footer */
.sow-page-container .sow-intro,
.scope-of-work-page .sow-intro,
.objectives-page .sow-intro,
.objectives-page .obj-intro {
    text-align: left;
    font-size: 11pt;
    line-height: 1.5;
    color: #212529;
    flex: 1 1 0;
    display: flex;
    flex-direction: column;
    overflow-x: visible; /* let toolbar picker dropdowns show */
    overflow-y: hidden;
    min-height: 0;
    max-height: none;
    width: calc(100% + 30px);
    margin-left: -15px;
    margin-right: -15px;
    margin-bottom: 0;
    box-sizing: border-box;
}

.sow-page-container #sow-editor-container,
.scope-of-work-page #sow-editor-container,
.objectives-page #obj-editor-container {
    flex: 1 1 0;
    width: 100%;
    display: flex;
    flex-direction: column;
    border: 1px solid #d1d5db;
    border-bottom: none;
    border-radius: 0;
    padding: 0;
    padding-left: 50px;
    box-sizing: border-box;
    box-shadow: inset 0 1px 3px rgba(0,0,0,0.05);
    background-color: #fff;
    position: relative;
    overflow-x: visible; /* let toolbar picker dropdowns (H, font, size) show to the right */
    overflow-y: hidden;
    min-height: 0;
    pointer-events: auto !important;
}

.sow-page-container .ql-container.ql-snow,
.scope-of-work-page .ql-container.ql-snow,
.objectives-page .ql-container.ql-snow {
    border-radius: 0 6px 6px 0;
    border: none;
    flex: 1 1 0;
    width: 100%;
    overflow-y: auto;
    padding: 20px 40px 20px 40px !important;
    box-sizing: border-box;
    min-height: 0;
    display: flex;
    flex-direction: column;
    pointer-events: auto !important;
}

.sow-page-container .ql-editor,
.scope-of-work-page .ql-editor,
.objectives-page .ql-editor {
    box-sizing: border-box;
    min-height: 0;
    flex: 1 1 0;
    font-size: 14px;
    line-height: 1.6;
    width: 100%;
    max-width: none;
    /* Ensure editor is interactive - fixes text input not working */
    pointer-events: auto !important;
    cursor: text !important;
    user-select: text !important;
    -webkit-user-select: text !important;
    -moz-user-select: text !important;
    -ms-user-select: text !important;
}

/* Match Objectives page: ensure Scope of Work text and placeholder start at same horizontal position */
.scope-of-work-page .ql-editor {
    padding: 12px 15px;
}

.scope-of-work-page .ql-editor.ql-blank::before {
    left: 55px !important;
    right: 15px;
}

/* Quill editor content – apply font size and font family from toolbar (so Size/Font picks work) */
.sow-page-container .ql-editor .ql-size-12px,
.scope-of-work-page .ql-editor .ql-size-12px,
.objectives-page .ql-editor .ql-size-12px { font-size: 12px !important; }
.sow-page-container .ql-editor .ql-size-14px,
.scope-of-work-page .ql-editor .ql-size-14px,
.objectives-page .ql-editor .ql-size-14px { font-size: 14px !important; }
.sow-page-container .ql-editor .ql-size-16px,
.scope-of-work-page .ql-editor .ql-size-16px,
.objectives-page .ql-editor .ql-size-16px { font-size: 16px !important; }
.sow-page-container .ql-editor .ql-size-18px,
.scope-of-work-page .ql-editor .ql-size-18px,
.objectives-page .ql-editor .ql-size-18px { font-size: 18px !important; }
.sow-page-container .ql-editor .ql-size-20px,
.scope-of-work-page .ql-editor .ql-size-20px,
.objectives-page .ql-editor .ql-size-20px { font-size: 20px !important; }
.sow-page-container .ql-editor .ql-size-24px,
.scope-of-work-page .ql-editor .ql-size-24px,
.objectives-page .ql-editor .ql-size-24px { font-size: 24px !important; }
.sow-page-container .ql-editor .ql-size-28px,
.scope-of-work-page .ql-editor .ql-size-28px,
.objectives-page .ql-editor .ql-size-28px { font-size: 28px !important; }

.sow-page-container .ql-editor .ql-font-sans-serif,
.scope-of-work-page .ql-editor .ql-font-sans-serif,
.objectives-page .ql-editor .ql-font-sans-serif { font-family: sans-serif !important; }
.sow-page-container .ql-editor .ql-font-serif,
.scope-of-work-page .ql-editor .ql-font-serif,
.objectives-page .ql-editor .ql-font-serif { font-family: serif !important; }
.sow-page-container .ql-editor .ql-font-monospace,
.scope-of-work-page .ql-editor .ql-font-monospace,
.objectives-page .ql-editor .ql-font-monospace { font-family: monospace !important; }
.sow-page-container .ql-editor .ql-font-arial,
.scope-of-work-page .ql-editor .ql-font-arial,
.objectives-page .ql-editor .ql-font-arial { font-family: Arial, sans-serif !important; }
.sow-page-container .ql-editor .ql-font-georgia,
.scope-of-work-page .ql-editor .ql-font-georgia,
.objectives-page .ql-editor .ql-font-georgia { font-family: Georgia, serif !important; }
.sow-page-container .ql-editor .ql-font-courier-new,
.scope-of-work-page .ql-editor .ql-font-courier-new,
.objectives-page .ql-editor .ql-font-courier-new { font-family: 'Courier New', monospace !important; }
.sow-page-container .ql-editor .ql-font-verdana,
.scope-of-work-page .ql-editor .ql-font-verdana,
.objectives-page .ql-editor .ql-font-verdana { font-family: Verdana, sans-serif !important; }
.sow-page-container .ql-editor .ql-font-impact,
.scope-of-work-page .ql-editor .ql-font-impact,
.objectives-page .ql-editor .ql-font-impact { font-family: Impact, sans-serif !important; }

/* Quill editor content – header (H) picker: so Heading 1–6 and Normal display correctly */
.sow-page-container .ql-editor h1,
.scope-of-work-page .ql-editor h1,
.objectives-page .ql-editor h1 { font-size: 2em !important; font-weight: bold !important; margin: 0.67em 0 !important; }
.sow-page-container .ql-editor h2,
.scope-of-work-page .ql-editor h2,
.objectives-page .ql-editor h2 { font-size: 1.5em !important; font-weight: bold !important; margin: 0.75em 0 !important; }
.sow-page-container .ql-editor h3,
.scope-of-work-page .ql-editor h3,
.objectives-page .ql-editor h3 { font-size: 1.17em !important; font-weight: bold !important; margin: 0.83em 0 !important; }
.sow-page-container .ql-editor h4,
.scope-of-work-page .ql-editor h4,
.objectives-page .ql-editor h4 { font-size: 1em !important; font-weight: bold !important; margin: 1em 0 !important; }
.sow-page-container .ql-editor h5,
.scope-of-work-page .ql-editor h5,
.objectives-page .ql-editor h5 { font-size: 0.83em !important; font-weight: bold !important; margin: 1.17em 0 !important; }
.sow-page-container .ql-editor h6,
.scope-of-work-page .ql-editor h6,
.objectives-page .ql-editor h6 { font-size: 0.67em !important; font-weight: bold !important; margin: 1.33em 0 !important; }

/* Hide Quill placeholder inputs and any stray inputs (formula/link/video prompts, etc.) */
.sow-page-container input[data-formula],
.sow-page-container input[data-link],
.sow-page-container input[data-video],
.scope-of-work-page input[data-formula],
.objectives-page input[data-formula],
.scope-of-work-page input[data-link],
.objectives-page input[data-link],
.scope-of-work-page input[data-video],
.objectives-page input[data-video],
.scope-of-work-page input,
.objectives-page input {
    display: none !important;
    position: absolute !important;
    left: -9999px !important;
}

/* Quill toolbar - compact vertical strip on left */
.sow-page-container .ql-toolbar.ql-snow,
.scope-of-work-page .ql-toolbar.ql-snow,
.objectives-page .ql-toolbar.ql-snow {
    position: absolute;
    left: 0;
    top: 200px;
    z-index: 1000;
    width: 34px;
    pointer-events: auto !important;
    max-height: calc(100% - 80px);
    min-height: 80px;
    overflow-y: auto;
    overflow-x: visible; /* allow picker dropdowns (H, font, size, etc.) to show to the right */
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1px;
    background-color: #f8f9fa;
    border: 1px solid #e9ecef;
    border-left: none;
    border-radius: 0 6px 6px 0;
    padding: 4px 0;
    box-shadow: 2px 0 4px rgba(0,0,0,0.05);
}

.sow-page-container .ql-toolbar.ql-snow .ql-formats,
.scope-of-work-page .ql-toolbar.ql-snow .ql-formats,
.objectives-page .ql-toolbar.ql-snow .ql-formats {
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1px;
    width: 100%;
}
/* Divider between format groups - compact */
.sow-page-container .ql-toolbar.ql-snow .ql-formats + .ql-formats,
.scope-of-work-page .ql-toolbar.ql-snow .ql-formats + .ql-formats,
.objectives-page .ql-toolbar.ql-snow .ql-formats + .ql-formats {
    border-top: 1px solid #dee2e6;
    margin-top: 3px;
    padding-top: 3px;
}

.sow-page-container .ql-toolbar.ql-snow button,
.sow-page-container .ql-toolbar.ql-snow .ql-picker,
.scope-of-work-page .ql-toolbar.ql-snow button,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker,
.objectives-page .ql-toolbar.ql-snow button,
.objectives-page .ql-toolbar.ql-snow .ql-picker {
    width: 26px !important;
    height: 26px !important;
    position: relative;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background-color: transparent;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.15s ease, transform 0.1s ease;
    font-size: 0 !important;
    line-height: 0 !important;
    color: transparent !important;
    will-change: transform;
    pointer-events: auto !important;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker .ql-picker-label,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker .ql-picker-label,
.objectives-page .ql-toolbar.ql-snow .ql-picker .ql-picker-label {
    pointer-events: auto !important;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker .ql-picker-label,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker .ql-picker-label,
.objectives-page .ql-toolbar.ql-snow .ql-picker .ql-picker-label {
    cursor: pointer;
    transition: color 0.15s ease;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker:hover .ql-picker-label,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker:hover .ql-picker-label,
.objectives-page .ql-toolbar.ql-snow .ql-picker:hover .ql-picker-label {
    color: #007bff;
}

.sow-page-container .ql-toolbar.ql-snow button:hover,
.sow-page-container .ql-toolbar.ql-snow .ql-picker:hover,
.scope-of-work-page .ql-toolbar.ql-snow button:hover,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker:hover,
.objectives-page .ql-toolbar.ql-snow button:hover,
.objectives-page .ql-toolbar.ql-snow .ql-picker:hover {
    background-color: #e9ecef;
    transform: scale(1.05);
}

.sow-page-container .ql-toolbar.ql-snow button:active,
.sow-page-container .ql-toolbar.ql-snow .ql-picker:active,
.scope-of-work-page .ql-toolbar.ql-snow button:active,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker:active,
.objectives-page .ql-toolbar.ql-snow button:active,
.objectives-page .ql-toolbar.ql-snow .ql-picker:active {
    background-color: #dee2e6;
    transform: scale(0.95);
}

.sow-page-container .ql-toolbar.ql-snow .ql-picker-label::after,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker-label::after,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label::after,
.objectives-page .ql-toolbar.ql-snow .ql-picker-label::after,
.objectives-page .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label::after {
    content: none !important;
    display: none !important;
    border: none !important;
    width: 0 !important;
    height: 0 !important;
}

.sow-page-container .ql-toolbar.ql-snow button svg,
.sow-page-container .ql-toolbar.ql-snow .ql-picker-label svg,
.scope-of-work-page .ql-toolbar.ql-snow button svg,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker-label svg,
.objectives-page .ql-toolbar.ql-snow button svg,
.objectives-page .ql-toolbar.ql-snow .ql-picker-label svg {
    display: none !important;
}

.sow-page-container .ql-toolbar.ql-snow button::before,
.sow-page-container .ql-toolbar.ql-snow .ql-picker .ql-picker-label::before,
.scope-of-work-page .ql-toolbar.ql-snow button::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker .ql-picker-label::before,
.objectives-page .ql-toolbar.ql-snow button::before,
.objectives-page .ql-toolbar.ql-snow .ql-picker .ql-picker-label::before {
    font-family: 'Font Awesome 5 Free', 'Font Awesome 6 Free';
    font-weight: 900;
    font-size: 13px !important;
    color: #495057;
    display: inline-block;
    width: 100%;
    height: 100%;
    text-align: center;
    line-height: 26px !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    transition: color 0.15s ease;
}

.sow-page-container .ql-toolbar.ql-snow button.ql-bold::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-bold::before,
.objectives-page .ql-toolbar.ql-snow button.ql-bold::before { content: '\f032' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-italic::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-italic::before,
.objectives-page .ql-toolbar.ql-snow button.ql-italic::before { content: '\f033' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-underline::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-underline::before,
.objectives-page .ql-toolbar.ql-snow button.ql-underline::before { content: '\f0cd' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-strike::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-strike::before,
.objectives-page .ql-toolbar.ql-snow button.ql-strike::before { content: '\f0cc' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-blockquote::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-blockquote::before { content: '\f10d' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-list[value="ordered"]::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-list[value="ordered"]::before { content: '\f03b' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-list[value="bullet"]::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-list[value="bullet"]::before { content: '\f03a' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-image::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-image::before { content: '\f03e' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-clean::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-clean::before { content: '\f12d' !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-label::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-label::before { content: '\f1dc' !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-label::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-label::before { content: '\f031' !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-label::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-label::before { content: '\f034' !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-color .ql-picker-label::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-color .ql-picker-label::before { content: '\f53f' !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-align .ql-picker-label::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-align .ql-picker-label::before { content: '\f036' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-script[value="super"]::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-script[value="super"]::before { content: '\f12b' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-script[value="sub"]::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-script[value="sub"]::before { content: '\f12a' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-indent[value="+1"]::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-indent[value="+1"]::before { content: '\f03c' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-indent[value="-1"]::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-indent[value="-1"]::before { content: '\f03c' !important; transform: scaleX(-1); }
.sow-page-container .ql-toolbar.ql-snow button.ql-direction::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-direction::before { content: '\f038' !important; }
.sow-page-container .ql-toolbar.ql-snow button.ql-divider::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-divider::before { content: '\f068' !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-background .ql-picker-label::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-background .ql-picker-label::before { content: '\f576' !important; }

.sow-page-container .ql-toolbar.ql-snow button:hover::before,
.sow-page-container .ql-toolbar.ql-snow .ql-picker:hover .ql-picker-label::before,
.scope-of-work-page .ql-toolbar.ql-snow button:hover::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker:hover .ql-picker-label::before,
.objectives-page .ql-toolbar.ql-snow button:hover::before,
.objectives-page .ql-toolbar.ql-snow .ql-picker:hover .ql-picker-label::before {
    color: #007bff !important;
}

.sow-page-container .ql-toolbar.ql-snow button.ql-active,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-active,
.objectives-page .ql-toolbar.ql-snow button.ql-active {
    background-color: #cfe2ff;
}

.sow-page-container .ql-toolbar.ql-snow button.ql-active::before,
.scope-of-work-page .ql-toolbar.ql-snow button.ql-active::before,
.objectives-page .ql-toolbar.ql-snow button.ql-active::before {
    color: #0056b3 !important;
}

.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label::before,
.objectives-page .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label::before {
    color: #007bff !important;
}

.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-expanded,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-expanded,
.objectives-page .ql-toolbar.ql-snow .ql-picker.ql-expanded {
    background-color: #e9ecef;
}

.sow-page-container .ql-toolbar.ql-snow .ql-picker-options,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker-options,
.objectives-page .ql-toolbar.ql-snow .ql-picker-options {
    position: absolute;
    left: 100%;
    top: 0;
    min-width: 140px;
    padding: 8px;
    background-color: white;
    border: 1px solid #ccc;
    border-radius: 0 4px 4px 0;
    box-shadow: 2px 2px 8px rgba(0,0,0,0.15);
    z-index: 10001;
    display: none;
    pointer-events: auto !important;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options,
.objectives-page .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options {
    display: block !important;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker-item,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker-item,
.objectives-page .ql-toolbar.ql-snow .ql-picker-item {
    padding: 5px 10px;
    cursor: pointer;
    white-space: nowrap;
    line-height: 1.5;
    font-size: 14px;
    color: #343a40;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker-item:hover,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker-item:hover,
.objectives-page .ql-toolbar.ql-snow .ql-picker-item:hover {
    background-color: #f1f3f5;
    color: #000;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker-item.ql-selected,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker-item.ql-selected,
.objectives-page .ql-toolbar.ql-snow .ql-picker-item.ql-selected {
    background-color: #e7f1ff;
    font-weight: 500;
    color: #0056b3;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker-item::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker-item::before,
.objectives-page .ql-toolbar.ql-snow .ql-picker-item::before {
    font-size: inherit;
    font-weight: normal;
    color: inherit;
    line-height: inherit;
    display: inline-block;
}

/* Font picker dropdown – readable labels */
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="sans-serif"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="sans-serif"]::before { content: 'Sans Serif'; font-family: sans-serif !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="serif"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="serif"]::before { content: 'Serif'; font-family: serif !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="monospace"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="monospace"]::before { content: 'Monospace'; font-family: monospace !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="arial"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="arial"]::before { content: 'Arial'; font-family: Arial, sans-serif !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="georgia"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="georgia"]::before { content: 'Georgia'; font-family: Georgia, serif !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="courier-new"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="courier-new"]::before { content: 'Courier New'; font-family: 'Courier New', monospace !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="verdana"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="verdana"]::before { content: 'Verdana'; font-family: Verdana, sans-serif !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="impact"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item[data-value="impact"]::before { content: 'Impact'; font-family: Impact, sans-serif !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item:not([data-value])::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-font .ql-picker-options .ql-picker-item:not([data-value])::before { content: 'Default Font'; }

/* Size picker dropdown – readable labels */
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="12px"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="12px"]::before { content: '12px'; font-size: 12px !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="14px"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="14px"]::before { content: '14px'; font-size: 14px !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="16px"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="16px"]::before { content: '16px'; font-size: 16px !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="18px"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="18px"]::before { content: '18px'; font-size: 18px !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="20px"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="20px"]::before { content: '20px'; font-size: 20px !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="24px"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="24px"]::before { content: '24px'; font-size: 24px !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="28px"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item[data-value="28px"]::before { content: '28px'; font-size: 28px !important; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item:not([data-value])::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-size .ql-picker-options .ql-picker-item:not([data-value])::before { content: 'Normal'; font-size: 14px !important; }

/* Header picker dropdown – readable labels */
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item[data-value="1"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item[data-value="1"]::before { content: 'Heading 1'; font-size: 1.8em; font-weight: bold; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item[data-value="2"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item[data-value="2"]::before { content: 'Heading 2'; font-size: 1.5em; font-weight: bold; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item[data-value="3"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item[data-value="3"]::before { content: 'Heading 3'; font-size: 1.3em; font-weight: bold; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item[data-value="4"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item[data-value="4"]::before { content: 'Heading 4'; font-size: 1.1em; font-weight: bold; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item[data-value="5"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item[data-value="5"]::before { content: 'Heading 5'; font-size: 1em; font-weight: bold; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item[data-value="6"]::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item[data-value="6"]::before { content: 'Heading 6'; font-size: 0.9em; font-weight: bold; }
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item:not([data-value])::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-header .ql-picker-options .ql-picker-item:not([data-value])::before { content: 'Normal'; font-size: 14px; font-weight: normal; }

/* Align picker – compact icon row (reference) */
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-align .ql-picker-options,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-align .ql-picker-options {
    min-width: auto;
    width: auto;
    padding: 4px;
    margin-top: -34px;
    margin-left: 4px;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options {
    display: flex !important;
    flex-wrap: nowrap;
    gap: 4px;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item {
    padding: 0 !important;
    width: 30px !important;
    height: 30px !important;
    min-width: 30px !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    font-size: 0 !important;
    line-height: 1 !important;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 3px;
    transition: background-color 0.15s ease;
    cursor: pointer;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item:hover,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item:hover {
    background-color: #f0f0f0;
    border-color: #bbb;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item.ql-selected,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item.ql-selected {
    background-color: #cfe2ff;
    border-color: #aaccf0;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item::before,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item::before {
    content: none !important;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item svg,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item svg {
    width: 20px !important;
    height: 20px !important;
    display: block !important;
    fill: #555;
    stroke-width: 0;
    transition: fill 0.15s ease;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item:hover svg,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item:hover svg {
    fill: #333;
}
.sow-page-container .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item.ql-selected svg,
.scope-of-work-page .ql-toolbar.ql-snow .ql-picker.ql-align.ql-expanded .ql-picker-options .ql-picker-item.ql-selected svg {
    fill: #0056b3;
}

.sow-page-container table.sow-print-container tfoot td,
.scope-of-work-page table.sow-print-container tfoot td,
.objectives-page table.sow-print-container tfoot td,
.objectives-page table.obj-print-container tfoot td {
    padding: 0;
    border: none;
    border-top: none;
}

.sow-page-container table.sow-print-container tfoot footer,
.scope-of-work-page table.sow-print-container tfoot footer,
.objectives-page table.sow-print-container tfoot footer,
.objectives-page table.obj-print-container tfoot footer {
    display: block;
    width: calc(100% - 16px);
    box-sizing: border-box;
    text-align: center;
    background-color: var(--brand-primary, #2063BE);
    color: white;
    font-size: 11px;
    padding: 12px 15px;
    border-radius: 0 0 4px 4px;
    margin-top: auto;
    margin-left: 8px;
    margin-right: 8px;
    margin-bottom: 0;
    border-top: none;
}

.sow-page-container table.sow-print-container tfoot footer p,
.scope-of-work-page table.sow-print-container tfoot footer p,
.objectives-page table.sow-print-container tfoot footer p,
.objectives-page table.obj-print-container tfoot footer p {
    margin: 0;
    line-height: 1.5;
}

.sow-page-container table.sow-print-container tfoot footer a,
.scope-of-work-page table.sow-print-container tfoot footer a,
.objectives-page table.sow-print-container tfoot footer a,
.objectives-page table.obj-print-container tfoot footer a {
    color: white;
    text-decoration: underline;
}

.sow-page-container table.sow-print-container tfoot footer a:hover,
.scope-of-work-page table.sow-print-container tfoot footer a:hover,
.objectives-page table.sow-print-container tfoot footer a:hover,
.objectives-page table.obj-print-container tfoot footer a:hover {
    color: #eee;
}

/* SOW FAB container – positioning/animation in shared floating-buttons.css (centered like other pages) */
.sow-fab-container {
    position: fixed !important;
    right: 20px !important;
    z-index: 1000 !important;
}
.sow-fab-container .action-fab {
    position: fixed !important;
    right: 20px !important;
}

/* SOW Toast */
#sow-toast {
    position: fixed;
    top: 20px;
    right: 20px;
    padding: 12px 25px;
    background-color: rgba(76,175,80, 0.8);
    color: #fff;
    border-radius: 5px;
    display: none;
    z-index: 9999;
    font-size: 14px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.3);
}

/* Print styles for Scope of Work - allows content to flow across multiple pages */
@media print {
    /* Reset page container to allow natural page flow */
    #page-content > .sow-wrapper > .sow-page-container,
    #page-content > .sow-page-container,
    #page-content > .obj-wrapper > .obj-page-container,
    .sow-page-container,
    .scope-of-work-page,
    .objectives-page {
        width: 100% !important;
        max-width: 100% !important;
        height: auto !important;
        max-height: none !important;
        min-height: 0 !important;
        margin: 0 !important;
        padding: 10mm !important;
        box-shadow: none !important;
        border: none !important;
        background-color: white !important;
        overflow: visible !important;
        transform: none !important;
        page-break-inside: auto !important;
    }

    /* Allow table to break across pages */
    .sow-page-container table.sow-print-container,
    .scope-of-work-page table.sow-print-container,
    .objectives-page table.sow-print-container,
    .objectives-page table.obj-print-container {
        display: table !important;
        height: auto !important;
        overflow: visible !important;
        page-break-inside: auto !important;
    }

    .sow-page-container table.sow-print-container tbody,
    .scope-of-work-page table.sow-print-container tbody,
    .objectives-page table.sow-print-container tbody,
    .objectives-page table.obj-print-container tbody {
        display: table-row-group !important;
        overflow: visible !important;
        page-break-inside: auto !important;
    }

    .sow-page-container table.sow-print-container tbody tr,
    .scope-of-work-page table.sow-print-container tbody tr,
    .objectives-page table.sow-print-container tbody tr,
    .objectives-page table.obj-print-container tbody tr {
        display: table-row !important;
        page-break-inside: auto !important;
    }

    .sow-page-container table.sow-print-container tbody td,
    .scope-of-work-page table.sow-print-container tbody td,
    .objectives-page table.sow-print-container tbody td,
    .objectives-page table.obj-print-container tbody td {
        display: table-cell !important;
        overflow: visible !important;
        page-break-inside: auto !important;
    }

    /* Hide toolbar and FABs during print */
    .sow-page-container .ql-toolbar,
    .objectives-page .ql-toolbar,
    .sow-fab-container,
    .obj-fab-container,
    .sow-fab-container .action-fab,
    .obj-fab-container .action-fab,
    #sow-toast,
    #obj-toast {
        display: none !important;
    }

    /* Header styling for print */
    .sow-page-container .sow-header-block,
    .objectives-page .sow-header-block,
    .objectives-page .obj-header-block {
        padding: 10px 0 15px 0 !important;
        border-bottom: 2px solid #333 !important;
        page-break-after: avoid !important;
    }

    /* Editor container - allow overflow for multi-page */
    .sow-page-container #sow-editor-container,
    .scope-of-work-page #sow-editor-container,
    .objectives-page #obj-editor-container {
        border: none !important;
        background: transparent !important;
        box-shadow: none !important;
        height: auto !important;
        max-height: none !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        min-height: 0 !important;
        overflow: visible !important;
    }

    /* Quill container - allow content to flow */
    .sow-page-container .ql-container.ql-snow,
    .scope-of-work-page .ql-container.ql-snow,
    .objectives-page .ql-container.ql-snow {
        border: none !important;
        overflow: visible !important;
        padding: 0 !important;
        max-height: none !important;
        height: auto !important;
    }

    /* Intro section - allow multi-page */
    .sow-page-container .sow-intro,
    .scope-of-work-page .sow-intro,
    .objectives-page .sow-intro,
    .objectives-page .obj-intro {
        max-height: none !important;
        height: auto !important;
        min-height: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        width: 100% !important;
        overflow: visible !important;
    }

    /* Editor content - the key fix for multi-page */
    .sow-page-container .ql-editor,
    .scope-of-work-page .ql-editor,
    .objectives-page .ql-editor {
        height: auto !important;
        max-height: none !important;
        overflow: visible !important;
        padding: 15px 20px !important;
        font-size: 11pt !important;
        color: #000 !important;
        min-height: unset !important;
        page-break-inside: auto !important;
    }

    /* Ensure text is black for print */
    .sow-page-container .ql-editor *,
    .objectives-page .ql-editor * {
        color: #000 !important;
        background: transparent !important;
    }

    /* Footer styling - try to keep on same page as some content */
    .sow-page-container table.sow-print-container tfoot,
    .objectives-page table.sow-print-container tfoot,
    .objectives-page table.obj-print-container tfoot {
        display: table-footer-group !important;
    }

    .sow-page-container table.sow-print-container tfoot footer,
    .objectives-page table.sow-print-container tfoot footer,
    .objectives-page table.obj-print-container tfoot footer {
        -webkit-print-color-adjust: exact !important;
        print-color-adjust: exact !important;
        color-adjust: exact !important;
        border-radius: 0 !important;
        margin: 10px 0 0 0 !important;
        width: 100% !important;
    }

    /* Preserve colors for header elements */
    .sow-page-container .sow-header-block,
    .objectives-page .sow-header-block,
    .sow-page-container .sow-logo,
    .objectives-page .sow-logo,
    .sow-page-container .sow-customer-name,
    .objectives-page .sow-customer-name {
        -webkit-print-color-adjust: exact !important;
        print-color-adjust: exact !important;
        color-adjust: exact !important;
    }

    /* Page break hints - avoid breaking in middle of paragraphs */
    .sow-page-container .ql-editor p,
    .sow-page-container .ql-editor li,
    .objectives-page .ql-editor p,
    .objectives-page .ql-editor li {
        page-break-inside: avoid !important;
        orphans: 3;
        widows: 3;
    }

    /* Keep headings with following content */
    .sow-page-container .ql-editor h1,
    .sow-page-container .ql-editor h2,
    .sow-page-container .ql-editor h3,
    .sow-page-container .ql-editor h4,
    .sow-page-container .ql-editor h5,
    .sow-page-container .ql-editor h6,
    .objectives-page .ql-editor h1,
    .objectives-page .ql-editor h2,
    .objectives-page .ql-editor h3,
    .objectives-page .ql-editor h4,
    .objectives-page .ql-editor h5,
    .objectives-page .ql-editor h6 {
        page-break-after: avoid !important;
    }
}

/* SOW Project Manager Modal - reuses project-manager layout patterns */
#sowProjectModal .modal-xl-custom {
    max-width: 950px;
    min-width: 800px;
}
#sowProjectModal .explorer-content {
    display: flex;
    width: 100%;
    gap: 25px;
    flex-grow: 1;
}
#sowProjectModal .explorer-section {
    flex: 1;
    display: flex;
    flex-direction: column;
}
#sowProjectModal .section-header {
    font-size: 1.15rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 12px;
    border-bottom: 1px solid #eee;
    padding-bottom: 8px;
}
#sowProjectModal .explorer-list {
    min-width: 200px;
    flex-basis: 250px;
    max-height: 500px;
    min-height: 350px;
    overflow-y: auto;
    border: 1px solid #ddd;
    padding: 10px;
    border-radius: 5px;
    background-color: #fff;
    flex-grow: 1;
}
#sowProjectModal .search-sort-container {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 15px;
}
#sowProjectModal .search-input {
    flex-grow: 1;
    padding: 9px 12px;
    font-size: 14px;
    border-radius: 5px;
    min-width: 150px;
}
#sowProjectModal .breadcrumbs {
    margin-bottom: 15px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    font-size: 14px;
    color: #6c757d;
    padding: 5px;
    background-color: #f8f9fa;
    border-radius: 4px;
}
#sowProjectModal .breadcrumb-item {
    cursor: pointer;
    color: #007bff;
    padding: 3px 5px;
    border-radius: 3px;
}
#sowProjectModal .breadcrumb-item:hover {
    background-color: #e2e6ea;
    color: #0056b3;
}
#sowProjectModal .breadcrumb-separator {
    margin: 0 5px;
    color: #6c757d;
}
#sowProjectModal .project-list-item {
    padding: 9px 12px;
    margin: 6px 0;
    background: #fff;
    border: 1px solid #e9ecef;
    border-radius: 6px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
#sowProjectModal .project-list-item:hover {
    background: #f8f9fa;
    border-color: #dee2e6;
}
#sowProjectModal .file-icon {
    margin-right: 12px;
    font-size: 1.5rem;
    color: #6c757d;
}
#sowProjectModal .file-name {
    flex-grow: 1;
    cursor: pointer;
    color: #333;
    font-size: 14px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
#sowProjectModal .file-name:hover {
    color: #007bff;
}
#sowProjectModal .project-list-item .actions {
    display: flex;
    align-items: center;
    position: relative;
    flex-shrink: 0;
}
#sowProjectModal .ellipsis-btn {
    background: transparent;
    border: none;
    padding: 4px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 12px;
    color: #6c757d;
}
#sowProjectModal .ellipsis-btn:hover {
    background: #e9ecef;
    color: #333;
}
#sowProjectModal .item-options-menu {
    display: none;
    position: absolute;
    right: 100%;
    margin-right: 6px;
    top: 50%;
    transform: translateY(-50%);
    background: #fff;
    border-radius: 5px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    padding: 6px;
    z-index: 20;
    flex-direction: row;
    gap: 6px;
    border: 1px solid #ddd;
}
#sowProjectModal .ellipsis-btn.active + .item-options-menu,
#sowProjectModal .item-options-menu.active {
    display: flex;
}
#sowProjectModal .menu-btn {
    padding: 4px 8px;
    font-size: 11px;
    border-radius: 4px;
    border: 1px solid #ccc;
    background: #fff;
    cursor: pointer;
}
#sowProjectModal .menu-btn.delete-btn {
    color: #dc3545;
}
#sowProjectModal .menu-btn.delete-btn:hover {
    background: #dc3545;
    color: #fff;
    border-color: #c82333;
}
#sowProjectModal .create-folder-btn {
    background-color: #007bff;
    color: white;
}
#sowProjectModal .create-folder-btn:hover {
    background-color: #0056b3;
}
#sowProjectModal .save-btn {
    background-color: #28a745;
    color: white;
}
#sowProjectModal .save-btn:hover {
    background-color: #218838;
}
#sowProjectModal .refresh-btn {
    position: absolute;
    top: 1rem;
    right: 1rem;
    padding: 6px 10px;
    font-size: 12px;
}
