/* LTD Portal Styles */

:root {
	--ltd-portal-primary: #1a5f7a;
	--ltd-portal-primary-dark: #10384b;
	--ltd-portal-accent: #f97316;
	--ltd-portal-success: #15803d;
	--ltd-portal-error: #b91c1c;
	--ltd-portal-bg: #f5f9fc;
	--ltd-portal-card: #ffffff;
	--ltd-portal-border: #d9e6ee;
	--ltd-portal-text: #162332;
	--ltd-portal-muted: #5d7286;
	--ltd-portal-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
	--ltd-portal-shadow-lg: 0 24px 48px rgba(15, 23, 42, 0.11);
}

.ltd-page-portal .ltd-page-hero {
	position: relative;
	overflow: hidden;
	color: #fff;
	background:
		radial-gradient(circle at top left, rgba(249, 115, 22, 0.18), transparent 24%),
		radial-gradient(circle at 88% 18%, rgba(56, 189, 248, 0.16), transparent 20%),
		linear-gradient(135deg, #0d2836 0%, #17485e 56%, #236f8a 100%);
	padding: clamp(4.6rem, 8vw, 6.1rem) 0 clamp(5.8rem, 9.8vw, 7.6rem);
	border-bottom: 0;
}

.ltd-page-portal .ltd-page-hero::before,
.ltd-page-portal .ltd-page-hero::after {
	content: '';
	position: absolute;
	pointer-events: none;
}

.ltd-page-portal .ltd-page-hero::before {
	inset: auto -8% -32% auto;
	width: clamp(18rem, 28vw, 26rem);
	height: clamp(18rem, 28vw, 26rem);
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.08);
	filter: blur(8px);
}

.ltd-page-portal .ltd-page-hero::after {
	inset: 0;
	background:
		linear-gradient(120deg, rgba(255, 255, 255, 0.06) 0%, transparent 34%),
		repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.04) 0 1px, transparent 1px 16px);
	opacity: 0.45;
}

.ltd-page-portal .ltd-page-hero .ltd-container {
	position: relative;
	z-index: 1;
}

.ltd-page-portal .ltd-page-hero .ltd-breadcrumb {
	padding-top: 0;
	margin-bottom: 1.5rem;
}

.ltd-page-portal .ltd-page-hero .ltd-breadcrumb__list li,
.ltd-page-portal .ltd-page-hero .ltd-breadcrumb__list a {
	color: rgba(255, 255, 255, 0.72);
}

.ltd-page-portal .ltd-page-hero .ltd-breadcrumb__list li:last-child {
	color: rgba(255, 255, 255, 0.96);
}

.ltd-page-portal .ltd-page-hero .ltd-breadcrumb__list li:not(:last-child)::after {
	color: rgba(255, 255, 255, 0.35);
}

.ltd-page-portal .ltd-page-hero__title {
	max-width: 14ch;
	color: #fff;
}

.ltd-page-portal .ltd-page-hero__desc {
	max-width: 64ch;
	color: rgba(255, 255, 255, 0.82);
}

.ltd-portal-page-hero__panel {
	max-width: min(72rem, 100%);
}

.ltd-portal-page-hero__body {
	display: block;
}

.ltd-portal-page-hero__copy {
	max-width: 48rem;
}

.ltd-page-portal--login .ltd-portal-page-hero__copy::after,
.ltd-page-portal--register .ltd-portal-page-hero__copy::after {
	content: '';
	display: block;
	width: 112px;
	height: 4px;
	margin-top: 1.6rem;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--ltd-portal-accent) 0%, var(--ltd-portal-primary) 100%);
}

.ltd-portal-page-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	padding: 0.42rem 0.82rem;
	margin-bottom: 1rem;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.12);
	color: rgba(255, 255, 255, 0.92);
	font-size: 0.74rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.ltd-portal-page-hero__signals {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 1.2rem;
}

.ltd-portal-page-hero__signal {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.62rem 0.88rem;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.14);
	color: rgba(255, 255, 255, 0.92);
	font-size: 0.92rem;
	font-weight: 600;
}

.ltd-portal-page-hero__signal::before {
	content: '';
	width: 0.56rem;
	height: 0.56rem;
	border-radius: 999px;
	background: linear-gradient(180deg, #f9b26a 0%, #ffffff 100%);
	box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.08);
}

.ltd-portal-page__section {
	background:
		linear-gradient(180deg, var(--ltd-portal-bg) 0%, #ffffff 40%);
	padding-top: 0;
}

.ltd-portal-page__content {
	margin-top: clamp(-3.2rem, -5vw, -4.25rem);
	position: relative;
	z-index: 2;
}

.ltd-portal {
	width: 100%;
}

.ltd-portal__shell {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.ltd-portal__hero,
.ltd-portal__card,
.ltd-portal__section-card {
	border: 1px solid var(--ltd-portal-border);
	border-radius: 30px;
	background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
	box-shadow: var(--ltd-portal-shadow);
}

.ltd-portal__hero {
	display: flex;
	justify-content: space-between;
	gap: 1.5rem;
	padding: 1.7rem 1.8rem;
	align-items: flex-end;
}

.ltd-portal__hero-copy {
	max-width: 42rem;
}

.ltd-portal__eyebrow {
	display: inline-flex;
	align-items: center;
	padding: 0.38rem 0.76rem;
	margin-bottom: 0.95rem;
	border-radius: 999px;
	background: rgba(26, 95, 122, 0.08);
	color: var(--ltd-portal-primary-dark);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.ltd-portal__heading {
	margin: 0;
	font-size: clamp(1.6rem, 3vw, 2.4rem);
	font-weight: 800;
	line-height: 1.05;
	letter-spacing: -0.04em;
	color: var(--ltd-portal-text);
}

.ltd-portal__intro {
	margin: 0.8rem 0 0;
	font-size: 1rem;
	line-height: 1.75;
	color: var(--ltd-portal-muted);
}

.ltd-portal__hero-chips {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 0.7rem;
	max-width: 20rem;
}

.ltd-portal__hero-chip {
	display: inline-flex;
	align-items: center;
	gap: 0.38rem;
	padding: 0.7rem 0.9rem;
	border-radius: 999px;
	background: rgba(26, 95, 122, 0.06);
	border: 1px solid rgba(26, 95, 122, 0.09);
	color: #2a4d61;
	font-size: 0.9rem;
	font-weight: 600;
}

.ltd-portal__hero-chip strong {
	color: var(--ltd-portal-text);
}

.ltd-portal__notice {
	padding: 0.9rem 1rem;
	border-radius: 18px;
	font-size: 0.94rem;
	line-height: 1.55;
}

.ltd-portal__notice--success {
	background: #f0fdf4;
	border: 1px solid #86efac;
	color: var(--ltd-portal-success);
}

.ltd-portal__notice--error {
	background: #fef2f2;
	border: 1px solid #fca5a5;
	color: var(--ltd-portal-error);
}

.ltd-portal__notice ul {
	margin: 0;
	padding: 0 0 0 1.15rem;
}

.ltd-portal__layout {
	display: grid;
	grid-template-columns: minmax(0, 1.6fr) minmax(300px, 0.95fr);
	gap: 1.5rem;
	align-items: start;
}

.ltd-portal__main,
.ltd-portal__sidebar {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.ltd-portal__card {
	max-width: 42rem;
	margin: 0 auto;
	padding: 2rem;
}

.ltd-portal__card--auth {
	max-width: none;
	padding: clamp(1.65rem, 3vw, 2.25rem);
	border-radius: 32px;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, #fafdff 100%);
	box-shadow: var(--ltd-portal-shadow-lg);
}

.ltd-portal__card-intro {
	display: grid;
	gap: 0.65rem;
	margin-bottom: 1rem;
}

.ltd-portal__card-kicker {
	display: inline-flex;
	align-items: center;
	align-self: start;
	padding: 0.42rem 0.82rem;
	border-radius: 999px;
	background: rgba(26, 95, 122, 0.08);
	color: var(--ltd-portal-primary-dark);
	font-size: 0.74rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.ltd-portal__section-card {
	padding: 1.45rem;
}

.ltd-portal__section-head {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.95rem;
	align-items: start;
	margin-bottom: 1.15rem;
}

.ltd-portal__section-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	border-radius: 999px;
	background: rgba(26, 95, 122, 0.08);
	color: var(--ltd-portal-primary);
	box-shadow: inset 0 0 0 1px rgba(26, 95, 122, 0.08);
}

.ltd-portal__section-icon svg {
	width: 1.35rem;
	height: 1.35rem;
	display: block;
}

.ltd-portal__section-title {
	margin: 0;
	font-size: 1.14rem;
	font-weight: 700;
	color: var(--ltd-portal-text);
}

.ltd-portal__section-text {
	margin: 0.35rem 0 0;
	font-size: 0.94rem;
	line-height: 1.65;
	color: var(--ltd-portal-muted);
}

.ltd-portal__form {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.ltd-portal__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem;
}

.ltd-portal__field {
	display: flex;
	flex-direction: column;
	gap: 0.38rem;
}

.ltd-portal__field--span-2 {
	grid-column: 1 / -1;
}

.ltd-portal__field label {
	font-size: 0.88rem;
	font-weight: 700;
	color: var(--ltd-portal-text);
}

.ltd-portal__field input[type="text"],
.ltd-portal__field input[type="email"],
.ltd-portal__field input[type="password"],
.ltd-portal__field input[type="tel"],
.ltd-portal__field input[type="url"],
.ltd-portal__field select,
.ltd-portal__field textarea {
	width: 100%;
	padding: 0.78rem 0.92rem;
	border: 1px solid var(--ltd-portal-border);
	border-radius: 16px;
	font-size: 1rem;
	color: var(--ltd-portal-text);
	background: #fff;
	transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
	box-sizing: border-box;
}

.ltd-portal__field input:focus,
.ltd-portal__field select:focus,
.ltd-portal__field textarea:focus {
	outline: none;
	border-color: var(--ltd-portal-primary);
	box-shadow: 0 0 0 3px rgba(26, 95, 122, 0.12);
	background: #fcfeff;
}

.ltd-portal__field textarea {
	min-height: 8.5rem;
	resize: vertical;
}

.ltd-portal__field small {
	font-size: 0.82rem;
	color: var(--ltd-portal-muted);
}

.ltd-portal__field--inline {
	flex-direction: row;
	align-items: center;
}

.ltd-portal__field--inline label {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	font-weight: 600;
}

.ltd-portal__field--inline input[type="checkbox"] {
	width: 1rem;
	height: 1rem;
	accent-color: var(--ltd-portal-primary);
}

.ltd-portal__checkboxes {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 0.6rem;
	padding: 0.8rem;
	border: 1px solid var(--ltd-portal-border);
	border-radius: 20px;
	background: #f8fbfd;
}

.ltd-portal__checkbox-label {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	min-height: 100%;
	padding: 0.75rem 0.82rem;
	border: 1px solid #deebf4;
	border-radius: 14px;
	background: #fff;
	font-size: 0.92rem;
	font-weight: 500;
	color: var(--ltd-portal-text);
	cursor: pointer;
}

.ltd-portal__checkbox-label input[type="checkbox"] {
	width: 1rem;
	height: 1rem;
	accent-color: var(--ltd-portal-primary);
}

.ltd-portal__upload-card {
	display: flex;
	flex-direction: column;
	gap: 0.7rem;
	padding: 0.95rem;
	border: 1px dashed #c9dae6;
	border-radius: 18px;
	background: #f9fcfe;
}

.ltd-portal__logo-preview {
	max-width: 180px;
	max-height: 88px;
	padding: 0.55rem;
	border: 1px solid var(--ltd-portal-border);
	border-radius: 12px;
	background: #fff;
	display: block;
}

.ltd-portal__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 0.25rem;
}

.ltd-portal__btn,
.ltd-portal__logout {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	padding: 0.82rem 1.3rem;
	border-radius: 999px;
	border: 1px solid transparent;
	background: var(--ltd-portal-primary);
	color: #fff;
	font-size: 0.95rem;
	font-weight: 700;
	line-height: 1;
	text-decoration: none;
	cursor: pointer;
	transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
	box-shadow: 0 14px 28px rgba(16, 56, 75, 0.14);
}

.ltd-portal__btn:hover,
.ltd-portal__logout:hover {
	transform: translateY(-1px);
}

.ltd-portal__btn:hover {
	background: var(--ltd-portal-primary-dark);
}

.ltd-portal__btn--secondary {
	background: #fff;
	color: var(--ltd-portal-primary-dark);
	border-color: rgba(26, 95, 122, 0.18);
	box-shadow: 0 10px 22px rgba(15, 23, 42, 0.06);
}

.ltd-portal__btn--secondary:hover {
	background: #f6fbfe;
	border-color: rgba(26, 95, 122, 0.3);
}

.ltd-portal__btn--auth {
	width: 100%;
	justify-content: center;
	padding-block: 0.96rem;
	background: linear-gradient(180deg, #1f6d8a 0%, #165771 100%);
	box-shadow: 0 18px 30px rgba(16, 56, 75, 0.18);
}

.ltd-portal__btn--auth:hover {
	background: linear-gradient(180deg, #15536b 0%, #10384b 100%);
}

.ltd-portal__summary-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.65rem;
}

.ltd-portal__summary-list li {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.9rem 0.95rem;
	border: 1px solid #e3edf4;
	border-radius: 16px;
	background: #f8fbfd;
}

.ltd-portal__summary-list span {
	font-size: 0.88rem;
	color: var(--ltd-portal-muted);
}

.ltd-portal__summary-list strong {
	font-size: 0.94rem;
	color: var(--ltd-portal-text);
	text-align: right;
}

.ltd-portal__town-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
	gap: 0.65rem;
}

.ltd-portal__town-list li {
	padding: 0.78rem 0.82rem;
	border: 1px solid #e3edf4;
	border-radius: 16px;
	background: #f8fbfd;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--ltd-portal-text);
}

.ltd-portal__town-list li span {
	display: block;
	margin-top: 0.18rem;
	font-size: 0.78rem;
	font-weight: 500;
	color: var(--ltd-portal-muted);
}

.ltd-portal__empty {
	margin: 0;
	padding: 0.95rem 1rem;
	border-radius: 16px;
	background: #f8fbfd;
	color: var(--ltd-portal-muted);
	font-size: 0.92rem;
	line-height: 1.65;
}

.ltd-portal__divider {
	border: none;
	border-top: 1px solid var(--ltd-portal-border);
	margin: 1.4rem 0;
}

.ltd-portal__links {
	margin: 1.25rem 0 0;
	font-size: 0.92rem;
	color: var(--ltd-portal-muted);
	text-align: center;
}

.ltd-portal__links a {
	color: var(--ltd-portal-primary);
	text-decoration: none;
	font-weight: 600;
}

.ltd-portal__links a:hover {
	text-decoration: underline;
}

.ltd-portal__links--auth {
	margin-top: 1rem;
}

.ltd-portal__text-link {
	color: var(--ltd-portal-primary);
	text-decoration: none;
	font-weight: 700;
}

.ltd-portal__text-link:hover {
	text-decoration: underline;
}

.ltd-portal__auth-layout {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.72fr);
	gap: 1.5rem;
	align-items: start;
}

.ltd-portal__auth-side {
	display: grid;
	gap: 1rem;
	align-content: start;
	grid-auto-rows: max-content;
}

.ltd-portal__auth-side-card {
	padding: 1.4rem 1.3rem;
	border: 1px solid rgba(26, 95, 122, 0.12);
	border-radius: 28px;
	background: linear-gradient(180deg, #ffffff 0%, #f5fbff 100%);
	box-shadow: var(--ltd-portal-shadow);
	align-self: start;
}

.ltd-portal__auth-side-card--soft {
	background:
		linear-gradient(180deg, #ffffff 0%, #f5fbff 100%);
	border-color: rgba(26, 95, 122, 0.12);
}

.ltd-portal__auth-side-kicker {
	display: inline-flex;
	align-items: center;
	padding: 0.38rem 0.76rem;
	margin-bottom: 0.9rem;
	border-radius: 999px;
	background: rgba(26, 95, 122, 0.08);
	color: var(--ltd-portal-primary-dark);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.ltd-portal__auth-points {
	list-style: none;
	margin: 1rem 0 0;
	padding: 0;
	display: grid;
	gap: 0.75rem;
}

.ltd-portal__auth-points li {
	position: relative;
	padding-left: 1.35rem;
	font-size: 0.96rem;
	line-height: 1.65;
	color: var(--ltd-portal-muted);
}

.ltd-portal__auth-points li::before {
	content: '';
	position: absolute;
	top: 0.62rem;
	left: 0;
	width: 0.55rem;
	height: 0.55rem;
	border-radius: 999px;
	background: linear-gradient(180deg, #f97316 0%, #fbbf24 100%);
	box-shadow: 0 0 0 5px rgba(249, 115, 22, 0.12);
}

.ltd-portal__auth-side-stat {
	display: block;
	margin-bottom: 0.55rem;
	font-size: 1.15rem;
	font-weight: 800;
	letter-spacing: -0.03em;
	color: var(--ltd-portal-text);
}

.ltd-portal__form-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.9rem;
	flex-wrap: wrap;
}

.ltd-portal__logout-wrap {
	margin: 0;
}

.ltd-portal__logout {
	background: #fff;
	color: var(--ltd-portal-error);
	border-color: rgba(185, 28, 28, 0.16);
	box-shadow: 0 10px 22px rgba(15, 23, 42, 0.06);
}

.ltd-portal__logout:hover {
	background: #fef2f2;
	border-color: rgba(185, 28, 28, 0.28);
	color: var(--ltd-portal-error);
}

.ltd-required {
	color: var(--ltd-portal-error);
}

@media (max-width: 1024px) {
	.ltd-portal__auth-layout,
	.ltd-portal__layout {
		grid-template-columns: 1fr;
	}

	.ltd-portal__hero {
		flex-direction: column;
		align-items: stretch;
	}

	.ltd-portal__hero-chips {
		justify-content: flex-start;
		max-width: none;
	}
}

@media (max-width: 768px) {
	.ltd-portal-page__content {
		margin-top: clamp(-2rem, -4vw, -2.6rem);
	}

	.ltd-portal-page-hero__signals,
	.ltd-portal__hero-chips {
		gap: 0.55rem;
	}

	.ltd-portal__hero,
	.ltd-portal__card,
	.ltd-portal__section-card {
		border-radius: 24px;
	}

	.ltd-portal__card,
	.ltd-portal__section-card {
		padding: 1.2rem;
	}

	.ltd-portal__auth-side-card {
		padding: 1.15rem;
	}

	.ltd-portal__grid {
		grid-template-columns: 1fr;
	}

	.ltd-portal__field--span-2 {
		grid-column: auto;
	}

	.ltd-portal__checkboxes,
	.ltd-portal__town-list {
		grid-template-columns: 1fr;
	}

}

@media (max-width: 480px) {
	.ltd-portal-page__section {
		padding-bottom: 3.25rem;
	}

	.ltd-portal__heading {
		font-size: clamp(1.45rem, 8vw, 2rem);
	}

	.ltd-portal__hero-chip,
	.ltd-portal-page-hero__signal,
	.ltd-portal__btn,
	.ltd-portal__logout {
		width: 100%;
	}

	.ltd-portal__actions {
		flex-direction: column;
	}
}
