/* ==========================================================================
   Proposal Submission System - Shared Styles (ML 2.0)
   Visually aligned with the admin (mchange.php / mlist.php) MMS component
   library. Public-facing pages do NOT use info-icon-behind-modal - field
   notes are rendered inline.
   ========================================================================== */

/* Pull in the org-specific link/dark/light colors so `--org-link-color`
   resolves to the org's configured brand color on public-facing pages
   that may not load the global mms_component_styles.css.
   We import a proposals-local copy that normalizes the stored color
   (handles missing `#` prefix, whitespace, etc.) so an invalid value in
   the DB doesn't break the cascade and leave buttons / accents broken. */
@import url("/members/proposals/css/org_color.php");



/* --------------------------------------------------------------------------
   Page wrapper - keeps content readable on wide screens
   -------------------------------------------------------------------------- */
.proposal-page-wrapper {
	max-width: 920px;
	margin: 0 auto;
	padding: 0 16px 60px;
}
.proposal-page-wrapper--wide { max-width: 1280px; }


/* --------------------------------------------------------------------------
   Step Progress Bar (top of each prop page)
   -------------------------------------------------------------------------- */
.proposal-steps-wrapper {
	margin-bottom: 30px;
}

.proposal-steps {
	display: flex;
	justify-content: center;
	padding: 25px 10px 15px;
	margin: 0;
	list-style: none;
	overflow-x: auto;
}

.proposal-step {
	position: relative;
	flex: 1;
	text-align: center;
	max-width: 160px;
	min-width: 80px;
	cursor: pointer;
	padding: 0 5px;
}

.proposal-step__connector {
	position: absolute;
	top: 18px;
	left: calc(-50% + 18px);
	right: calc(50% + 18px);
	height: 3px;
	background-color: var(--mms-secondary-light, #d5d5d5);
	z-index: 1;
}

.proposal-step:first-child .proposal-step__connector { display: none; }

.proposal-step__number {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background-color: var(--mms-secondary-light, #d5d5d5);
	color: #fff;
	line-height: 36px;
	text-align: center;
	font-weight: 700;
	font-size: 14px;
	margin: 0 auto 8px;
	position: relative;
	z-index: 2;
	transition: background-color 0.2s, box-shadow 0.2s;
}

.proposal-step__label {
	font-size: 12px;
	color: var(--mms-secondary, #888);
	line-height: 1.3;
	font-weight: 600;
	transition: color 0.2s;
}

/* Completed state - green */
.proposal-step.completed .proposal-step__number    { background-color: var(--mms-success-dark, #166534); }
.proposal-step.completed .proposal-step__connector { background-color: var(--mms-success-dark, #166534); }
.proposal-step.completed .proposal-step__label     { color: var(--mms-secondary-dark, #555); }

/* Active state - primary brand color */
.proposal-step.active .proposal-step__number {
	background-color: var(--org-link-color, var(--mms-primary, #ae0e0d));
	box-shadow: 0 0 0 4px rgba(174, 14, 13, 0.18);
}
.proposal-step.active .proposal-step__connector { background-color: var(--mms-success-dark, #166534); }
.proposal-step.active .proposal-step__label {
	font-weight: 700;
	color: var(--org-link-color, var(--mms-primary, #ae0e0d));
}

.proposal-step:hover .proposal-step__number { opacity: 0.85; }
.proposal-step:hover .proposal-step__label  { color: var(--mms-secondary-dark, #333); }


/* --------------------------------------------------------------------------
   Page header (title bar above the step bar / content)
   -------------------------------------------------------------------------- */
.proposal-page-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 0 14px 0;
	margin-bottom: 20px;
	border-bottom: 2px solid var(--mms-secondary-light, #e0e0e0);
}

.proposal-page-header h1,
.proposal-page-header h2 {
	margin: 0;
	font-size: 20px;
	font-weight: 700;
	color: var(--mms-secondary-deep, #333);
}


/* --------------------------------------------------------------------------
   Section cards - mirrors the admin `.prp-section` look
   -------------------------------------------------------------------------- */
.proposal-section {
	background: #fdfcf9;
	border: 1px solid var(--mms-secondary-light, #e0e0e0);
	border-radius: var(--mms-radius, 6px);
	padding: 22px 26px 16px;
	margin-bottom: 20px;
}

.proposal-section-heading {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.09em;
	color: var(--org-link-color, var(--mms-primary, #ae0e0d));
	text-transform: uppercase;
	margin: 0 0 18px 0;
	padding: 0 0 0 12px;
	line-height: 1.2;
	border-left: 3px solid var(--org-link-color, var(--mms-primary, #ae0e0d));
	min-height: 18px;
}


/* --------------------------------------------------------------------------
   Form Layout
   -------------------------------------------------------------------------- */
.proposal-form .form-group {
	margin-bottom: 18px;
}

.proposal-form .control-label,
.proposal-form label {
	font-weight: 600;
	color: var(--mms-secondary-dark, #444);
	padding-top: 7px;
}

.proposal-form .form-control,
.proposal-form input[type="text"],
.proposal-form input[type="email"],
.proposal-form input[type="number"],
.proposal-form input[type="tel"],
.proposal-form input[type="url"],
.proposal-form input[type="password"],
.proposal-form input[type="search"],
.proposal-form select,
.proposal-form textarea {
	border-radius: var(--mms-radius, 4px);
	border: 1px solid var(--mms-secondary-light, #d1d5db);
	padding: 7px 10px;
	font-size: 14px;
	background: #fff;
	color: var(--mms-secondary-deep, #1f2937);
	transition: border-color 0.15s, box-shadow 0.15s;
}

.proposal-form .form-control:focus,
.proposal-form input:focus,
.proposal-form select:focus,
.proposal-form textarea:focus {
	border-color: var(--org-link-color, var(--mms-primary, #ae0e0d));
	outline: none;
	box-shadow: 0 0 0 3px rgba(174, 14, 13, 0.08);
}

.proposal-form .form-group [class*="col-sm"]:not(.control-label) {
	display: flex;
	align-items: flex-start;
	flex-wrap: wrap;
	gap: 5px;
}

.proposal-form .form-group [class*="col-sm"] .form-control {
	flex: 1 1 0%;
	width: auto;
	min-width: 0;
}

.proposal-form .form-group [class*="col-sm"] .email_validation_message {
	flex: 0 0 100%;
}

.proposal-form .form-group [class*="col-sm"]:has(.email_validation_message) {
	flex-wrap: wrap;
}

.proposal-form textarea.form-control,
.proposal-form textarea {
	min-height: 100px;
	resize: vertical;
}

/* Inline field note - replaces the admin's info-icon-behind-modal pattern.
   Public-facing pages render these in-place under the field. */
.field-note,
.proposal-form .field-note,
.proposal-form .mms-field-note {
	display: block;
	font-size: 12px;
	color: var(--mms-secondary, #6b7280);
	margin-top: 4px;
	line-height: 1.4;
}


/* --------------------------------------------------------------------------
   MMS field primitives - standalone styles so .mms-text-field / .mms-select-field
   / .mms-textarea-field / .mms-number-field work on pages that don't load the
   global /css_mms/mms_component_styles.css (e.g. mheader5-based pages like
   return_edit.php).
   -------------------------------------------------------------------------- */
.mms-text-field,
.mms-textarea-field,
.mms-select-field,
.mms-number-field {
	display: block;
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 9px 12px;
	font-size: 14px;
	line-height: 1.4;
	color: var(--mms-secondary-deep, #1f2937);
	background: #fff;
	border: 1px solid var(--mms-secondary-light, #d1d5db);
	border-radius: var(--org-radius, var(--mms-radius, 4px));
	box-shadow: none;
	transition: border-color 0.15s, box-shadow 0.15s;
	font-family: inherit;
	box-sizing: border-box;
}

.mms-textarea-field {
	min-height: 100px;
	resize: vertical;
}

.mms-select-field {
	appearance: auto;
	cursor: pointer;
}

.mms-number-field {
	width: auto;
	min-width: 80px;
}

.mms-text-field:focus,
.mms-textarea-field:focus,
.mms-select-field:focus,
.mms-number-field:focus {
	border-color: var(--org-link-color, var(--mms-primary, #ae0e0d));
	outline: none;
	box-shadow: 0 0 0 3px rgba(174, 14, 13, 0.08);
}

.mms-text-field:disabled,
.mms-textarea-field:disabled,
.mms-select-field:disabled,
.mms-number-field:disabled {
	background: var(--mms-light-gray, #f3f4f6);
	color: var(--mms-secondary, #6b7280);
	cursor: not-allowed;
}


/* --------------------------------------------------------------------------
   Action Bar (Prev/Next/Save) - matches the admin `.prp-action-bar`
   -------------------------------------------------------------------------- */
.proposal-form-actions,
.proposal-action-bar {
	margin-top: 24px;
	padding: 16px 0;
	border-top: 1px solid var(--mms-secondary-light, #e5e7eb);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}

.proposal-form-actions .proposal-nav-group,
.proposal-action-bar .proposal-nav-group {
	display: flex;
	gap: 8px;
}


/* --------------------------------------------------------------------------
   Presenter / Selection cards (existing class names, restyled)
   -------------------------------------------------------------------------- */
.presenter-card,
.selection-card {
	margin-bottom: 20px;
	border: 1px solid var(--mms-secondary-light, #e0e0e0);
	border-radius: var(--mms-radius, 6px);
	background: #fff;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
	overflow: hidden;
}

.presenter-card .panel-heading,
.selection-card .panel-heading {
	background: #fdfcf9;
	padding: 14px 22px;
	font-size: 12px;
	font-weight: 700;
	color: var(--org-link-color, var(--mms-primary, #ae0e0d));
	text-transform: uppercase;
	letter-spacing: 0.07em;
	border-bottom: 1px solid var(--mms-secondary-light, #e5e7eb);
	border-left: 3px solid var(--org-link-color, var(--mms-primary, #ae0e0d));
}

.presenter-card .panel-body,
.selection-card .panel-body {
	padding: 20px 22px;
}

.presenter-card .panel-body .form-group:last-child,
.selection-card .panel-body .form-group:last-child {
	margin-bottom: 0;
}


/* --------------------------------------------------------------------------
   Selection Options (Topic / Type radio groups)
   -------------------------------------------------------------------------- */
.selection-option {
	padding: 14px 22px;
	margin: 0;
	border-bottom: 1px solid var(--mms-secondary-light, #f0f0f0);
	transition: background-color 0.15s;
	cursor: pointer;
}

.selection-option:last-child { border-bottom: none; }

.selection-option:hover { background-color: var(--mms-light-gray, #f8f9fa); }

.selection-option,
.selection-option label,
.selection-option * { cursor: pointer !important; }

.selection-option label {
	display: flex !important;
	flex-direction: row !important;
	align-items: center;
	gap: 12px;
	margin: 0;
	font-weight: normal;
	line-height: 1.5;
}

.selection-option input[type="radio"] {
	flex: 0 0 auto;
	margin: 0 !important;
	position: static !important;
	width: 16px;
	height: 16px;
	accent-color: var(--org-link-color, var(--mms-primary, #ae0e0d));
}

.selection-option__text { flex: 1; min-width: 0; }

.selection-option__name {
	font-weight: 600;
	font-size: 14px;
	color: var(--mms-secondary-deep, #1f2937);
}

.selection-option__desc {
	margin-top: 3px;
	color: var(--mms-secondary, #6b7280);
	font-size: 13px;
	line-height: 1.4;
	font-weight: normal;
}

.alternate-selection {
	margin: 24px 22px 4px;
	padding: 16px 18px;
	background: var(--mms-light-gray, #f9f9f9);
	border-radius: var(--mms-radius, 4px);
}

.alternate-selection .form-group { margin-bottom: 10px; }


/* --------------------------------------------------------------------------
   Propselect Cards (RFP picker page)
   -------------------------------------------------------------------------- */
.propselect-wrapper {
	max-width: 760px;
	margin: 0 auto;
}

.propselect-wrapper .propselect-header {
	text-align: center;
	margin-bottom: 30px;
}

.propselect-wrapper .propselect-header h3 {
	font-size: 18px;
	color: var(--mms-secondary, #666);
	font-weight: 600;
}

.propselect-card {
	border: 1px solid var(--mms-secondary-light, #e0e0e0);
	border-radius: var(--mms-radius, 6px);
	overflow: hidden;
	margin-bottom: 25px;
	background: #fff;
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04);
	transition: box-shadow 0.2s;
}

.propselect-card:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.propselect-card__title {
	background: #fdfcf9;
	padding: 18px 26px;
	border-bottom: 1px solid var(--mms-secondary-light, #e8e8e8);
	border-left: 3px solid var(--org-link-color, var(--mms-primary, #ae0e0d));
	font-size: 18px;
	font-weight: 700;
	color: var(--mms-secondary-deep, #333);
	margin: 0;
}

.propselect-card__body {
	padding: 24px 26px 28px;
}

.propselect-card__desc {
	font-size: 14px;
	line-height: 1.6;
	color: var(--mms-secondary-dark, #555);
	margin-bottom: 24px;
}

.propselect-card__dates {
	display: inline-block;
	background: var(--mms-light-gray, #f0f4f8);
	border-radius: var(--mms-radius, 4px);
	padding: 8px 16px;
	font-size: 13px;
	color: var(--mms-secondary-dark, #556);
	font-style: italic;
}

.propselect-card__actions {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 16px;
	padding: 22px 0 4px;
	border-top: 1px solid var(--mms-secondary-light, #f0f0f0);
	margin-top: 4px;
}

.propselect-card__actions .btn,
.propselect-card__actions .mms-button {
	min-width: 210px;
}


/* --------------------------------------------------------------------------
   Buttons - keep legacy classes working, restyled with MMS tokens
   -------------------------------------------------------------------------- */
.btn-proposal,
.btn-proposal-secondary {
	display: inline-block;
	font-size: 14px;
	padding: 9px 22px;
	min-width: 160px;
	border-radius: var(--mms-radius, 4px);
	font-weight: 600;
	line-height: 1.4;
	text-align: center;
	text-decoration: none;
	border: 1px solid transparent;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s, color 0.15s, transform 0.1s;
}

.btn-proposal {
	background: var(--org-link-color, var(--mms-primary, #ae0e0d));
	border-color: var(--org-link-color, var(--mms-primary, #ae0e0d));
	color: #fff;
}
.btn-proposal:hover,
.btn-proposal:focus {
	background: var(--org-dark-color, var(--mms-primary-dark, #8a0b0a));
	border-color: var(--org-dark-color, var(--mms-primary-dark, #8a0b0a));
	color: #fff;
	text-decoration: none;
	transform: translateY(-1px);
}

.btn-proposal-secondary {
	background: #fff;
	border-color: var(--mms-secondary-light, #d1d5db);
	color: var(--mms-secondary-dark, #444);
}
.btn-proposal-secondary:hover,
.btn-proposal-secondary:focus {
	background: var(--mms-light-gray, #f3f4f6);
	color: var(--mms-secondary-deep, #1f2937);
	text-decoration: none;
}

/* Specificity-boost: bootstrap_forced.css (loaded by pageWrapper's forceBootstrap)
   uses `#mheader_5_wrapper button { color: inherit }` and
   `#mheader_5_wrapper a { color: #428bca }`. Those ID-prefixed selectors beat
   our `.btn-proposal { color: #fff }` rule. Re-state the colors with the same
   ID prefix so the button text + secondary text + hover states win. */
#mheader_5_wrapper a.btn-proposal,
#mheader_5_wrapper button.btn-proposal,
#mheader_5_wrapper input.btn-proposal {
	color: #fff;
	background: var(--org-link-color, var(--mms-primary, #ae0e0d));
	border-color: var(--org-link-color, var(--mms-primary, #ae0e0d));
}
#mheader_5_wrapper a.btn-proposal:hover,
#mheader_5_wrapper a.btn-proposal:focus,
#mheader_5_wrapper button.btn-proposal:hover,
#mheader_5_wrapper button.btn-proposal:focus,
#mheader_5_wrapper input.btn-proposal:hover,
#mheader_5_wrapper input.btn-proposal:focus {
	color: #fff;
	background: var(--org-dark-color, var(--mms-primary-dark, #8a0b0a));
	border-color: var(--org-dark-color, var(--mms-primary-dark, #8a0b0a));
}
#mheader_5_wrapper a.btn-proposal-secondary,
#mheader_5_wrapper button.btn-proposal-secondary,
#mheader_5_wrapper input.btn-proposal-secondary {
	color: var(--mms-secondary-dark, #444);
	background: #fff;
	border-color: var(--mms-secondary-light, #d1d5db);
}
#mheader_5_wrapper a.btn-proposal-secondary:hover,
#mheader_5_wrapper a.btn-proposal-secondary:focus,
#mheader_5_wrapper button.btn-proposal-secondary:hover,
#mheader_5_wrapper button.btn-proposal-secondary:focus,
#mheader_5_wrapper input.btn-proposal-secondary:hover,
#mheader_5_wrapper input.btn-proposal-secondary:focus {
	color: var(--mms-secondary-deep, #1f2937);
	background: var(--mms-light-gray, #f3f4f6);
}

/* Inline anchor links inside the proposal flow - make them use the org's
   link color rather than Bootstrap-forced #428bca. */
#mheader_5_wrapper .propselect-wrapper a:not(.btn-proposal):not(.btn-proposal-secondary),
#mheader_5_wrapper .proposal-form a:not(.btn-proposal):not(.btn-proposal-secondary),
#mheader_5_wrapper .presenter-card a:not(.btn-proposal):not(.btn-proposal-secondary),
#mheader_5_wrapper .review-section a:not(.btn-proposal):not(.btn-proposal-secondary) {
	color: var(--org-link-color, var(--mms-primary, #ae0e0d));
}
#mheader_5_wrapper .propselect-wrapper a:not(.btn-proposal):not(.btn-proposal-secondary):hover,
#mheader_5_wrapper .proposal-form a:not(.btn-proposal):not(.btn-proposal-secondary):hover,
#mheader_5_wrapper .presenter-card a:not(.btn-proposal):not(.btn-proposal-secondary):hover,
#mheader_5_wrapper .review-section a:not(.btn-proposal):not(.btn-proposal-secondary):hover {
	color: var(--org-dark-color, var(--mms-primary-dark, #8a0b0a));
}


/* --------------------------------------------------------------------------
   Review Layout (prop5) - section + key/value rows
   -------------------------------------------------------------------------- */
.review-section {
	margin-bottom: 20px;
	border: 1px solid var(--mms-secondary-light, #e0e0e0);
	border-radius: var(--mms-radius, 6px);
	overflow: hidden;
	background: #fff;
}

.review-section-title {
	font-size: 12px;
	font-weight: 700;
	color: var(--org-link-color, var(--mms-primary, #ae0e0d));
	padding: 12px 20px 12px 22px;
	background: #fdfcf9;
	border-bottom: 1px solid var(--mms-secondary-light, #e0e0e0);
	border-left: 3px solid var(--org-link-color, var(--mms-primary, #ae0e0d));
	text-transform: uppercase;
	letter-spacing: 0.07em;
}

.review-section-body { padding: 18px 22px; }

.review-row {
	display: flex;
	padding: 8px 0;
	border-bottom: 1px solid var(--mms-light-gray, #f5f5f5);
	align-items: flex-start;
}
.review-row:last-child  { border-bottom: none; padding-bottom: 0; }
.review-row:first-child { padding-top: 0; }

.review-row__label {
	flex: 0 0 200px;
	font-weight: 600;
	color: var(--mms-secondary-dark, #555);
	padding-right: 15px;
	text-align: right;
}

.review-row__value {
	flex: 1;
	color: var(--mms-secondary-deep, #333);
	min-width: 0;
	word-wrap: break-word;
	overflow-wrap: break-word;
}

.review-block {
	padding: 8px 0;
	line-height: 1.6;
	color: var(--mms-secondary-deep, #333);
}

.review-intro {
	background: #fdfcf9;
	border: 1px solid var(--mms-secondary-light, #e5e7eb);
	border-radius: var(--mms-radius, 6px);
	padding: 18px 22px;
	margin-bottom: 24px;
	font-size: 14px;
	line-height: 1.6;
	color: var(--mms-secondary-dark, #444);
}

.review-intro .btn,
.review-intro .mms-button { margin: 0 5px; vertical-align: middle; }

.passcode-box {
	background: #fff8e1;
	border: 1px solid #ffd54f;
	border-radius: var(--mms-radius, 6px);
	padding: 18px 22px;
	margin: 20px 0;
}

.passcode-box__row { display: flex; margin-bottom: 8px; }

.passcode-box__label {
	flex: 0 0 100px;
	font-weight: 600;
	color: var(--mms-secondary-dark, #555);
}

.passcode-box__note {
	margin-top: 12px;
	font-size: 13px;
	color: #856404;
}

@media (max-width: 600px) {
	.review-row { flex-direction: column; }
	.review-row__label {
		flex: 0 0 auto;
		text-align: left;
		margin-bottom: 2px;
	}
}


/* --------------------------------------------------------------------------
   Custom Fields (prop3 - from custom_field_output_subs.php)
   -------------------------------------------------------------------------- */
.custom-field-group {
	margin-bottom: 18px !important;
	padding-bottom: 18px;
	border-bottom: 1px solid var(--mms-light-gray, #f0f0f0);
}
.custom-field-group:last-child { border-bottom: none; padding-bottom: 0; }

.custom-field-label {
	font-size: 14px;
	font-weight: 600;
	color: var(--mms-secondary-deep, #333);
	margin-bottom: 4px;
	display: block;
}

.custom-field-desc {
	font-size: 13px;
	color: var(--mms-secondary, #777);
	margin-bottom: 8px;
	line-height: 1.4;
}

.custom-field-mandatory {
	font-size: 12px;
	color: var(--mms-secondary, #999);
	font-style: italic;
	margin-top: 4px;
}

.custom-field-checkbox {
	margin: 0 0 18px 0 !important;
	padding: 10px 0 18px !important;
	border-bottom: 1px solid var(--mms-light-gray, #f0f0f0);
}
.custom-field-checkbox:last-child { border-bottom: none; padding-bottom: 0 !important; }

.custom-field-checkbox label {
	display: flex !important;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	font-weight: normal;
	margin: 0;
	color: var(--mms-secondary-dark, #444);
}

.custom-field-checkbox input[type="checkbox"] {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	margin: 0 !important;
	position: static !important;
	cursor: pointer;
	accent-color: var(--org-link-color, var(--mms-primary, #ae0e0d));
}

.custom-field-checkbox strong {
	font-size: 14px;
	color: var(--mms-secondary-deep, #1f2937);
}


/* --------------------------------------------------------------------------
   Word Counter
   -------------------------------------------------------------------------- */
.word-counter {
	text-align: right;
	font-style: italic;
	color: var(--mms-secondary, #888);
	font-size: 13px;
}
.word-counter span { font-style: normal; }


/* --------------------------------------------------------------------------
   Validation & Status Messages
   -------------------------------------------------------------------------- */
.required-indicator {
	color: var(--mms-error-dark, #991b1b);
	font-weight: bold;
}

.email-validation-message,
.email_validation_message,
.validation-warning,
#validation_modal_confirmation_warning {
	color: var(--mms-error-dark, #991b1b);
	font-size: 13px;
	font-weight: 600;
}

.wordLimit {
	color: var(--mms-error-dark, #991b1b);
	font-weight: bold;
	font-size: 14px;
}

#input_validation_modal,
#gpa_disqualification_modal { display: none; }

.mandatory-note {
	color: var(--mms-error-dark, #991b1b);
	font-size: 12px;
	font-style: italic;
}

.small-note {
	font-size: 11px;
	color: var(--mms-secondary, #888);
}


/* --------------------------------------------------------------------------
   Status text colors - used inline across proposal pages
   -------------------------------------------------------------------------- */
.status-text-pending { color: var(--mms-warning-dark, #92400e); }
.status-text-success { color: var(--mms-success-dark, #166534); }
.status-text-error   { color: var(--mms-error-dark,   #991b1b); }
.status-text-muted   { color: var(--mms-secondary,    #6b7280); }


/* --------------------------------------------------------------------------
   Callout box - reference/assignment cards, RSVP boxes, etc.
   -------------------------------------------------------------------------- */
.proposal-callout-box {
	border: 1px solid var(--mms-secondary-light, #d1d5db);
	border-radius: 6px;
	padding: 20px;
	margin-bottom: 20px;
	background: #fff;
}
.proposal-callout-box.compact { padding: 12px 16px; }


/* --------------------------------------------------------------------------
   Scoring fields - rendered by displayScoringFields() in custom_field_output_subs.php
   -------------------------------------------------------------------------- */
.field-wrapper {
	padding: 12px 0;
}

.field-wrapper .form-label {
	display: block;
	font-weight: 600;
	color: var(--mms-secondary-deep, #1f2937);
	margin: 0 0 4px;
}
.field-wrapper .small-note {
	font-size: 12px;
	color: var(--mms-secondary, #6b7280);
	margin: 0 0 6px;
}
.field-wrapper .mms-select-field,
.field-wrapper .mms-text-field,
.field-wrapper .mms-textarea-field,
.field-wrapper .mms-number-field {
	width: 100%;
	max-width: 100%;
}
.field-wrapper .form-group { margin: 0; }

/* Indicator (checkbox) field - checkbox + label inline */
.field-wrapper .checkbox-group {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px;
}
.field-wrapper .checkbox-left {
	flex-shrink: 0;
	display: flex;
	align-items: center;
}
.field-wrapper .checkbox-right {
	flex: 1;
	min-width: 0;
}
.field-wrapper .checkbox-group .form-label {
	margin: 0;
	cursor: pointer;
}
.field-wrapper .checkbox-group .small-note {
	flex-basis: 100%;
	margin: 4px 0 0;
}
.field-wrapper .checkbox-control {
	margin: 0;
	width: 18px;
	height: 18px;
}

/* Scoring section wrapper (score.php) */
.scoring-section { margin: 12px 0 0; }
.scoring-section-header {
	text-align: center;
	font-size: 16px;
	margin-bottom: 4px;
}
.scoring-divider {
	border: 0;
	border-top: 1px solid var(--mms-secondary-light, #d1d5db);
	width: 50%;
	margin: 10px auto 0;
}
.scoring-workshop-label {
	font-weight: bold;
	line-height: 1.6;
	margin: 8px 0;
}
.scoring-upload {
	display: flex;
	gap: 18px;
	align-items: flex-start;
	padding: 16px 0;
}
.scoring-upload-label {
	flex: 0 0 35%;
	font-weight: 600;
	font-size: 14px;
}
.scoring-upload-input { flex: 1; }
.scoring-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	margin-top: 24px;
	padding-top: 16px;
}
.scoring-total {
	font-size: 18px;
	font-weight: 600;
	color: var(--mms-secondary-deep, #1f2937);
}
.scoring-actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* Inbox / Outbox style cards used by proplist.php */
.proplist-boxes { margin: 0 -10px; }
.proplist-box { margin-bottom: 20px; }
.proplist-box-heading {
	margin: 0 0 14px;
	font-size: 15px;
	font-weight: 700;
	color: var(--mms-secondary-deep, #1f2937);
	padding-bottom: 8px;
	border-bottom: 1px solid var(--mms-secondary-light, #e5e7eb);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.proplist-status { font-size: 11px; color: var(--mms-secondary, #6b7280); }


/* --------------------------------------------------------------------------
   Inline alerts - used by propemailcheck and similar status pages
   -------------------------------------------------------------------------- */
.mms-alert-error,
.mms-alert-info,
.mms-alert-warning,
.mms-alert-success {
	padding: 12px 16px;
	border-radius: var(--mms-radius, 6px);
	margin: 12px 0;
	font-size: 14px;
	line-height: 1.5;
	border: 1px solid transparent;
}
.mms-alert-error {
	background: #f8d7da;
	color: #721c24;
	border-color: #f5c6cb;
}
.mms-alert-info {
	background: #d1ecf1;
	color: #0c5460;
	border-color: #bee5eb;
}
.mms-alert-warning {
	background: #fff3cd;
	color: #856404;
	border-color: #ffeeba;
}
.mms-alert-success {
	background: #d4edda;
	color: #155724;
	border-color: #c3e6cb;
}


/* --------------------------------------------------------------------------
   File Upload Area
   -------------------------------------------------------------------------- */
#previous-files {
	color: var(--mms-secondary, #777);
	margin: 0 0 20px 0;
	border: 1px solid var(--mms-secondary-light, #e0e0e0);
	border-radius: var(--mms-radius, 4px);
	padding: 12px 14px;
	background: var(--mms-light-gray, #f9fafb);
}

.prev-files-name { text-align: left; }
.prev-files-date { text-align: right; }
.prev-files-del  { text-align: center; }


/* --------------------------------------------------------------------------
   Co-presenter Sections
   -------------------------------------------------------------------------- */
.co-presenter-head {
	cursor: pointer;
	padding: 12px 22px;
	margin: 0;
	background: #fdfcf9;
	border-left: 3px solid var(--org-link-color, var(--mms-primary, #ae0e0d));
	transition: background 0.15s;
	display: flex;
	align-items: center;
	gap: 12px;
}
.presenter-card .co-presenter-head + .panel-body {
	border-top: 1px solid var(--mms-secondary-light, #e5e7eb);
}
.co-presenter-head:hover { background: var(--mms-light-gray, #f3f4f6); }

.co-presenter-left {
	flex: 1 1 auto;
	width: auto;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: var(--org-link-color, var(--mms-primary, #ae0e0d));
}
.co-presenter-right {
	flex: 0 0 auto;
	width: auto;
	text-align: right;
	font-size: 12px;
	font-style: normal;
	color: var(--mms-secondary, #6b7280);
}

/* Trash-icon delete link - used for co-presenters and reference rows */
.co-presenter-delete,
.reference-delete {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: var(--mms-radius, 4px);
	color: var(--mms-secondary, #6b7280);
	text-decoration: none;
	transition: background 0.15s, color 0.15s;
}
.co-presenter-delete:hover,
.co-presenter-delete:focus,
.reference-delete:hover,
.reference-delete:focus {
	background: rgba(153, 27, 27, 0.08);
	color: var(--mms-error-dark, #991b1b);
	text-decoration: none;
}
.co-presenter-delete svg,
.reference-delete svg { display: block; }

.co-presenter-member-status-message {
	font-size: 14px;
	text-align: center;
	color: var(--mms-secondary-dark, #444);
}


/* --------------------------------------------------------------------------
   Read-only & Disabled Fields
   -------------------------------------------------------------------------- */
input[readonly]:not([type="submit"]):not([type="button"]):not([type="reset"]):not([type="image"]),
textarea[readonly] {
	background-color: var(--mms-light-gray, #f0f0f0);
	cursor: not-allowed;
	color: var(--mms-secondary, #6b7280);
}


/* --------------------------------------------------------------------------
   Page Indicator (PAHU style)
   -------------------------------------------------------------------------- */
.page-indicator {
	font-size: 14px;
	text-align: center;
	margin-bottom: 15px;
	color: var(--mms-secondary, #666);
}


/* --------------------------------------------------------------------------
   Required Fields Legend
   -------------------------------------------------------------------------- */
.required-legend {
	font-size: 13px;
	margin: 10px 0 20px;
	color: var(--mms-secondary, #666);
	font-style: italic;
}


/* --------------------------------------------------------------------------
   Responsive Adjustments
   -------------------------------------------------------------------------- */
@media (max-width: 767px) {
	.proposal-steps { padding: 15px 5px 10px; }
	.proposal-step  { min-width: 60px; }
	.proposal-step__number {
		width: 30px;
		height: 30px;
		line-height: 30px;
		font-size: 12px;
	}
	.proposal-step__connector {
		top: 15px;
		left: calc(-50% + 15px);
		right: calc(50% + 15px);
	}
	.proposal-step__label { font-size: 10px; }

	.proposal-form .control-label { text-align: left; margin-bottom: 5px; }
	.proposal-form-actions,
	.proposal-action-bar {
		flex-direction: column;
		align-items: stretch;
		text-align: center;
	}

	.btn-proposal,
	.btn-proposal-secondary {
		display: block;
		width: 100%;
		margin-bottom: 10px;
	}
	.proposal-form-actions .btn + .btn { margin-left: 0; }

	.propselect-card__actions .btn,
	.propselect-card__actions .mms-button {
		min-width: 0;
		width: 100%;
	}

	.proposal-section { padding: 18px 18px 10px; }
}
