/* Migrawise — Client Portal CSS */

/* ----- Layout ----- */
.mw-portal-wrapper {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	background:
		radial-gradient(ellipse 60% 50% at 20% 10%, rgba(218,119,86,.05), transparent 60%),
		radial-gradient(ellipse 50% 60% at 80% 80%, rgba(196,101,74,.04), transparent 60%),
		linear-gradient(180deg, #FFFBF5 0%, #FDF2EE 50%, #FFFBF5 100%);
}

.mw-portal-header {
	background: rgba(253,245,240,.9);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border-bottom: 1px solid rgba(218,119,86,.06);
	position: sticky;
	top: 0;
	z-index: 100;
}
.mw-portal-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: 960px;
	margin: 0 auto;
	padding: 0 24px;
	height: 60px;
}
.mw-portal-header__logo { font-weight: 700; font-size: 18px; color: var(--mw-primary, #DA7756); }
.mw-portal-header__nav { display: flex; align-items: center; gap: 16px; font-size: 14px; }
.mw-portal-header__logout { color: var(--mw-red); }

.mw-portal-main { flex: 1; max-width: 960px; margin: 0 auto; padding: 32px 24px; width: 100%; }

.mw-portal-footer {
	text-align: center;
	font-size: 12px;
	color: var(--mw-gray-400);
	padding: 16px;
	border-top: 1px solid rgba(218,119,86,.06);
}

/* ----- Section cards ----- */
.mw-portal-section {
	background: rgba(253,245,240,.75);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid rgba(218,119,86,.08);
	border-radius: var(--mw-radius);
	box-shadow: 0 8px 32px rgba(218,119,86,.04);
	padding: 24px;
	margin-bottom: 24px;
	transition: box-shadow .2s, border-color .2s;
}
.mw-portal-section:hover {
	box-shadow: 0 8px 28px rgba(218,119,86,.06), 0 0 40px rgba(218,119,86,.03);
	border-color: rgba(218,119,86,.12);
}

/* ----- Loading spinner ----- */
.mw-portal-loading { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 48px 0; color: var(--mw-gray-400); }
.mw-spinner {
	display: inline-block;
	width: 36px;
	height: 36px;
	border: 3px solid var(--mw-gray-200);
	border-top-color: var(--mw-primary, #DA7756);
	border-radius: 50%;
	animation: mw-spin 0.8s linear infinite;
}
@keyframes mw-spin { to { transform: rotate(360deg); } }

/* ----- Forms ----- */
.mw-form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.mw-form-group[hidden] { display: none; }
.mw-form-group label { font-size: 14px; font-weight: 500; color: var(--mw-gray-600); }
.mw-input {
	padding: 8px 12px;
	border: 1px solid var(--mw-gray-200);
	border-radius: 6px;
	font-size: 15px;
	font-family: var(--mw-font);
	width: 100%;
	transition: border-color 0.15s;
}
.mw-input:focus { outline: none; border-color: var(--mw-primary, #DA7756); box-shadow: 0 0 0 3px rgba(218,119,86,.15); }
.mw-input--readonly { background: var(--mw-gray-100); cursor: not-allowed; }
.mw-input-hint { font-size: 12px; color: var(--mw-gray-400); }

/* ----- Buttons ----- */
.mw-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 9px 18px;
	border-radius: 6px;
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
	border: none;
	transition: background 0.15s, opacity 0.15s;
}
.mw-btn--primary {
	background: linear-gradient(135deg, #DA7756 0%, #C4654A 50%, #DA7756 100%);
	background-size: 200% auto;
	color: #fff;
	transition: background-position .3s, box-shadow .3s, transform .2s;
}
.mw-btn--primary:hover {
	background-position: right center;
	box-shadow: 0 4px 16px rgba(218,119,86,.35), 0 0 30px rgba(218,119,86,.08);
	transform: translateY(-1px);
}
.mw-btn--full { width: 100%; }
.mw-btn:disabled { opacity: .6; cursor: not-allowed; }

/* ----- Register page ----- */
.mw-register-wrapper {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	background:
		radial-gradient(ellipse 60% 50% at 20% 20%, rgba(218,119,86,.12), transparent 60%),
		radial-gradient(ellipse 50% 60% at 80% 70%, rgba(196,101,74,.08), transparent 60%),
		radial-gradient(ellipse 70% 40% at 50% 100%, rgba(232,146,111,.06), transparent 60%),
		linear-gradient(135deg, #FFFBF5 0%, #FDF2EE 30%, #FAE5DA 60%, #FDF2EE 100%);
	position: relative;
	overflow: hidden;
}
.mw-register-wrapper::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse 500px 500px at 20% 20%, rgba(218,119,86,.08), transparent 70%),
		radial-gradient(ellipse 400px 400px at 80% 70%, rgba(196,101,74,.06), transparent 70%);
	pointer-events: none;
}
.mw-register-card {
	background: rgba(255,255,255,.85);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border: 1px solid rgba(218,119,86,.12);
	border-radius: var(--mw-radius);
	box-shadow: 0 24px 64px rgba(218,119,86,.08), 0 0 80px rgba(218,119,86,.04);
	padding: 40px;
	width: 100%;
	max-width: 440px;
	position: relative;
	z-index: 1;
}
.mw-register-card__logo { font-size: 20px; font-weight: 700; color: var(--mw-primary, #DA7756); margin-bottom: 24px; }
.mw-register-card__title { font-size: 22px; font-weight: 700; margin: 0 0 8px; }
.mw-register-card__subtitle { color: var(--mw-gray-600); margin: 0 0 24px; font-size: 14px; }
.mw-register-error { background: #fef2f2; border: 1px solid #fecaca; border-radius: 6px; padding: 12px 16px; font-size: 14px; color: var(--mw-red); margin-bottom: 16px; }

/* ----- Password toggle ----- */
.mw-input-wrapper { position: relative; display: flex; align-items: center; }
.mw-input-wrapper .mw-input { padding-right: 44px; }
.mw-password-toggle {
	position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
	background: none; border: none; cursor: pointer; padding: 4px;
	color: var(--mw-gray-400, #9CA3AF); transition: color 0.15s;
	display: flex; align-items: center; line-height: 1;
}
.mw-password-toggle:hover { color: var(--mw-gray-600, #4B5563); }
.mw-password-toggle svg { width: 20px; height: 20px; }
.mw-password-toggle .mw-eye-off { display: none; }
.mw-password-toggle.mw-visible .mw-eye-on { display: none; }
.mw-password-toggle.mw-visible .mw-eye-off { display: block; }

/* ----- Password match indicator ----- */
.mw-password-match {
	display: inline-flex; align-items: center; gap: 4px;
	font-size: 13px; font-weight: 500; margin-top: 4px;
}
.mw-password-match--ok { color: var(--mw-green, #22c55e); }
.mw-password-match--mismatch { color: var(--mw-red, #ef4444); }

/* ----- Required asterisk ----- */
.mw-required { color: var(--mw-red, #ef4444); font-weight: 400; }

/* ----- Conditional field slide animation ----- */
.mw-form-group.mw-slide-in { animation: mw-slide-down 0.25s ease-out; }
@keyframes mw-slide-down { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }

/* ----- Custom Select (MwSelect) ----- */
.mw-select { position: relative; width: 100%; }
.mw-select__trigger {
	display: flex; align-items: center; justify-content: space-between; gap: 8px;
	width: 100%; padding: 8px 12px; border: 1px solid var(--mw-gray-200, #e5e7eb);
	border-radius: 6px; background: #fff; cursor: pointer;
	font-size: 15px; font-family: var(--mw-font, inherit); color: var(--mw-gray-800, #1f2937);
	transition: border-color 0.15s; text-align: left; line-height: 1.4;
}
.mw-select__trigger:focus { outline: none; border-color: var(--mw-primary, #DA7756); box-shadow: 0 0 0 3px rgba(218,119,86,.15); }
.mw-select--open .mw-select__trigger { border-color: var(--mw-primary, #DA7756); box-shadow: 0 0 0 3px rgba(218,119,86,.15); }
.mw-select__value { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mw-select__value--placeholder { color: var(--mw-gray-400, #9ca3af); }
.mw-select__arrow { flex-shrink: 0; color: var(--mw-gray-400, #9ca3af); transition: transform 0.2s; display: flex; }
.mw-select--open .mw-select__arrow { transform: rotate(180deg); }
.mw-select__dropdown {
	position: absolute; top: calc(100% + 4px); left: 0;
	min-width: 100%;
	background: #fff; border: 1px solid var(--mw-gray-200, #e5e7eb);
	border-radius: 8px; box-shadow: 0 8px 24px rgba(0,0,0,.12);
	z-index: 1000; display: none; flex-direction: column;
	overflow: hidden;
}
.mw-select--open .mw-select__dropdown { display: flex; }
.mw-select--open { z-index: 1001; }
.mw-select__search {
	padding: 10px 12px; border: none; border-bottom: 1px solid var(--mw-gray-100, #f3f4f6);
	font-size: 14px; font-family: var(--mw-font, inherit); outline: none;
	color: var(--mw-gray-800, #1f2937); background: #fff;
}
.mw-select__search::placeholder { color: var(--mw-gray-400, #9ca3af); }
.mw-select__list { overflow-y: auto; max-height: 240px; padding: 4px 0; }
.mw-select__option {
	padding: 8px 12px; cursor: pointer; font-size: 14px;
	color: var(--mw-gray-700, #374151); transition: background 0.1s;
	white-space: normal; word-break: break-word;
}
.mw-select__option:hover,
.mw-select__option--focused { background: var(--mw-gray-50, #f9fafb); }
.mw-select__option--selected { background: rgba(218,119,86,.08); color: var(--mw-primary, #DA7756); font-weight: 500; }
.mw-select__option[hidden] { display: none; }
.mw-select__empty { padding: 12px; text-align: center; font-size: 13px; color: var(--mw-gray-400, #9ca3af); }

/* ----- Phone input group ----- */
.mw-phone-group { display: flex; gap: 8px; align-items: flex-start; }
.mw-phone-group .mw-select { flex: 0 0 150px; }
.mw-phone-group .mw-select__dropdown { min-width: 320px; }
.mw-phone-group__number { flex: 1; }

/* ----- Input focus orange accent on register page ----- */
.mw-register-page .mw-input:focus { border-color: var(--mw-primary, #DA7756); box-shadow: 0 0 0 3px rgba(218,119,86,.15); }

/* ----- Progress bar ----- */
.mw-progress-bar { height: 6px; background: var(--mw-gray-200); border-radius: 3px; overflow: hidden; margin-bottom: 8px; }
.mw-progress-bar__fill { height: 100%; background: var(--mw-primary, #DA7756); border-radius: 3px; transition: width 0.3s ease; }
.mw-progress-label { font-size: 13px; color: var(--mw-gray-600); }

/* ----- Ghost button (register page) ----- */
.mw-btn--ghost { background: transparent; color: var(--mw-gray-600); border: 1px solid var(--mw-gray-200); }
.mw-btn--ghost:hover { background: var(--mw-gray-100); }

/* ----- Questionnaire step nav ----- */
.mw-step-nav { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; }
.mw-step-btn { padding: 6px 12px; border-radius: 20px; border: 1px solid var(--mw-gray-200); background: #fff; font-size: 13px; cursor: pointer; transition: all 0.15s; }
.mw-step-btn--active { background: var(--mw-primary, #DA7756); color: #fff; border-color: var(--mw-primary, #DA7756); }
.mw-step-btn--complete { background: var(--mw-primary-light, #FDF2EE); color: var(--mw-primary, #DA7756); border-color: var(--mw-primary, #DA7756); }

/* =========================================================
   Portal Dashboard (rendered by PortalDashboard JS class)
   ========================================================= */

/* ----- Welcome banner ----- */
.mw-portal-welcome {
	background: linear-gradient(135deg, #DA7756 0%, #C4654A 50%, #DA7756 100%);
	background-size: 200% auto;
	animation: mw-gradient-shift 6s ease-in-out infinite;
	color: #fff;
	border-radius: var(--mw-radius);
	padding: 24px 28px;
	margin-bottom: 24px;
}
.mw-portal-welcome h2 { margin: 0 0 4px; font-size: 22px; font-weight: 700; }
.mw-portal-welcome p  { margin: 0; font-size: 14px; opacity: .85; }
.mw-portal-welcome strong { font-weight: 600; opacity: 1; }

/* ----- Section title row ----- */
.mw-portal-section__title {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 16px;
	font-weight: 600;
	margin: 0 0 16px;
	color: var(--mw-gray-800, #1f2937);
}
.mw-portal-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	height: 22px;
	padding: 0 7px;
	background: var(--mw-gray-100, #f3f4f6);
	border-radius: 11px;
	font-size: 12px;
	font-weight: 600;
	color: var(--mw-gray-600, #4b5563);
}

/* ----- Empty state ----- */
.mw-portal-empty { color: var(--mw-gray-400, #9ca3af); font-size: 14px; margin: 0; padding: 16px 0; }

/* ----- Case cards ----- */
.mw-portal-cases { display: grid; gap: 12px; }

.mw-portal-case-card {
	background: rgba(253,245,240,.65);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border: 1px solid rgba(218,119,86,.08);
	border-radius: 8px;
	padding: 16px 20px;
	transition: box-shadow .2s, border-color .2s, transform .2s;
}
.mw-portal-case-card:hover {
	box-shadow: 0 6px 20px rgba(0,0,0,.08), 0 0 0 1px rgba(218,119,86,.08);
	border-color: rgba(218,119,86,.12);
	transform: translateY(-2px);
}

.mw-portal-case-card__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 8px;
}
.mw-portal-case-card__title {
	font-weight: 600;
	font-size: 15px;
	color: var(--mw-gray-800, #1f2937);
}
.mw-portal-case-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 12px;
	font-size: 13px;
	color: var(--mw-gray-500, #6b7280);
}
.mw-portal-case-card__desc {
	margin: 10px 0 0;
	font-size: 13px;
	color: var(--mw-gray-600, #4b5563);
	line-height: 1.5;
}
.mw-portal-deadline {
	font-size: 12px;
	font-weight: 500;
	color: #dc2626;
	background: #fef2f2;
	border-radius: 4px;
	padding: 2px 7px;
}

/* ----- Status badges ----- */
.mw-portal-status {
	display: inline-flex;
	align-items: center;
	padding: 3px 9px;
	border-radius: 12px;
	font-size: 12px;
	font-weight: 500;
	white-space: nowrap;
	text-transform: capitalize;
	background: var(--mw-gray-100, #f3f4f6);
	color: var(--mw-gray-600, #4b5563);
}
/* Case / document statuses */
.mw-portal-status--active         { background: #dcfce7; color: #166534; }
.mw-portal-status--approved       { background: #dcfce7; color: #166534; }
.mw-portal-status--complete       { background: #dbeafe; color: #1e40af; }
.mw-portal-status--submitted      { background: #dbeafe; color: #1e40af; }
.mw-portal-status--in-progress    { background: #fef3c7; color: #92400e; }
.mw-portal-status--under-review   { background: #fef3c7; color: #92400e; }
.mw-portal-status--pending        { background: #f3f4f6; color: #374151; }
.mw-portal-status--uploaded       { background: #f3f4f6; color: #374151; }
.mw-portal-status--on-hold        { background: #fef3c7; color: #92400e; }
.mw-portal-status--rejected       { background: #fef2f2; color: #991b1b; }
.mw-portal-status--closed         { background: #f3f4f6; color: #9ca3af; }
.mw-portal-status--inactive       { background: #f3f4f6; color: #9ca3af; }

/* ----- Documents table ----- */
.mw-portal-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}
.mw-portal-table thead th {
	text-align: left;
	font-weight: 600;
	font-size: 12px;
	color: var(--mw-gray-500, #6b7280);
	text-transform: uppercase;
	letter-spacing: .04em;
	padding: 0 12px 10px 0;
	border-bottom: 1px solid var(--mw-gray-200, #e5e7eb);
}
.mw-portal-table tbody td {
	padding: 11px 12px 11px 0;
	border-bottom: 1px solid var(--mw-gray-100, #f3f4f6);
	color: var(--mw-gray-700, #374151);
	vertical-align: middle;
}
.mw-portal-table tbody tr:last-child td { border-bottom: none; }
.mw-portal-doc-link { color: var(--mw-primary, #DA7756); text-decoration: none; font-weight: 500; }
.mw-portal-doc-link:hover { text-decoration: underline; }

/* ----- Error state ----- */
.mw-portal-error {
	background: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: 8px;
	padding: 24px;
	color: var(--mw-red, #dc2626);
	font-size: 14px;
	line-height: 1.6;
}
.mw-portal-error p { margin: 0 0 8px; }
.mw-portal-error p:last-child { margin-bottom: 0; }

/* =========================================================
   Questionnaire layout
   ========================================================= */

/* Dashboard teaser card */
.mw-q-dashboard-card .mw-btn { font-size: 14px; }

/* Two-column layout: sidebar nav + form */
.mw-q-layout {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: 0;
	min-height: 60vh;
	background: #fff;
	border-radius: var(--mw-radius);
	box-shadow: var(--mw-shadow);
	overflow: hidden;
}

/* Sidebar */
.mw-q-nav {
	background: var(--mw-gray-50);
	border-right: 1px solid var(--mw-gray-200);
	padding: 20px 16px;
}
.mw-q-progress { margin-bottom: 16px; }
.mw-q-nav__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.mw-q-nav__btn {
	display: flex;
	align-items: center;
	gap: 8px;
	width: 100%;
	padding: 8px 10px;
	background: transparent;
	border: none;
	border-radius: 6px;
	font-size: 13px;
	color: var(--mw-gray-700);
	cursor: pointer;
	text-align: left;
	transition: background 0.12s;
}
.mw-q-nav__btn:hover  { background: var(--mw-gray-100); }
.mw-q-nav__btn--active { background: var(--mw-primary, #DA7756); color: #fff; }
.mw-q-nav__btn--done { color: #166534; }
.mw-q-nav__btn--done.mw-q-nav__btn--active { background: var(--mw-primary, #DA7756); color: #fff; }
.mw-q-nav__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: var(--mw-gray-200);
	font-size: 11px;
	font-weight: 700;
	flex-shrink: 0;
}
.mw-q-nav__btn--active  .mw-q-nav__icon { background: rgba(255,255,255,.25); color: #fff; }
.mw-q-nav__btn--done    .mw-q-nav__icon { background: #dcfce7; color: #166534; }

/* Submit / submitted badges */
.mw-q-submitted-badge {
	margin-top: 12px;
	padding: 10px 12px;
	background: #dcfce7;
	color: #166534;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 500;
}
.mw-q-submitted-note { font-size: 13px; color: var(--mw-gray-500); font-style: italic; margin: 16px 0 0; }

/* Form area */
.mw-q-content { padding: 28px 32px; overflow-y: auto; }
.mw-q-section__title { font-size: 18px; font-weight: 700; margin: 0 0 20px; color: var(--mw-gray-800); }
.mw-q-form__actions { display: flex; align-items: center; gap: 12px; margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--mw-gray-100); }
.mw-q-autosave-note { font-size: 12px; color: var(--mw-gray-400); }

/* Repeater */
.mw-q-repeater { border: 1px solid var(--mw-gray-200); border-radius: 8px; padding: 16px; margin-bottom: 16px; }
.mw-q-repeater legend { font-size: 14px; font-weight: 600; color: var(--mw-gray-700); padding: 0 6px; }
.mw-q-repeater__entry { margin-bottom: 12px; padding-bottom: 12px; border-bottom: 1px dashed var(--mw-gray-200); }
.mw-q-repeater__entry:last-of-type { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }

/* ----- Responsive tweaks ----- */
@media (max-width: 700px) {
	.mw-q-layout { grid-template-columns: 1fr; }
	.mw-q-nav { border-right: none; border-bottom: 1px solid var(--mw-gray-200); }
	.mw-q-content { padding: 20px 16px; }
}
@media (max-width: 600px) {
	.mw-portal-case-card__header { flex-direction: column; align-items: flex-start; }
	.mw-portal-table thead th:nth-child(3),
	.mw-portal-table tbody td:nth-child(3) { display: none; } /* hide Size on mobile */
}

/* =========================================================
   Document Upload
   ========================================================= */

.mw-doc-upload-row { display: flex; flex-direction: column; gap: 10px; }
@media (min-width: 600px) { .mw-doc-upload-row { flex-direction: row; align-items: flex-start; flex-wrap: wrap; } }

.mw-doc-upload-area {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 20px 16px;
	border: 2px dashed var(--mw-gray-300, #D1D5DB);
	border-radius: 8px;
	cursor: pointer;
	transition: border-color 0.15s, background 0.15s;
	text-align: center;
	font-size: 13px;
	color: var(--mw-gray-500, #6B7280);
	background: #FAFAFA;
	min-width: 200px;
}
.mw-doc-upload-area:hover,
.mw-doc-upload-area:focus,
.mw-doc-upload-area--dragging { border-color: var(--mw-primary, #DA7756); background: #FDF2EE; color: var(--mw-primary, #DA7756); outline: none; }
.mw-doc-upload-area__icon { font-size: 22px; }
.mw-doc-upload-area__hint { font-size: 11px; color: var(--mw-gray-400, #9CA3AF); }

.mw-doc-upload-status { display: block; margin-top: 8px; font-size: 13px; }
.mw-doc-upload-status--success { color: #059669; }
.mw-doc-upload-status--error   { color: var(--mw-red, #DC2626); }

/* =========================================================
   Portal Messages
   ========================================================= */

.mw-portal-msg-section {}

.mw-msg-form { display: flex; flex-direction: column; gap: 8px; }
.mw-msg-form textarea { resize: vertical; min-height: 64px; }

.mw-msg-item {
	padding: 12px 14px;
	border-radius: 8px;
	margin-bottom: 8px;
	max-width: 90%;
}
.mw-msg-item--firm    { background: #F3F4F6; color: var(--mw-gray-700, #374151); align-self: flex-start; margin-right: auto; }
.mw-msg-item--contact { background: #FDF2EE; color: #C2410C; align-self: flex-end; margin-left: auto; }

#mw-portal-messages { display: flex; flex-direction: column; gap: 4px; max-height: 320px; overflow-y: auto; padding: 4px 0; }

.mw-msg-item__author { font-size: 11px; font-weight: 600; opacity: .7; margin-bottom: 3px; }
.mw-msg-item__body   { font-size: 13px; line-height: 1.5; word-break: break-word; }
.mw-msg-item__date   { font-size: 11px; opacity: .6; margin-top: 4px; text-align: right; }

/* Help text for questionnaire fields */
.mw-field-help {
    display: block;
    margin-top: 4px;
    font-size: 12px;
    color: var(--mw-gray-500, #6b7280);
    line-height: 1.4;
}

/* =========================================================
   Portal Invoices
   ========================================================= */

/* Invoice status badges */
.mw-portal-status--sent    { background: #dbeafe; color: #1e40af; }
.mw-portal-status--paid    { background: #dcfce7; color: #166534; }
.mw-portal-status--partial { background: #fef3c7; color: #92400e; }
.mw-portal-status--overdue { background: #fef2f2; color: #991b1b; }

/* Invoice table row — clickable */
.mw-invoice-row {
	cursor: pointer;
	transition: background 0.12s;
}
.mw-invoice-row:hover { background: var(--mw-gray-50, #f9fafb); }
.mw-invoice-row:focus-visible { outline: 2px solid var(--mw-primary, #DA7756); outline-offset: -2px; }

.mw-invoice-link {
	color: var(--mw-primary, #DA7756);
	font-weight: 500;
}

/* Invoice detail panel */
.mw-invoice-detail {
	margin-top: 20px;
	padding: 20px;
	border: 1px solid var(--mw-gray-200, #e5e7eb);
	border-radius: var(--mw-radius, 8px);
	background: #fff;
}

.mw-invoice-detail__header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 20px;
	flex-wrap: wrap;
}
.mw-invoice-detail__title {
	font-size: 18px;
	font-weight: 700;
	margin: 0 0 4px;
	color: var(--mw-gray-800, #1f2937);
}
.mw-invoice-detail__meta {
	display: flex;
	gap: 16px;
	font-size: 13px;
	color: var(--mw-gray-500, #6b7280);
}
.mw-invoice-detail__actions {
	display: flex;
	align-items: center;
	gap: 8px;
}

/* Line-items table */
.mw-invoice-items-table { margin-bottom: 20px; }
.mw-invoice-items-table thead th:nth-child(2),
.mw-invoice-items-table thead th:nth-child(3),
.mw-invoice-items-table thead th:nth-child(4),
.mw-invoice-items-table thead th:nth-child(5),
.mw-invoice-items-table tbody td:nth-child(2),
.mw-invoice-items-table tbody td:nth-child(3),
.mw-invoice-items-table tbody td:nth-child(4),
.mw-invoice-items-table tbody td:nth-child(5) { text-align: right; }

/* Totals */
.mw-invoice-totals {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 6px;
	margin-bottom: 20px;
}
.mw-invoice-totals__row {
	display: flex;
	justify-content: space-between;
	gap: 32px;
	font-size: 14px;
	color: var(--mw-gray-700, #374151);
	min-width: 240px;
}
.mw-invoice-totals__row--total {
	font-weight: 700;
	font-size: 15px;
	color: var(--mw-gray-800, #1f2937);
	padding-top: 6px;
	border-top: 1px solid var(--mw-gray-200, #e5e7eb);
}
.mw-invoice-totals__row--balance {
	font-weight: 600;
	color: var(--mw-primary, #DA7756);
}

/* Payment history */
.mw-invoice-payments { margin-top: 16px; }
.mw-invoice-payments__title {
	font-size: 14px;
	font-weight: 600;
	margin: 0 0 8px;
	color: var(--mw-gray-800, #1f2937);
}
.mw-invoice-payments__list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.mw-invoice-payment-item {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 8px 12px;
	font-size: 13px;
	color: var(--mw-gray-700, #374151);
	border-bottom: 1px solid var(--mw-gray-100, #f3f4f6);
}
.mw-invoice-payment-item:last-child { border-bottom: none; }
.mw-invoice-payment-method {
	font-size: 12px;
	color: var(--mw-gray-500, #6b7280);
	text-transform: capitalize;
}
.mw-invoice-payment-ref {
	font-size: 11px;
	color: var(--mw-gray-400, #9ca3af);
}

/* Print: hide everything except invoice detail */
@media print {
	.mw-portal-header,
	.mw-portal-footer,
	.mw-invoice-print-btn,
	.mw-invoice-close-btn,
	.mw-invoice-table,
	.mw-portal-section:not(:has(.mw-invoice-detail)),
	.mw-portal-welcome { display: none !important; }
	.mw-invoice-detail { border: none; box-shadow: none; padding: 0; }
}

/* Responsive: stack invoice detail header on mobile */
@media (max-width: 600px) {
	.mw-invoice-detail__header { flex-direction: column; }
	.mw-invoice-totals__row { min-width: 180px; }
	.mw-invoice-items-table thead th:nth-child(4),
	.mw-invoice-items-table tbody td:nth-child(4) { display: none; } /* hide Tax % on mobile */
}

/* =========================================================
   Brand Color Custom Properties (v3.0.0)
   ========================================================= */

:root {
	--portal-primary: var(--mw-primary, #DA7756);
	--portal-accent: var(--mw-primary-dark, #C4654A);
}

/* Override primary-colored elements with brand custom properties */
.mw-portal-wrapper .mw-btn--primary { background: var(--portal-primary); }
.mw-portal-wrapper .mw-btn--primary:hover { background: var(--portal-accent); filter: brightness(0.95); }
.mw-portal-wrapper .mw-portal-doc-link { color: var(--portal-primary); }
.mw-portal-wrapper .mw-portal-welcome {
	background: linear-gradient(135deg, var(--portal-primary) 0%, var(--portal-accent) 50%, var(--portal-primary) 100%);
	background-size: 200% auto;
	animation: mw-gradient-shift 6s ease-in-out infinite;
}
.mw-portal-wrapper .mw-portal-header__logo { color: var(--portal-primary); }
.mw-portal-wrapper .mw-progress-bar__fill { background: var(--portal-primary); }
.mw-portal-wrapper .mw-spinner { border-top-color: var(--portal-primary); }
.mw-portal-wrapper .mw-input:focus { border-color: var(--portal-primary); box-shadow: 0 0 0 3px rgba(218,119,86,.15); }

/* =========================================================
   Firm Logo in Header (v3.0.0)
   ========================================================= */

.mw-portal-header__logo-img {
	height: 36px;
	max-width: 160px;
	object-fit: contain;
	display: block;
}

/* =========================================================
   Social Links (v3.0.0)
   ========================================================= */

.mw-portal-social-links {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 12px;
}
.mw-portal-social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: rgba(255,255,255,.2);
	color: #fff;
	text-decoration: none;
	transition: background 0.15s, transform 0.15s;
}
.mw-portal-social-link:hover {
	background: rgba(255,255,255,.35);
	transform: scale(1.1);
}
.mw-portal-social-link svg { width: 16px; height: 16px; fill: currentColor; }

/* =========================================================
   Case Progress / Workflow Bar (v3.0.0)
   ========================================================= */

.mw-portal-workflow { margin-bottom: 24px; }

.mw-workflow-case { margin-bottom: 20px; }
.mw-workflow-case:last-child { margin-bottom: 0; }

.mw-workflow-case__title {
	font-size: 14px;
	font-weight: 600;
	color: var(--mw-gray-800, #1f2937);
	margin: 0 0 12px;
}

/* Horizontal step bar (desktop) */
.mw-workflow-steps {
	display: flex;
	align-items: flex-start;
	position: relative;
	padding: 0;
	margin: 0;
	list-style: none;
}
.mw-workflow-step {
	display: flex;
	flex-direction: column;
	align-items: center;
	flex: 1;
	position: relative;
	text-align: center;
	min-width: 0;
}

/* Connecting line between steps */
.mw-workflow-step::before {
	content: '';
	position: absolute;
	top: 14px;
	left: -50%;
	right: 50%;
	height: 2px;
	background: var(--mw-gray-200, #e5e7eb);
	z-index: 0;
}
.mw-workflow-step:first-child::before { display: none; }
.mw-workflow-step--completed::before { background: #22c55e; }
.mw-workflow-step--current::before { background: #22c55e; }

/* Step circle */
.mw-workflow-step__circle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	font-size: 12px;
	font-weight: 600;
	z-index: 1;
	flex-shrink: 0;
	background: var(--mw-gray-200, #e5e7eb);
	color: var(--mw-gray-500, #6b7280);
	border: 2px solid var(--mw-gray-200, #e5e7eb);
}
.mw-workflow-step--completed .mw-workflow-step__circle {
	background: #22c55e;
	border-color: #22c55e;
	color: #fff;
}
.mw-workflow-step--current .mw-workflow-step__circle {
	background: #3b82f6;
	border-color: #3b82f6;
	color: #fff;
	box-shadow: 0 0 0 4px rgba(59,130,246,.2);
}

/* Step label */
.mw-workflow-step__label {
	font-size: 11px;
	color: var(--mw-gray-500, #6b7280);
	margin-top: 6px;
	max-width: 90px;
	line-height: 1.3;
	word-break: break-word;
}
.mw-workflow-step--current .mw-workflow-step__label {
	color: #3b82f6;
	font-weight: 600;
}
.mw-workflow-step--completed .mw-workflow-step__label {
	color: #166534;
}

/* Mobile: vertical list layout */
@media (max-width: 600px) {
	.mw-workflow-steps {
		flex-direction: column;
		align-items: flex-start;
		gap: 0;
	}
	.mw-workflow-step {
		flex-direction: row;
		align-items: center;
		text-align: left;
		gap: 10px;
		padding: 6px 0;
	}
	.mw-workflow-step::before {
		top: -6px;
		left: 13px;
		right: auto;
		width: 2px;
		height: 12px;
	}
	.mw-workflow-step:first-child::before { display: none; }
	.mw-workflow-step__label {
		margin-top: 0;
		max-width: none;
		font-size: 13px;
	}
}

/* =========================================================
   Document Review Status Badges (v3.0.0)
   ========================================================= */

.mw-doc-review-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px 8px;
	border-radius: 10px;
	font-size: 11px;
	font-weight: 500;
	white-space: nowrap;
}
.mw-doc-review-badge--pending {
	background: var(--mw-gray-100, #f3f4f6);
	color: var(--mw-gray-600, #4b5563);
}
.mw-doc-review-badge--approved {
	background: #dcfce7;
	color: #166534;
}
.mw-doc-review-badge--needs_revision {
	background: #fff7ed;
	color: #c2410c;
}

.mw-doc-review-note {
	display: block;
	font-size: 12px;
	color: #c2410c;
	margin-top: 4px;
	line-height: 1.4;
	padding-left: 2px;
}

.mw-doc-reupload-prompt {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 12px;
	color: var(--portal-primary);
	font-weight: 500;
	cursor: pointer;
	margin-top: 4px;
	background: none;
	border: none;
	padding: 0;
	text-decoration: underline;
}
.mw-doc-reupload-prompt:hover { text-decoration: none; }

/* =========================================================
   Reminders / Upcoming Items (v3.0.0)
   ========================================================= */

.mw-portal-reminders { margin-bottom: 24px; }

.mw-reminder-list {
	display: grid;
	gap: 10px;
}

.mw-reminder-card {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 14px 16px;
	border: 1px solid var(--mw-gray-200, #e5e7eb);
	border-radius: 8px;
	transition: box-shadow 0.15s;
	cursor: default;
}
.mw-reminder-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,.06); }

.mw-reminder-card__icon {
	font-size: 20px;
	flex-shrink: 0;
	line-height: 1;
	margin-top: 1px;
}

.mw-reminder-card__body { flex: 1; min-width: 0; }

.mw-reminder-card__title {
	font-size: 14px;
	font-weight: 600;
	color: var(--mw-gray-800, #1f2937);
	margin: 0 0 2px;
}

.mw-reminder-card__date {
	font-size: 12px;
	color: var(--mw-gray-500, #6b7280);
}

.mw-reminder-card__desc {
	font-size: 13px;
	color: var(--mw-gray-600, #4b5563);
	margin-top: 4px;
	line-height: 1.4;
}

.mw-reminder-card--clickable { cursor: pointer; }
.mw-reminder-card--clickable:hover { border-color: var(--portal-primary); }

/* Appointment detail overlay (within card) */
.mw-reminder-card__detail {
	margin-top: 8px;
	padding-top: 8px;
	border-top: 1px solid var(--mw-gray-100, #f3f4f6);
	font-size: 13px;
	color: var(--mw-gray-600, #4b5563);
	line-height: 1.5;
}
.mw-reminder-card__detail dt {
	font-weight: 600;
	color: var(--mw-gray-700, #374151);
	display: inline;
}
.mw-reminder-card__detail dd {
	display: inline;
	margin: 0 0 0 4px;
}
.mw-reminder-card__detail dd::after { content: ''; display: block; margin-bottom: 4px; }

/* =========================================================
   Mobile Responsive — Portal
   ========================================================= */

@media (max-width: 768px) {
	/* Portal wrapper */
	.mw-portal-wrapper { padding: 0; }
	.mw-portal-content { padding: 16px; max-width: 100%; }

	/* Portal header */
	.mw-portal-header { padding: 12px 16px; }
	.mw-portal-header__title { font-size: 16px; }

	/* Portal welcome */
	.mw-portal-welcome { padding: 20px; font-size: 14px; }
	.mw-portal-welcome h2 { font-size: 20px; }

	/* Portal nav */
	.mw-portal-nav { overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap; scrollbar-width: none; }
	.mw-portal-nav::-webkit-scrollbar { display: none; }
	.mw-portal-nav a { white-space: nowrap; flex-shrink: 0; font-size: 13px; padding: 8px 14px; }

	/* Sections */
	.mw-portal-section { padding: 16px; margin-bottom: 16px; }
	.mw-portal-section h3 { font-size: 16px; }

	/* Register card */
	.mw-register-card { padding: 24px 20px; max-width: calc(100vw - 32px); }
	.mw-register-card__title { font-size: 18px; }

	/* Case cards */
	.mw-portal-case-card { padding: 16px; }

	/* Invoice detail */
	.mw-invoice-detail { padding: 16px; }

	/* Footer */
	.mw-portal-footer { padding: 16px; font-size: 12px; }
}

@media (max-width: 480px) {
	.mw-portal-content { padding: 12px; }
	.mw-portal-section { padding: 14px; }
	.mw-register-card { padding: 20px 16px; }
	.mw-portal-welcome { padding: 16px; }
	.mw-portal-welcome h2 { font-size: 18px; }
}

/* =========================================================
   Questionnaire Cards (Portal Dashboard)
   ========================================================= */

.mw-q-cards-grid {
	display: grid;
	gap: 12px;
}

.mw-q-card {
	background: #fff;
	border: 1px solid var(--mw-gray-200, #e5e7eb);
	border-radius: 10px;
	padding: 16px;
	transition: box-shadow 0.2s, border-color 0.2s;
}
.mw-q-card:hover {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
	border-color: rgba(218, 119, 86, 0.15);
}
.mw-q-card--submitted {
	border-color: #10b981;
	background: #f0fdf4;
}

.mw-q-card__header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 10px;
	gap: 12px;
}
.mw-q-card__info { flex: 1; min-width: 0; }
.mw-q-card__title {
	font-weight: 600;
	font-size: 14px;
	color: var(--mw-gray-800, #1f2937);
}
.mw-q-card__subtype {
	font-size: 12px;
	color: var(--mw-gray-500, #6b7280);
	margin-top: 2px;
}

.mw-q-card__badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 3px 10px;
	border-radius: 12px;
	font-size: 12px;
	font-weight: 600;
	white-space: nowrap;
	flex-shrink: 0;
}
.mw-q-card__badge--submitted {
	background: #dcfce7;
	color: #166534;
}
.mw-q-card__badge--progress {
	background: var(--mw-primary-light, #FDF2EE);
	color: var(--portal-primary, #DA7756);
}

.mw-q-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	margin-top: 4px;
}
.mw-q-card__fields {
	font-size: 12px;
	color: var(--mw-gray-500, #6b7280);
}
.mw-q-card__status-text {
	font-size: 12px;
	color: #166534;
	font-weight: 500;
}
.mw-q-card__status-text i { margin-right: 4px; }

/* Small button variant */
.mw-btn--sm {
	padding: 6px 14px;
	font-size: 13px;
	border-radius: 6px;
}
.mw-btn--sm i { margin-right: 4px; }

/* =========================================================
   Document Cards & Upload Zones (Portal Dashboard)
   ========================================================= */

.mw-docs-case-group {
	margin-bottom: 20px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--mw-gray-100, #f3f4f6);
}
.mw-docs-case-group:last-child { border-bottom: none; padding-bottom: 0; }

.mw-docs-case-group__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 12px;
}
.mw-docs-case-group__title {
	font-size: 15px;
	font-weight: 600;
	color: var(--mw-gray-800, #1f2937);
	margin: 0;
}
.mw-docs-case-group__count {
	font-size: 12px;
	color: var(--mw-gray-500, #6b7280);
	font-weight: 500;
}

.mw-docs-general-upload {
	margin-top: 20px;
	padding-top: 16px;
	border-top: 1px solid var(--mw-gray-100, #f3f4f6);
}

/* Document card */
.mw-doc-card {
	background: #fff;
	border: 1px solid var(--mw-gray-200, #e5e7eb);
	border-radius: 8px;
	padding: 14px 16px;
	margin-bottom: 8px;
	transition: box-shadow 0.15s, border-color 0.15s;
}
.mw-doc-card:hover {
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}
.mw-doc-card[data-status="approved"] {
	border-left: 3px solid #10b981;
}
.mw-doc-card[data-status="needs_revision"] {
	border-left: 3px solid #DA7756;
}
.mw-doc-card[data-status="uploaded"] {
	border-left: 3px solid #3b82f6;
}
.mw-doc-card[data-status="pending"] {
	border-left: 3px solid var(--mw-gray-300, #d1d5db);
}

.mw-doc-card__header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 10px;
}
.mw-doc-card__info { flex: 1; min-width: 0; }
.mw-doc-card__name {
	font-weight: 600;
	font-size: 14px;
	color: var(--mw-gray-800, #1f2937);
	display: block;
}
.mw-doc-card__desc {
	font-size: 12px;
	color: var(--mw-gray-500, #6b7280);
	margin-top: 2px;
	display: block;
}
.mw-doc-card__optional {
	font-size: 11px;
	color: var(--mw-gray-500, #6b7280);
	font-style: italic;
	margin-left: 6px;
}

.mw-doc-card__review-note {
	margin-top: 8px;
	padding: 8px 12px;
	background: #fff7ed;
	border: 1px solid #fed7aa;
	border-radius: 6px;
	font-size: 12px;
	color: #c2410c;
	line-height: 1.4;
}
.mw-doc-card__review-note i { margin-right: 4px; }

.mw-doc-card__file {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-top: 8px;
	font-size: 13px;
}
.mw-doc-card__file i { color: var(--mw-gray-400, #9ca3af); margin-right: 2px; }
.mw-doc-card__size {
	font-size: 11px;
	color: var(--mw-gray-400, #9ca3af);
}

/* Document status badges */
.mw-doc-status-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 3px 9px;
	border-radius: 12px;
	font-size: 11px;
	font-weight: 500;
	white-space: nowrap;
	flex-shrink: 0;
}
.mw-doc-status-badge i { font-size: 10px; }

.mw-doc-status-badge--pending {
	background: var(--mw-gray-100, #f3f4f6);
	color: var(--mw-gray-600, #4b5563);
}
.mw-doc-status-badge--uploaded {
	background: #dbeafe;
	color: #1e40af;
}
.mw-doc-status-badge--approved {
	background: #dcfce7;
	color: #166534;
}
.mw-doc-status-badge--needs-revision {
	background: #fff7ed;
	color: #DA7756;
}

/* Inline upload zone (per-doc-requirement) */
.mw-doc-upload-zone {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 8px;
	padding: 10px 14px;
	border: 2px dashed var(--mw-gray-300, #d1d5db);
	border-radius: 8px;
	cursor: pointer;
	font-size: 13px;
	color: var(--mw-gray-500, #6b7280);
	background: #fafafa;
	transition: border-color 0.15s, background 0.15s, color 0.15s;
}
.mw-doc-upload-zone:hover,
.mw-doc-upload-zone:focus,
.mw-doc-upload-zone--dragging {
	border-color: var(--portal-primary, #DA7756);
	background: #FDF2EE;
	color: var(--portal-primary, #DA7756);
	outline: none;
}
.mw-doc-upload-zone i { font-size: 16px; }

/* Responsive: document cards */
@media (max-width: 600px) {
	.mw-doc-card__header { flex-direction: column; align-items: flex-start; gap: 6px; }
	.mw-q-card__header { flex-direction: column; align-items: flex-start; gap: 6px; }
	.mw-q-card__footer { flex-direction: column; align-items: flex-start; }
}
