.dtmv-client-portal-root,
.dtmv-portal-login {
	--dtmv-navy: #1B2A4A;
	--dtmv-purple: #5A3D8C;
	--dtmv-gold: #D4AF37;
	--dtmv-cream: #F8F6F2;
	color: var(--dtmv-navy);
	font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.dtmv-portal,
.dtmv-portal-login {
	background: linear-gradient(135deg, #f8f6f2 0%, #ffffff 100%);
	border-radius: 28px;
	padding: clamp(18px, 4vw, 34px);
}

.dtmv-portal-login {
	display: grid;
	place-items: center;
	min-height: 560px;
}

.dtmv-portal-login__card,
.dtmv-portal-card {
	background: #fff;
	border: 1px solid rgba(27, 42, 74, .09);
	border-radius: 24px;
	box-shadow: 0 22px 60px rgba(27, 42, 74, .09);
	padding: clamp(18px, 3vw, 28px);
}

.dtmv-portal-login__card {
	width: min(460px, 100%);
}

.dtmv-portal-login__card h2,
.dtmv-portal h1,
.dtmv-portal h2,
.dtmv-portal h3 {
	color: var(--dtmv-navy);
	margin-top: 0;
}

.dtmv-portal-login .login-username,
.dtmv-portal-login .login-password,
.dtmv-portal-login .login-remember {
	display: grid;
	gap: 7px;
}

.dtmv-portal-login input[type="text"],
.dtmv-portal-login input[type="password"],
.dtmv-portal input,
.dtmv-portal textarea {
	width: 100%;
	border: 1px solid rgba(27, 42, 74, .14);
	border-radius: 14px;
	padding: 12px 14px;
	box-sizing: border-box;
	color: var(--dtmv-navy);
	background: #fff;
}

.dtmv-portal-login input[type="submit"],
.dtmv-portal button,
.dtmv-portal-card a {
	border: 0;
	border-radius: 14px;
	background: var(--dtmv-purple);
	color: #fff;
	font-weight: 800;
	padding: 12px 16px;
	cursor: pointer;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.dtmv-portal-eyebrow {
	color: var(--dtmv-purple);
	font-weight: 850;
	font-size: 12px;
	letter-spacing: .08em;
	text-transform: uppercase;
	margin: 0 0 8px;
}

.dtmv-portal-hero {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	gap: 20px;
	background: linear-gradient(135deg, var(--dtmv-navy), #2d245e);
	color: #fff;
	border-radius: 28px;
	padding: clamp(22px, 4vw, 38px);
	margin-bottom: 22px;
	overflow: hidden;
}

.dtmv-portal-hero h1,
.dtmv-portal-hero p {
	color: #fff;
}

.dtmv-portal-hero h1 {
	font-size: clamp(30px, 5vw, 54px);
	line-height: 1;
	margin-bottom: 12px;
}

.dtmv-countdown {
	min-width: 190px;
	border-radius: 24px;
	background: rgba(255, 255, 255, .12);
	border: 1px solid rgba(255, 255, 255, .18);
	display: grid;
	place-items: center;
	text-align: center;
	padding: 18px;
}

.dtmv-countdown strong {
	color: var(--dtmv-gold);
	font-size: clamp(42px, 7vw, 72px);
	line-height: 1;
}

.dtmv-countdown span {
	font-weight: 800;
}

.dtmv-portal-layout {
	display: grid;
	grid-template-columns: minmax(240px, 320px) 1fr;
	gap: 22px;
	align-items: start;
}

.dtmv-trip-list {
	background: var(--dtmv-navy);
	border-radius: 24px;
	padding: 18px;
	position: sticky;
	top: 24px;
}

.dtmv-trip-list__header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 10px;
	margin-bottom: 14px;
}

.dtmv-trip-list h2,
.dtmv-trip-list a,
.dtmv-trip-list p {
	color: #fff;
}

.dtmv-trip-list a {
	font-weight: 800;
	font-size: 13px;
}

.dtmv-trip-button {
	width: 100%;
	display: grid;
	gap: 5px;
	text-align: left;
	background: rgba(255, 255, 255, .08);
	color: #fff;
	border: 1px solid rgba(255, 255, 255, .12);
	margin-bottom: 10px;
}

.dtmv-trip-button:hover,
.dtmv-trip-button.is-active {
	background: rgba(212, 175, 55, .18);
	box-shadow: inset 4px 0 0 var(--dtmv-gold);
}

.dtmv-trip-button span,
.dtmv-trip-button em {
	color: rgba(255, 255, 255, .76);
	font-size: 13px;
}

.dtmv-portal-main {
	display: grid;
	gap: 18px;
}

.dtmv-trip-detail {
	display: grid;
	gap: 18px;
}

.dtmv-trip-summary {
	display: flex;
	justify-content: space-between;
	gap: 18px;
	align-items: center;
}

.dtmv-status {
	border-radius: 999px;
	background: rgba(212, 175, 55, .2);
	color: var(--dtmv-navy);
	font-weight: 850;
	padding: 8px 12px;
	white-space: nowrap;
}

.dtmv-portal-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.dtmv-fact {
	display: grid;
	gap: 7px;
}

.dtmv-fact span,
.dtmv-section-heading p,
.dtmv-muted {
	color: rgba(27, 42, 74, .68);
}

.dtmv-fact strong {
	font-size: 16px;
}

.dtmv-section-heading {
	display: flex;
	justify-content: space-between;
	gap: 14px;
	align-items: start;
	margin-bottom: 16px;
}

.dtmv-documents {
	display: grid;
	gap: 10px;
	padding: 0;
	margin: 0 0 16px;
	list-style: none;
}

.dtmv-documents li {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	align-items: center;
	border: 1px solid rgba(27, 42, 74, .09);
	border-radius: 16px;
	padding: 12px;
}

.dtmv-documents span {
	display: block;
	color: rgba(27, 42, 74, .62);
	font-size: 13px;
}

.dtmv-inline-form {
	display: grid;
	grid-template-columns: 1fr 180px 1fr auto;
	gap: 10px;
}

.dtmv-messages {
	display: grid;
	gap: 12px;
	margin-bottom: 14px;
	max-height: 420px;
	overflow: auto;
}

.dtmv-message {
	max-width: 78%;
	background: var(--dtmv-cream);
	border-radius: 18px;
	padding: 12px 14px;
}

.dtmv-message.is-mine {
	justify-self: end;
	background: rgba(90, 61, 140, .1);
}

.dtmv-message p {
	margin: 6px 0;
}

.dtmv-message span {
	color: rgba(27, 42, 74, .56);
	font-size: 12px;
}

.dtmv-message-form {
	display: grid;
	gap: 10px;
}

.dtmv-message-form textarea {
	min-height: 96px;
}

.dtmv-portal-error,
.dtmv-portal-notice {
	background: #fff1f1;
	border: 1px solid rgba(157, 45, 45, .2);
	color: #9d2d2d;
	border-radius: 16px;
	padding: 14px 16px;
	margin-bottom: 16px;
}

.dtmv-portal-loading {
	background: #fff;
	border-radius: 20px;
	padding: 28px;
	text-align: center;
	box-shadow: 0 18px 45px rgba(27, 42, 74, .08);
}

@media (max-width: 980px) {
	.dtmv-portal-layout {
		grid-template-columns: 1fr;
	}

	.dtmv-trip-list {
		position: static;
	}

	.dtmv-portal-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.dtmv-inline-form {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.dtmv-portal,
	.dtmv-portal-login {
		border-radius: 0;
		padding: 14px;
	}

	.dtmv-portal-hero,
	.dtmv-trip-summary,
	.dtmv-section-heading,
	.dtmv-documents li {
		display: grid;
	}

	.dtmv-portal-grid {
		grid-template-columns: 1fr;
	}

	.dtmv-countdown {
		min-width: 0;
	}

	.dtmv-message {
		max-width: 100%;
	}
}


.dtmv-mobile-nav {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 10px;
	margin: 0 0 20px;
}

.dtmv-mobile-nav button {
	background: #fff;
	border: 1px solid rgba(27, 42, 74, .12);
	color: var(--dtmv-navy);
	box-shadow: 0 10px 24px rgba(27, 42, 74, .06);
}

.dtmv-mobile-nav button.is-active {
	background: var(--dtmv-purple);
	color: #fff;
}

.dtmv-logout {
	align-self: flex-start;
	background: rgba(255, 255, 255, .14);
	border: 1px solid rgba(255, 255, 255, .22);
	border-radius: 999px;
	color: #fff;
	font-weight: 800;
	padding: 10px 14px;
	text-decoration: none;
}

.dtmv-portal-hero__subtitle {
	font-size: clamp(20px, 3vw, 30px);
	font-weight: 850;
	margin: 0 0 10px;
}

.dtmv-dashboard-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 14px;
	margin-bottom: 18px;
}

.dtmv-dashboard-card {
	position: relative;
	overflow: hidden;
}

.dtmv-dashboard-card::after {
	content: "";
	position: absolute;
	right: -24px;
	bottom: -24px;
	width: 76px;
	height: 76px;
	border-radius: 999px;
	background: rgba(212, 175, 55, .18);
}

.dtmv-dashboard-card span,
.dtmv-countdown-card span {
	color: rgba(27, 42, 74, .66);
	font-weight: 800;
}

.dtmv-dashboard-card strong,
.dtmv-countdown-card strong {
	display: block;
	font-size: clamp(26px, 4vw, 42px);
	line-height: 1;
	color: var(--dtmv-purple);
	margin-top: 10px;
}

.dtmv-next-trip {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 18px;
}

.dtmv-trip-layout {
	display: grid;
	grid-template-columns: minmax(260px, 340px) 1fr;
	gap: 20px;
	align-items: start;
}

.dtmv-trip-select {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 10px;
	margin-bottom: 18px;
}

.dtmv-trip-select .dtmv-trip-button {
	background: var(--dtmv-cream);
	color: var(--dtmv-navy);
	border-color: rgba(27, 42, 74, .1);
}

.dtmv-trip-select .dtmv-trip-button span,
.dtmv-trip-select .dtmv-trip-button em {
	color: rgba(27, 42, 74, .66);
}

.dtmv-countdown-card {
	text-align: center;
	background: linear-gradient(135deg, #fff, var(--dtmv-cream));
}

.dtmv-countdown-card strong {
	color: var(--dtmv-gold);
}

.dtmv-portal-grid.compact {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.dtmv-profile-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.4fr) minmax(280px, .8fr);
	gap: 18px;
	align-items: start;
}

.dtmv-profile-form {
	display: grid;
	gap: 14px;
}

.dtmv-profile-form label {
	display: grid;
	gap: 7px;
	font-weight: 800;
}

.dtmv-profile-form label span {
	color: rgba(27, 42, 74, .72);
}

.dtmv-forgot-password,
.dtmv-forgot-inline {
	display: inline-flex;
	margin-top: 12px;
	font-weight: 800;
	color: var(--dtmv-purple);
}

.dtmv-portal-success {
	background: #eefaf1;
	border: 1px solid rgba(42, 125, 65, .2);
	color: #286b3b;
	border-radius: 16px;
	padding: 14px 16px;
	margin-bottom: 16px;
}

@media (max-width: 1100px) {
	.dtmv-dashboard-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.dtmv-trip-layout,
	.dtmv-profile-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.dtmv-mobile-nav {
		position: sticky;
		top: 0;
		z-index: 10;
		grid-template-columns: repeat(5, max-content);
		overflow-x: auto;
		background: var(--dtmv-cream);
		padding: 8px 0;
	}

	.dtmv-mobile-nav button {
		padding: 10px 12px;
		font-size: 13px;
	}

	.dtmv-dashboard-grid,
	.dtmv-portal-grid.compact {
		grid-template-columns: 1fr;
	}

	.dtmv-next-trip {
		display: grid;
	}
}
