/* ==========================================================================
   Majix style_v5
   Sections: 1 Tokens · 2 Structure · 3 Grids · 4 Form controls · 5 Modals
   · 6 Feedback · 7 Chrome · 8 Pages · 9 Responsive
   ========================================================================== */

/* ==========================================================================
   1. DESIGN TOKENS
   ========================================================================== */
:root {
    --light-blue: #95bfff;
    --mid-blue: #4173c1;
    --dark-blue: #2B2D42;
    --light-purple: #c4bbfc;
    --mid-purple: #6e62b6;
    --dark-grey: #333;
    --dark-red: #4d0303;
    --background-grey: #F8F7F9;
    --surface-white: #fff;
    --text-strong: #000;
    --text-muted: #666;
    --light-grey: #f0f0f0;
    --hover-grey: #f5f5f5;
    --input-highlight-bg: #fdfdfd;
    --shadow: rgba(0, 0, 0, 0.1);
    --border: #ccc;
    --overlay-backdrop: rgba(0, 0, 0, 0.45);
    --divider: rgba(0, 0, 0, 0.15);
    --error-border-light: #f5c6cb;
    --error-bg: #fff0f0;
    --success-text: #155724;
    --success-border: #c3e6cb;
    --success-bg: #d4edda;
    --brand-magenta: #a55eea;
    --brand-violet: #706fd3;
    --brand-cyan: #00a8ff;
    --brand-focus-ring: rgba(0, 168, 255, 0.35);
    --avatar-shadow: rgba(112, 111, 211, 0.4);
    --font-family-base: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --font-size-body: 12px;
    --font-size-ui: 12px;
    --font-size-title: 14px;
    --font-size-meta: 12px;
    --font-size-modal-close: 20px;
    --line-height-base: 1.5;
    --control-height: 22px;
    --control-padding-inline: 4px;
    --select-padding-end: 1.5em;
    --min-width-currency-control: 10ch; /* e.g. 0,000.00 */
    --min-width-teeth-column: calc(5ch + 6px + 5.5ch + 12px); /* Teeth + Copy */
    /* treatments.Code (5), Treatment (30), Classification (20) */
    --width-treatment-code: 8ch;
    --width-treatment-label: 18ch;
    --width-treatment-classification: 14ch;
}

/* ==========================================================================
   2. STRUCTURE — document, shells, sections, dual panels
   ========================================================================== */
html {
    min-width: 540px;
}

body {
    background-color: var(--background-grey);
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    min-height: 80vh;
    margin: 0;
    font-family: var(--font-family-base);
    font-size: var(--font-size-body);
    line-height: var(--line-height-base);
    color: var(--dark-grey);
    padding-top: 70px;
}

body.login {
    align-items: center;
    justify-content: center;
}

.container, .login-container {
    background-color: var(--surface-white);
    border-radius: 8px;
    box-shadow: 0 2px 5px var(--shadow);
    padding: 20px;
    width: 90%;
    max-width: 100%;
    box-sizing: border-box;
    margin: 20px auto;
}

/* Form wraps container: 90% of viewport; inner card fills the form (avoid 90% of shrink-wrapped form). */
body > form {
    width: 90%;
    max-width: 100%;
    box-sizing: border-box;
}

body > form > .container {
    width: 100%;
    box-sizing: border-box;
}

/* Container wraps form: card is full width of the white box (matches index visual weight). */
.container > form {
    display: block;
    width: 100%;
    box-sizing: border-box;
}

.has-minimum {
    min-width: 540px;
}

/* ==========================================================================
   PAGE — login
   ========================================================================== */
.login-container {
    width: 300px;
    padding: 30px;
}

.login-container h2 {
    text-align: center;
    margin-bottom: 20px;
    color: var(--dark-grey);
}

.login-container .logo {
    width: 250px;
    margin: 0 auto 20px;
}

.login-container .logo img {
    max-width: 100%;
    height: auto;
}

.loginForm div {
    margin-bottom: 15px;
}

.loginForm label {
    display: block;
    margin-bottom: 5px;
    color: var(--dark-grey);
}

.loginForm input, .loginForm button {
    width: 100%;
    padding: 10px;
    border: 1px solid var(--border);
    border-radius: 4px;
    box-sizing: border-box;
}

.loginForm button {
    background-color: var(--mid-purple);
    color: var(--background-grey);
    border: none;
    cursor: pointer;
}

.loginForm button:hover {
    background-color: var(--dark-blue);
    color: var(--background-grey);
}

#procedure-container, .section-header, .section-content, .dual-content {
    border: 1px solid var(--border);
    padding: 10px;
    margin: 5px;
}

.narrow {
    padding: 2px 10px;
}

.dual-wrapper {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 4px;
    margin: 5px;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
}

.dual-container {
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    min-width: 0;
    max-width: 100%;
    width: 100%;
}

/* Dual headers Styles */
.dual-container .section-header {
    flex: 0 0 auto;
    margin: 0;
    padding: 10px;
    min-width: 0;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
    overflow: hidden;
}

.dual-container .dual-content {
    flex: 1 1 auto;
    margin: 0;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
}

/* ==========================================================================
   3. STRUCTURE — data grids (procedure, consult-tx, treatment-costs)
   ========================================================================== */

.seven-field {
    display: grid;
    grid-template-columns: repeat(7, minmax(var(--min-width-currency-control), 1fr));
    margin-top: 5px;
    gap: 2px;
}

.eight-field {
    display: grid;
    grid-template-columns:
        minmax(var(--min-width-currency-control), 1fr)
        minmax(var(--min-width-teeth-column), max-content)
        repeat(6, minmax(var(--min-width-currency-control), 1fr));
    margin-top: 5px;
    gap: 2px;
    min-width: 0;
    max-width: 100%;
}

/* ==========================================================================
   PAGE — consult-tx (eight-field grids, teeth column, waiting highlight)
   ========================================================================== */

/* Keep dual panels inside the same horizontal bounds as Patient Details sections */
.consult-tx-page #patientForm {
    min-width: 0;
    max-width: 100%;
}

.consult-tx-page .dual-wrapper {
    margin: 5px;
    min-width: 0;
    max-width: 100%;
}

.consult-tx-page .dual-container {
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
}

.consult-tx-page .dual-content.eight-field,
.consult-tx-page .dual-content.three-field {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
}

.dual-content.eight-field {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.dual-content.three-field {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
}

.eight-field .grid-header {
    align-self: stretch;
    width: 100%;
    box-sizing: border-box;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

/* Teeth column (2nd): header label + Copy stay on one row */
.eight-field > .grid-item:nth-child(8n + 2) {
    min-width: var(--min-width-teeth-column);
}

.eight-field > .grid-item:nth-child(8n + 2).grid-header {
    overflow: visible;
    white-space: nowrap;
    text-overflow: clip;
}

.eight-field .grid-header .teeth-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
    width: 100%;
    min-width: max-content;
    flex-wrap: nowrap;
}

.eight-field .grid-header .teeth-header > span {
    flex-shrink: 0;
}

/* consult-tx: align controls to the same row height (incl. disabled Covered % select) */
.eight-field .grid-item:not(.grid-header) {
    min-width: 0;
    align-items: stretch;
}

.eight-field .grid-item:not(.grid-header) > input,
.eight-field .grid-item:not(.grid-header) > select,
.eight-field .grid-item:not(.grid-header) > .assign-teeth-btn {
    flex: 1 1 auto;
    align-self: stretch;
    width: 100%;
    min-width: var(--min-width-currency-control);
    min-height: var(--control-height);
}

/* Highlight when create-quote Waiting Applies is checked */
.eight-field input.contx-field-waiting-applies,
.eight-field select.contx-field-waiting-applies {
    border: 2px dashed var(--light-purple) !important;
    box-sizing: border-box;
}

.three-field {
    display: grid;
    grid-template-columns: repeat(3, minmax(var(--min-width-currency-control), 1fr));
    margin-top: 5px;
    gap: 2px;
}

/* Target every second .section-header within .dual-container */
.dual-container:nth-child(even) .section-header {
    background-color: var(--light-purple);
}

/* Target every odd .section-header within .dual-container */
.dual-container:nth-child(odd) .section-header {
    background-color: var(--light-blue);
}

.span-2 {
    grid-column: span 2;
}

.section-header {
    background-color: var(--light-blue);
}

.section-header:nth-child(4n+1) {
    background-color: var(--light-purple);
}

.section-title {
    font-weight: bold;
    font-size: var(--font-size-title);
    margin-bottom: 0;
}

.section-content, .section-inline {
    display: flex; /* Use flexbox for content */
    flex-wrap: wrap; /* Allow wrapping */
    align-items: flex-start; /* Align items to the top */
}

/* Page footers (Back / Finish etc.): intrinsic button width when grids scroll on narrow viewports */
.section-content.section-inline:not(:has(.inline-field)) {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
}

.section-content.section-inline:not(:has(.inline-field)) .nav-button,
.section-content.section-inline:not(:has(.inline-field)) .submit-button {
    width: auto;
    max-width: none;
    flex: 0 0 auto;
}

.label, .full-width label {
    font-weight: bold;
    display: inline-block;
    width: 60%;
    margin-right: 5px;
}

.required-asterisk {
    color: var(--dark-red);
    font-size: 0.9em;
    font-weight: 700;
    vertical-align: super;
    margin-left: 2px;
    line-height: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.required-asterisk__star {
    font-size: 1.25em;
    line-height: 1;
    display: inline-block;
    width: 1ch;
    text-align: center;
}

.largeLabel {
    font-weight: bold;
    display: inline-block;
    width: 100%;
    margin-right: 5px;
}

.inline-field {
    display: flex;
    align-items: stretch;
    flex: 1 0 33.33%;
    padding: 5px;
    box-sizing: border-box;
}

/* create-quote: 40% label, 60% control (beat #patientForm select { padding: 3px }) */
#patientForm .inline-field > .label {
    flex: 0 0 40%;
    width: 40%;
    max-width: 40%;
    margin-right: 5px;
    align-self: center;
    box-sizing: border-box;
}

#patientForm .inline-field > input:not([type="hidden"]),
#patientForm .inline-field > select,
#patientForm .inline-field > .assign-teeth-btn {
    flex: 1 1 60%;
    min-width: var(--min-width-currency-control);
    min-height: var(--control-height);
    height: var(--control-height);
    margin: 0;
    box-sizing: border-box;
}

.inline-field.inline-spacer {
    visibility: hidden; /* occupy grid slot but don't show */
    pointer-events: none;
}

.single-field {
    display: block;
    max-width: 20%;
    min-width: 20%;
    padding: 5px;
    box-sizing: border-box;
}

/* ==========================================================================
   4. FUNCTION — form controls (typography, compact inputs, selects, buttons)
   ========================================================================== */

/* UI font on controls (buttons do not inherit reliably on all platforms) */
.container input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]),
.container select,
.container textarea,
.container button,
.container a.nav-button {
    font-family: var(--font-family-base);
    font-size: var(--font-size-ui);
    line-height: 1.35;
}

.container button.modal-close {
    font-size: var(--font-size-modal-close);
    line-height: 1;
}

/* Compact <select> — centred label text at fixed control height */
.container select,
#patientForm select,
#searchForm select,
#userForm select,
.eight-field select,
.seven-field select,
.three-field select,
.treatment-grid select {
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    font-size: var(--font-size-ui);
    min-width: var(--min-width-currency-control);
    height: var(--control-height);
    min-height: var(--control-height);
    padding: 0 var(--select-padding-end) 0 var(--control-padding-inline);
    line-height: var(--control-height);
}

/* Compact text <input> in data grids */
.eight-field input,
.seven-field input,
.three-field input,
.treatment-grid input {
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    padding: 2px var(--control-padding-inline);
    font-size: var(--font-size-ui);
    line-height: 1.35;
    min-width: var(--min-width-currency-control);
    min-height: var(--control-height);
    height: var(--control-height);
}

#patientForm select,
#searchForm select,
#userForm select,
form input {
    width: 100%;
    box-sizing: border-box;
}

form input {
    padding: 2px;
}

.container input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]),
.container select,
.container textarea,
.container button.assign-teeth-btn.nav-button:not(.treatment-waiting-applies-btn),
.eight-field input,
.eight-field select,
.seven-field input,
.seven-field select,
.three-field input,
.three-field select {
    min-width: var(--min-width-currency-control);
}

/* ==========================================================================
   PAGE — create-quote (procedure grid, inline fields, notes)
   ========================================================================== */

/* Section title + column headers may use long copy */
.procedure-information > .section-header .section-title {
    white-space: normal;
    overflow-wrap: break-word;
    word-wrap: break-word;
}

.procedure-information .procedure-container > .grid-item.grid-header {
    white-space: normal;
    overflow-wrap: break-word;
    word-wrap: break-word;
    hyphens: auto;
}

.procedure-container {
    display: grid;
    grid-template-columns: var(--width-treatment-code) repeat(7, minmax(var(--min-width-currency-control), 1fr));
    gap: 4px;
}

/* create-quote: optional "Waiting Applies" column (after procedure code) */
.procedure-container.has-waiting-applies-col {
    grid-template-columns: var(--width-treatment-code) repeat(7, minmax(var(--min-width-currency-control), 1fr)) max-content;
}

.procedure-container > .grid-item:nth-child(8n + 1) input,
.procedure-container.has-waiting-applies-col > .grid-item:nth-child(9n + 1) input {
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
}

.procedure-information .procedure-container .waiting-applies-grid-col {
    display: flex;
    align-items: center;
    justify-content: center;
}

.procedure-information .procedure-container input.quote-waiting-applies-ind {
    width: auto;
    margin: 0;
}

#patientForm input#RenewalDate[readonly] {
    background-color: var(--light-grey);
    cursor: not-allowed;
}

.grid-item {
    padding: 3px;
    font-size: var(--font-size-ui);
    display: flex;
    align-items: center;
}

.copy-teeth-header-btn {
    padding: 2px 6px;
    font-size: var(--font-size-ui);
    line-height: 1.35;
    width: auto;
    min-width: max-content;
    flex-shrink: 0;
    white-space: nowrap;
    background-color: var(--background-grey);
    color: var(--dark-grey);
    border: 1px solid var(--dark-grey);
    border-radius: 4px;
    cursor: pointer;
}

.copy-teeth-header-btn:hover {
    background-color: var(--dark-blue);
    color: var(--background-grey);
}

/* Assign teeth (create-quote, consult-tx) — match compact control footprint */
button.assign-teeth-btn.nav-button:not(.treatment-waiting-applies-btn) {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    margin-top: 0;
    margin-right: 0;
    padding: 2px 15px;
    min-width: var(--min-width-currency-control);
    min-height: var(--control-height);
    height: var(--control-height);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-color: var(--background-grey);
    color: var(--dark-grey);
    border: 1px solid var(--dark-grey);
    border-radius: 4px;
    cursor: pointer;
    text-decoration: none;
    white-space: pre-line;
    overflow-wrap: anywhere;
}

button.assign-teeth-btn.nav-button:not(.treatment-waiting-applies-btn):not(.has-teeth) {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

button.assign-teeth-btn.nav-button:not(.treatment-waiting-applies-btn).has-teeth {
    height: auto;
    min-height: var(--control-height);
    max-height: none;
    font-weight: 600;
    align-items: center;
}

.eight-field .grid-item:not(.grid-header) > .assign-teeth-btn:not(.has-teeth) {
    height: var(--control-height);
    max-height: var(--control-height);
}

button.assign-teeth-btn.nav-button:not(.treatment-waiting-applies-btn):hover {
    background-color: var(--dark-blue);
    color: var(--background-grey);
}

/* create-quote: hidden multi-select still posts */
#patientForm .inline-field:has(> .assign-teeth-btn) {
    flex-wrap: nowrap;
}

#patientForm #ToothNo,
#patientForm #HistoryTeethNo {
    display: none;
}

/* Assign buttons get .error on failed submit; .container .error is for message blocks */
.container button.assign-teeth-btn.error {
    margin: 0;
    padding: 2px 15px;
    text-align: center;
    border: 2px solid var(--dark-red);
    border-radius: 4px;
    color: var(--dark-grey);
}

.full-width {
    /* Current setup - remove top two lines for simpler display */
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    flex: 1 0 95%; /* Takes full width of the section */
    padding: 5px;
}

.full-width label {
    grid-column: 1 / 2; /* Value spans 1 columns */
}

.full-width input {
    grid-column: 2 / 8; /* Value spans 5 columns */
}

/* Primary actions (Back, Finish, etc.) */
a.nav-button,
button.nav-button:not(.assign-teeth-btn) {
    margin-top: 0;
    padding: 8px 25px;
    background-color: var(--background-grey);
    color: var(--mid-purple);
    border: 1px solid var(--dark-grey);
    border-radius: 4px;
    cursor: pointer;
    margin-right: 5px;
    text-decoration: none;
}

.submit-button {
    margin-top: 0;
    padding: 10px 20px;
    background-color: var(--mid-purple);
    color: var(--background-grey);
    border: none;
    border-radius: 4px;
    cursor: pointer;
}

.submit-button:hover,
a.nav-button:hover,
button.nav-button:not(.assign-teeth-btn):hover {
    background-color: var(--dark-blue);
    color: var(--background-grey);
}

/* ==========================================================================
   5. FUNCTION — modals (assign teeth, procedure notes)
   ========================================================================== */
.modal-backdrop {
    position: fixed;
    inset: 0;
    background: var(--overlay-backdrop);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 9999;
}

.modal-backdrop .modal {
    background: var(--background-grey);
    color: var(--dark-grey);
    max-height: 80vh;
    overflow: auto;
    border-radius: 10px;
    padding: 20px;
    box-sizing: border-box;
}

.modal-backdrop .modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}

.modal-backdrop .modal-title {
    font-weight: 700;
    font-size: var(--font-size-title);
}

.modal-backdrop .modal-close {
    background: transparent;
    border: 0;
    font-size: var(--font-size-modal-close);
    cursor: pointer;
    line-height: 1;
}

.modal-backdrop .modal-body {
    margin-top: 12px;
}

.modal-backdrop .modal-actions {
    margin-top: 20px;
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

.modal-backdrop .modal-actions .nav-button,
.modal-backdrop .modal-actions .submit-button {
    margin-top: 0;
}

#assignTeethModalBackdrop .modal {
    width: fit-content;
    max-width: 92vw;
}

#assignTeethModalBackdrop .modal-body {
    display: grid;
    grid-template-columns: repeat(3, max-content);
    gap: 8px 16px;
    justify-content: start;
}

#assignTeethModalBackdrop .tooth-col {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    width: 80px;
}

#assignTeethModalBackdrop .tooth-col-title {
    font-weight: 700;
    padding-bottom: 4px;
    border-bottom: 1px solid var(--divider);
    width: 100%;
    text-align: left;
}

/* checkbox left aligned, 10px right margin to label */
#assignTeethModalBackdrop .tooth-option {
    display: flex;
    align-items: center;
    white-space: nowrap;
    justify-content: flex-start;
}

#assignTeethModalBackdrop .tooth-option input {
    flex: 0 0 20px;
    margin-right: 10px;
    margin: 0px 10px 0px 0px;
    padding: 0px;
    text-align: left;
}

@media (prefers-color-scheme: dark) {
    #assignTeethModalBackdrop .tooth-col-title {
        border-bottom-color: rgba(255, 255, 255, 0.15);
    }
}

#procedureNotesModalBackdrop .modal {
    width: min(36rem, 92vw);
}

#procedureNotesModalBackdrop #procedureNotesModalText {
    width: 100%;
    min-height: 10rem;
    padding: 10px;
    box-sizing: border-box;
    border: 1px solid var(--border);
    border-radius: 4px;
    font: inherit;
    font-size: var(--font-size-ui);
    line-height: 1.45;
    resize: vertical;
}

.procedure-notes-value {
    display: none;
}

.procedure-notes-input {
    cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ==========================================================================
   6. FUNCTION — validation & error / success messages
   ========================================================================== */
.error {
    border-color: var(--dark-red);
}

.loginForm #errorMessage {
    margin-top: 10px;
}

.login .error:not(input):not(select):not(textarea):not(button),
.container .error:not(input):not(select):not(textarea):not(button) {
    color: var(--dark-red);
    margin: 5px;
    padding: 10px;
    text-align: left;
    border: 1px solid var(--error-border-light);
    border-radius: 4px;
}

.login .error:not(input):not(select):not(textarea):not(button) {
    margin: 0px;
}

#patientForm input.error,
#patientForm select.error,
#patientForm textarea.error,
.login input.error,
.login select.error,
.login textarea.error,
.container input.error,
.container select.error,
.container textarea.error {
    color: var(--dark-red);
    margin: 0;
    text-align: left;
    border: 2px solid var(--dark-red);
    border-radius: 4px;
}

.loginForm input.error {
    padding: 10px;
    border-width: 1px;
}

.container .success {
    color: var(--success-text);
    margin-bottom: 0px;
    padding: 10px;
    text-align: left;
    border: 1px solid var(--success-border);
    border-radius: 4px;
    background-color: var(--success-bg);
}

/* Stack flash + intro above the grid (parent .section-content is flex row) */
.treatment-costs-messages {
    width: 100%;
    flex-basis: 100%;
}
.treatment-costs-messages .error,
.treatment-costs-messages .success {
    display: block;
    width: auto;
    box-sizing: border-box;
    margin-bottom: 10px;
}
.treatment-costs-messages > p {
    margin-top: 0;
}

/* ==========================================================================
   PAGE — manage-users
   ========================================================================== */
.manage-users-page .section-content.dashboard-panel-content {
    margin: 5px;
    padding: 0;
    border: none;
}

.manage-users-page .manage-users-actions {
    margin-bottom: 0;
}

.manage-users-page .manage-users-by-type {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin: 5px;
    min-width: 0;
}

.manage-users-page .manage-users-type-column {
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.manage-users-page .manage-users-type-column > .section-header {
    margin: 0;
}

.manage-users-page .manage-users-type-column > .section-content {
    flex: 1 1 auto;
    min-width: 0;
}

.manage-users-page .dashboard-empty {
    padding: 10px 4px;
    margin: 0;
}


/* Stacked user details; label column width = widest label (Last login:) */
.manage-users-page .manage-users-activity-meta {
    display: grid;
    grid-template-columns: max-content 1fr;
    column-gap: 0.35rem;
    row-gap: 0.15rem;
    align-items: baseline;
    width: 100%;
    max-width: 100%;
}

.manage-users-page .manage-users-meta-label,
.dashboard-activity-meta-label {
    font-weight: bold;
    color: var(--text-muted);
}

.manage-users-page .manage-users-meta-label {
    white-space: nowrap;
}

.manage-users-page .manage-users-meta-value {
    min-width: 0;
    overflow-wrap: anywhere;
}

#displayErrorsBox .error,
#displayErrorsBox .success {
    white-space: pre-wrap;
}

/* ==========================================================================
   7. STRUCTURE — site chrome (banner, navigation)
   ========================================================================== */
.banner {
    background-color: var(--surface-white);
    padding: 1rem 0;
    box-shadow: 0 2px 4px var(--shadow);
    width: 100%;
    min-width: 540px;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
}

.banner-content {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    max-width: 90%;
    margin: 0 auto;
    padding: 0 10px;
    overflow: visible;
}

.logo-container {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.main-nav {
    overflow: visible;
    flex-shrink: 0;
}

.logo-container .logo img {
    height: 50px;
    margin-right: 10px;
}

/* Navigation Menu Styles */
.main-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.main-nav > ul {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
}

.main-nav > ul > li {
    display: block;
    flex: 0 0 auto;
    font-size: var(--font-size-title);
    text-align: center;
}

/* Word nav items (Home, Contact, Admin) share one width; set in Script/user-menu.js */
.main-nav > ul > li.nav-word-item {
    width: var(--nav-word-item-width, 90px);
    min-width: var(--nav-word-item-width, 90px);
    box-sizing: border-box;
}

.main-nav > ul > li > a,
.main-nav > ul > li.nav-word-item > .nav-menu-trigger {
    color: var(--dark-grey);
    text-decoration: none;
    padding: 10px 15px;
    display: block;
    width: 100%;
    box-sizing: border-box;
    font-family: var(--font-family-base);
    font-size: var(--font-size-title);
    line-height: var(--line-height-base);
    transition: background-color 0.3s, color 0.3s;
    border-radius: 4px;
}

.main-nav > ul > li > a:hover,
.main-nav > ul > li.nav-word-item > .nav-menu-trigger:hover,
.main-nav > ul > li.nav-word-item.nav-menu.is-open > .nav-menu-trigger {
    color: var(--background-grey);
    background-color: var(--dark-blue);
}

/* Nav menus (Admin, Profile) — click to open; close on mouse leave */
.main-nav .nav-menu {
    position: relative;
}

.main-nav > ul > li.nav-word-item > .nav-menu-trigger {
    width: 100%;
}

.nav-menu-trigger {
    margin: 0;
    border: none;
    background: transparent;
    text-align: center;
    cursor: pointer;
    box-sizing: border-box;
}

.nav-menu-dropdown {
    display: block;
    position: absolute;
    top: calc(100% + 6px);
    left: auto;
    right: 0;
    margin: 0;
    padding: 4px var(--nav-menu-inset, 5px);
    list-style: none;
    background-color: var(--surface-white);
    border-radius: 4px;
    box-shadow: 0 4px 12px var(--shadow);
    z-index: 1100;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
    box-sizing: border-box;
    /* width set in Script/user-menu.js: widest label + 20px + horizontal insets */
}

.nav-menu.is-open .nav-menu-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
}

.main-nav .nav-menu-dropdown li {
    display: block;
    min-width: 0;
    width: 100%;
    text-align: left;
}

.main-nav .nav-menu-dropdown li a {
    display: block;
    width: 100%;
    padding: 8px 0;
    border-radius: 4px;
    white-space: nowrap;
    box-sizing: border-box;
    text-align: center;
    color: var(--dark-grey);
    background-color: transparent;
    text-decoration: none;
    transition: background-color 0.2s, color 0.2s;
}

.main-nav .nav-menu-dropdown li a:hover,
.main-nav .nav-menu-dropdown li a:focus,
.main-nav .nav-menu-dropdown li a:visited {
    text-decoration: none;
}

.main-nav .nav-menu-dropdown li a:hover {
    color: var(--background-grey);
    background-color: var(--dark-blue);
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.user-menu > .nav-menu-trigger.user-menu-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: auto;
    padding: 4px;
    border: 2px solid transparent;
    border-radius: 50%;
    background: transparent;
}

.user-menu > .nav-menu-trigger.user-menu-trigger:hover,
.user-menu.is-open > .nav-menu-trigger.user-menu-trigger {
    color: inherit;
    background: transparent;
    border-color: var(--brand-violet);
    box-shadow: 0 0 0 2px var(--brand-focus-ring);
}

.user-menu > .nav-menu-trigger.user-menu-trigger:focus-visible {
    outline: none;
    border-color: var(--brand-violet);
    box-shadow: 0 0 0 2px var(--brand-focus-ring);
}

.user-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--brand-magenta) 0%, var(--brand-violet) 48%, var(--brand-cyan) 100%);
    color: var(--surface-white);
    box-shadow: 0 1px 4px var(--avatar-shadow);
}

.user-avatar-icon {
    width: 22px;
    height: 22px;
    fill: currentColor;
}

/* ==========================================================================
   PAGE — treatment-costs
   ========================================================================== */
.treatment-costs-page > form {
    display: block;
    width: 100%;
    box-sizing: border-box;
}

.treatment-costs-page .grid-scroll-wrapper {
    max-width: 100%;
}

/* Keep readable column width; horizontal scroll when viewport is narrower */
.treatment-costs-page .treatment-grid {
    min-width: 56rem;
}

.treatment-costs-page .treatment-grid .grid-col-code,
.treatment-costs-page .treatment-grid .grid-col-treatment,
.treatment-costs-page .treatment-grid .grid-col-classification {
    min-width: 0;
}

.treatment-costs-page .treatment-grid .grid-col-code input,
.treatment-costs-page .treatment-grid .grid-col-treatment input,
.treatment-costs-page .treatment-grid .grid-col-classification input {
    min-width: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

/* ==========================================================================
   PAGE — profile
   ========================================================================== */
.profile-page .profile-columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin: 5px;
    align-items: start;
    min-width: 0;
}

.profile-page .profile-column {
    min-width: 0;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
}

/* Header + content share full column width (no extra 5px inset on content only) */
.profile-page .profile-column > .section-header,
.profile-page .profile-column > .section-content {
    margin: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.profile-page .profile-column > .section-header {
    flex: 0 0 auto;
    padding: 10px;
    overflow: hidden;
}

.profile-page .profile-column > .section-content {
    flex: 1 1 auto;
    min-width: 0;
}

/* Same alternating header colours as consult-tx dual panels */
.profile-page .profile-column:nth-child(odd) > .section-header {
    background-color: var(--light-blue);
}

.profile-page .profile-column:nth-child(even) > .section-header {
    background-color: var(--light-purple);
}

.profile-page .profile-details,
.profile-page .profile-security {
    justify-content: flex-start;
    align-items: flex-start;
    flex-direction: column;
    text-align: left;
}

.profile-security-head {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    width: 100%;
    max-width: 100%;
}

.profile-enable-2fa-form {
    margin: 0;
}

.profile-page .profile-fields {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
    width: 100%;
    max-width: 100%;
}

.profile-page .profile-field {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    width: 100%;
}

.profile-page .profile-field .label {
    width: auto;
    margin: 0;
}

.profile-page .profile-field input[readonly] {
    width: 100%;
    box-sizing: border-box;
    padding: 6px 8px;
    border: 1px solid var(--border);
    border-radius: 4px;
    background-color: var(--background-grey);
    color: var(--dark-grey);
    cursor: default;
}

.profile-security-note {
    margin: 0;
    color: var(--dark-grey);
    text-align: left;
}

/* Match .section-header horizontal extent (same 5px margin, full container width). */
.profile-page > #displayErrorsBox.treatment-costs-messages {
    display: block;
    width: auto;
    max-width: none;
    margin: 5px;
    padding: 0;
    box-sizing: border-box;
    flex-basis: auto;
}

.profile-page > #displayErrorsBox .error,
.profile-page > #displayErrorsBox .success {
    margin: 0 0 10px;
    width: 100%;
    box-sizing: border-box;
}

.profile-page > #displayErrorsBox .error:last-child,
.profile-page > #displayErrorsBox .success:last-child {
    margin-bottom: 0;
}

.profile-security-status {
    margin: 0 0 12px;
    text-align: left;
}

.profile-totp-setup,
.profile-disable-form {
    max-width: 100%;
    width: 100%;
    text-align: left;
}

.profile-recovery-box + .profile-disable-form {
    margin-top: 24px;
}

.profile-disable-form .profile-field {
    margin-bottom: 16px;
}

.profile-disable-actions {
    margin-top: 8px;
}

.profile-disable-actions .nav-button {
    margin-top: 0;
}

.profile-totp-qr {
    display: block;
    margin: 8px 0;
}

.profile-totp-manual code,
.profile-recovery-list code {
    font-family: Consolas, monospace;
    font-size: 13px;
}

.profile-recovery-list {
    margin: 8px 0 0;
    padding-left: 1.25rem;
    text-align: left;
}

.profile-recovery-box {
    max-width: 100%;
    margin-bottom: 16px;
    padding: 12px;
    background: var(--surface-white);
    border: 1px solid var(--border);
    border-radius: 4px;
}

.profile-totp-form {
    margin-top: 20px;
    width: 100%;
    max-width: 100%;
}

.profile-totp-form .profile-field {
    margin-bottom: 16px;
}

.profile-totp-form .profile-field input:not([readonly]),
.profile-disable-form .profile-field input:not([readonly]) {
    width: 100%;
    box-sizing: border-box;
    padding: 6px 8px;
    margin: 0;
    border: 2px solid var(--border);
    border-radius: 4px;
}

.profile-page .profile-field input.error {
    color: var(--dark-red);
    margin: 0;
    padding: 6px 8px;
    border-color: var(--dark-red);
    background-color: var(--surface-white);
}

.profile-totp-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 5px;
    margin-top: 4px;
}

.profile-totp-actions button.submit-button {
    margin-top: 0;
}

.profile-totp-manual {
    margin-bottom: 4px;
}

.profile-field input:not([readonly]) {
    background-color: var(--surface-white);
}

.login .treatment-costs-messages {
    width: 100%;
    margin-bottom: 12px;
}

.login-2fa-hint,
.login-remember-device,
.login-2fa-back {
    text-align: left;
    font-size: var(--font-size-title);
}

.login-remember-device {
    margin: 0 0 15px;
    text-align: left;
}

.loginForm .login-remember-device-label {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    margin: 0;
    font-weight: normal;
    cursor: pointer;
}

.loginForm .login-remember-device-label input[type="checkbox"] {
    width: auto;
    margin: 0;
    padding: 0;
    flex: 0 0 auto;
}

.loginForm .login-remember-device-label span {
    flex: 1 1 auto;
    line-height: 1.4;
}

.login-2fa-back {
    margin-top: 12px;
}

.login-2fa-back a {
    color: var(--mid-blue);
}

/* ==========================================================================
   PAGE — PDF export
   ========================================================================== */
@page { size: A4 portrait; margin: 0.5cm; }
table {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}
td {
    width: 8%; 
    padding-right: 10px;
}
td.data {
    width: 18%;
}
td input {
    width:100%;
}
#pdfContainer {
    position: absolute;
    top: 0px;
    left: 0;
    right: 0;
    width: calc(100% - 1cm); /* keep equal margins inside @page */
    margin-left: auto;
    margin-right: auto;
    font-size: 11px;
}
#pdfContainer .section-title {
    font-size: 12px;
}

.grid-scroll-wrapper {
    overflow-x: auto;
    width: 100%;
    flex-basis: 100%;
    margin-bottom: 15px;
    border: 1px solid var(--border);
    background-color: var(--surface-white);
}

/* The main grid container (column count set inline on update-treatment-costs.php) */
.treatment-grid {
    display: grid;
    gap: 4px;
    padding: 10px;
}

/* Header Cell Styling */
.grid-header {
    background-color: var(--background-grey);
    color: var(--text-strong);
    font-weight: bold;
    text-align: left;
    padding: 5px;
    font-size: var(--font-size-ui);
    border-bottom: 2px solid var(--mid-blue);
    white-space: nowrap;
}

/* Treatment costs: wrap headers so columns need less horizontal space */
.treatment-grid .grid-item.grid-header {
    white-space: normal;
    overflow-wrap: anywhere;
    word-wrap: break-word;
    hyphens: auto;
    line-height: 1.35;
    align-items: flex-start;
}

.treatment-grid input,
.treatment-grid select {
    border: 1px solid var(--border);
    border-radius: 2px;
}

.treatment-grid input {
    padding: 2px;
}

/* Waiting applies / Copy Providers (compact grid buttons) */
.treatment-grid button.treatment-waiting-applies-btn.assign-teeth-btn,
.treatment-costs-intro-row button.treatment-waiting-applies-btn.assign-teeth-btn {
    height: auto;
    padding: 1px;
    margin-top: 0;
    margin-right: 0;
    box-sizing: border-box;
    border: 1px solid var(--border);
    border-radius: 2px;
    font-size: var(--font-size-ui);
    line-height: 1.35;
    font-weight: normal;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    background-color: var(--background-grey);
    color: var(--dark-grey);
    cursor: pointer;
}
.treatment-grid button.treatment-waiting-applies-btn.assign-teeth-btn {
    width: 100%;
}
.treatment-costs-intro-row button.treatment-waiting-applies-btn.assign-teeth-btn {
    width: auto;
    flex-shrink: 0;
}
.treatment-grid button.treatment-waiting-applies-btn.assign-teeth-btn:hover,
.treatment-costs-intro-row button.treatment-waiting-applies-btn.assign-teeth-btn:hover {
    background-color: var(--hover-grey);
    border-color: var(--mid-blue);
    color: var(--dark-grey);
}
.treatment-grid button.treatment-waiting-applies-btn.assign-teeth-btn.error,
.treatment-costs-intro-row button.treatment-waiting-applies-btn.assign-teeth-btn.error {
    border-color: var(--dark-red);
    background-color: var(--error-bg);
}

#copyWaitingAppliesProvidersBtn {
    margin-right: 16px;
}

/* Readonly inputs (like Code, Description) */
.treatment-grid input[readonly] {
    background-color: var(--background-grey);
    color: var(--dark-grey);
    border: 1px solid transparent;
    cursor: default;
}

/* Highlight the primary input (New Cost) */
.treatment-grid input[name*="new_cost"] {
    border-color: var(--mid-purple);
    font-weight: bold;
    background-color: var(--input-highlight-bg);
}

/* Error state for inputs */
.treatment-grid input.error {
    border-color: var(--dark-red);
    background-color: var(--error-bg);
}

/* ==========================================================================
   PAGE — dashboard (index)
   ========================================================================== */
.dashboard-welcome.section-header {
    width: 100%;
    margin: 0 0 16px;
    box-sizing: border-box;
    background-color: var(--light-blue);
}

.dashboard-grid {
    display: grid;
    gap: 16px;
    align-items: start;
}

.dashboard-grid--three {
    grid-template-columns: minmax(9.5rem, min(25rem, 28%)) minmax(0, 1fr) minmax(9.5rem, min(25rem, 28%));
}

.dashboard-grid--two {
    grid-template-columns: minmax(9.5rem, min(25rem, 28%)) minmax(0, 1fr);
}

.dashboard-panel-side {
    width: 100%;
    max-width: min(25rem, 100%);
    min-width: 0;
}

.dashboard-panel-main {
    min-width: 0;
}

.dashboard-panel .dashboard-activity-link {
    padding: 8px 2px;
}

.dashboard-panel {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.dashboard-panel .section-header {
    margin: 0 0 10px;
}

.dashboard-panel-content {
    flex-direction: column;
    align-items: stretch;
    margin: 0;
    padding: 0;
    border: none;
}

.dashboard-empty {
    margin: 0;
    color: var(--dark-grey);
    font-size: var(--font-size-title);
}

.dashboard-activity-list {
    list-style: none;
    margin: 0;
    padding: 0;
    width: 100%;
}

.dashboard-activity-item {
    border-bottom: 1px solid var(--border);
}

.dashboard-activity-item:last-child {
    border-bottom: none;
}

.dashboard-activity-link {
    display: block;
    padding: 10px 4px;
    color: var(--dark-grey);
    text-decoration: none;
    border-radius: 4px;
    transition: background-color 0.2s ease, color 0.2s ease;
    min-width: 0;
}

.dashboard-activity-link:hover,
.dashboard-activity-link:focus {
    background-color: var(--light-blue);
    color: var(--dark-blue);
    text-decoration: none;
}

.dashboard-activity-primary {
    display: block;
    font-weight: 600;
    font-size: var(--font-size-ui);
    margin-bottom: 4px;
}

.dashboard-activity-meta {
    display: block;
    font-size: var(--font-size-meta);
    color: var(--text-muted);
}

.dashboard-activity-meta-columns {
    --meta-label-width: 3.25rem;
    --meta-field-gap: 0.15rem;
    /* Max content: "31 Dec 2026, 11:59pm" / "None Selected" / "BCBS Traditional" */
    --meta-on-value-width: 20ch;
    --meta-teeth-value-width: 14ch;
    --meta-insurer-value-width: 18ch;
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    column-gap: 0.5rem;
    row-gap: 0.2rem;
    width: 100%;
    min-width: 0;
}

.dashboard-activity-meta-segment {
    display: inline-flex;
    align-items: baseline;
    gap: var(--meta-field-gap);
    flex: 0 1 auto;
    min-width: 0;
    max-width: 100%;
}

.dashboard-activity-meta-segment-on {
    flex-basis: calc(
        var(--meta-label-width) + var(--meta-field-gap) + var(--meta-on-value-width)
    );
}

.dashboard-activity-meta-segment-teeth {
    flex-basis: calc(
        var(--meta-label-width) + var(--meta-field-gap) + var(--meta-teeth-value-width)
    );
}

.dashboard-activity-meta-segment-insurer {
    flex-basis: calc(
        var(--meta-label-width) + var(--meta-field-gap) + var(--meta-insurer-value-width)
    );
}

.dashboard-activity-meta-label {
    flex: 0 0 var(--meta-label-width);
    font-weight: bold;
    color: var(--text-muted);
}

.dashboard-activity-meta-value {
    flex: 0 1 auto;
    min-width: 0;
    overflow-wrap: anywhere;
}

.dashboard-activity-meta-segment-on .dashboard-activity-meta-value {
    flex: 0 0 var(--meta-on-value-width);
    max-width: var(--meta-on-value-width);
}

.dashboard-activity-meta-segment-teeth .dashboard-activity-meta-value {
    flex: 0 0 var(--meta-teeth-value-width);
    max-width: var(--meta-teeth-value-width);
}

.dashboard-activity-meta-segment-insurer .dashboard-activity-meta-value {
    flex: 0 0 var(--meta-insurer-value-width);
    max-width: var(--meta-insurer-value-width);
}

.dashboard-activity-meta + .dashboard-activity-meta {
    margin-top: 2px;
}

/* ==========================================================================
   9. RESPONSIVE
   ========================================================================== */
@media (max-width: 1400px) {
    .dual-wrapper {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 1024px) {
    .dashboard-grid--three,
    .dashboard-grid--two {
        grid-template-columns: 1fr;
    }

    .dashboard-panel-side {
        max-width: none;
    }

    .manage-users-page .manage-users-by-type {
        grid-template-columns: 1fr;
    }

    .profile-page .profile-columns {
        grid-template-columns: 1fr;
    }
}