:root {
	--cap-primary: #2563eb;
	--cap-primary-dark: #1d4ed8;
	--cap-accent: #3b82f6;
	--cap-text: #0f172a;
	--cap-muted: #64748b;
	--cap-border: #e6ebf5;
	--cap-input-border: #d6deec;
	--cap-input-bg: #ffffff;
	--cap-frame-bg: #ffffff;
	--cap-page-bg: radial-gradient(
			60% 50% at 12% 8%,
			rgba(244, 196, 214, 0.45),
			transparent 60%
		),
		radial-gradient(55% 45% at 90% 12%, rgba(186, 222, 255, 0.5), transparent 60%),
		radial-gradient(60% 55% at 86% 92%, rgba(214, 200, 240, 0.42), transparent 62%),
		linear-gradient(135deg, #eef1f8 0%, #f6f8fd 100%);
	--cap-visual-bg: radial-gradient(
		120% 90% at 50% 0%,
		#f4f8ff 0%,
		#dde9fd 55%,
		#c6dafb 100%
	);
	--cap-ring: rgba(37, 99, 235, 0.18);
	--cap-badge-bg: #ffffff;
	--cap-caption: #3b5b8c;
	--cap-dot: rgba(37, 99, 235, 0.25);
	--cap-grid-dot: rgba(37, 99, 235, 0.16);
	--cap-toggle-bg: rgba(255, 255, 255, 0.65);
	--cap-toggle-border: rgba(37, 99, 235, 0.18);
	--cap-toggle-icon: #2563eb;
}

[data-capline-login-theme="dark"] {
	--cap-primary: #3b82f6;
	--cap-primary-dark: #2563eb;
	--cap-accent: #60a5fa;
	--cap-text: #e8eefb;
	--cap-muted: #94a3b8;
	--cap-border: #1c2740;
	--cap-input-border: #2a3a5c;
	--cap-input-bg: #0e1626;
	--cap-frame-bg: #0b1220;
	--cap-page-bg: linear-gradient(135deg, #060b15 0%, #0a1120 100%);
	--cap-visual-bg: radial-gradient(
		120% 90% at 50% 0%,
		#13284a 0%,
		#0d1c33 60%,
		#0a1526 100%
	);
	--cap-ring: rgba(96, 165, 250, 0.22);
	--cap-badge-bg: #f5f8ff;
	--cap-caption: #9bb6e6;
	--cap-dot: rgba(96, 165, 250, 0.3);
	--cap-grid-dot: rgba(96, 165, 250, 0.18);
	--cap-toggle-bg: rgba(255, 255, 255, 0.08);
	--cap-toggle-border: rgba(255, 255, 255, 0.16);
	--cap-toggle-icon: #cfe0ff;
}

body.capline-login-page {
	background: var(--cap-page-bg);
	font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
		sans-serif;
	color: var(--cap-text);
}

body.capline-login-page .web-footer,
body.capline-login-page .navbar,
body.capline-login-page .page-breadcrumbs {
	display: none !important;
}

body.capline-login-page main.container {
	max-width: none;
	margin: 0 !important;
	padding: 0 !important;
}

body.capline-login-page .page-content-wrapper {
	padding: 0;
}

/* ---------- Framed split-screen shell ---------- */
.capline-login {
	position: relative;
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	width: calc(100% - 48px);
	max-width: 1160px;
	min-height: calc(100vh - 64px);
	margin: 32px auto;
	padding: 14px;
	background: var(--cap-frame-bg);
	border: 1px solid var(--cap-border);
	border-radius: 30px;
	box-shadow: 0 40px 90px rgba(2, 32, 96, 0.12);
}

/* ---------- Theme toggle ---------- */
.capline-theme-toggle {
	position: absolute;
	top: 26px;
	right: 26px;
	z-index: 10;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	padding: 0;
	border: 1px solid var(--cap-toggle-border);
	border-radius: 50%;
	background: var(--cap-toggle-bg);
	color: var(--cap-toggle-icon);
	cursor: pointer;
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	transition: transform 0.15s ease, background 0.2s ease, border-color 0.2s ease;
}

.capline-theme-toggle:hover {
	transform: translateY(-1px);
}

.capline-theme-toggle:active {
	transform: scale(0.94);
}

.capline-theme-toggle svg {
	width: 18px;
	height: 18px;
}

.capline-theme-toggle__moon {
	display: block;
}

.capline-theme-toggle__sun {
	display: none;
}

[data-capline-login-theme="dark"] .capline-theme-toggle__moon {
	display: none;
}

[data-capline-login-theme="dark"] .capline-theme-toggle__sun {
	display: block;
}

@media (max-width: 575px) {
	.capline-theme-toggle {
		top: 16px;
		right: 16px;
	}
}

@media (min-width: 992px) {
	.capline-login {
		grid-template-columns: 1fr 1fr;
		column-gap: 18px;
	}
}

@media (max-width: 575px) {
	.capline-login {
		width: calc(100% - 24px);
		margin: 16px auto;
		min-height: calc(100vh - 32px);
		padding: 8px;
		border-radius: 24px;
	}
}

/* ---------- Left: form panel ---------- */
.capline-login__panel {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 40px 40px 32px;
}

@media (max-width: 575px) {
	.capline-login__panel {
		padding: 72px 22px 32px;
	}
}

.capline-login__brandbar {
	position: absolute;
	top: 26px;
	left: 30px;
	display: flex;
	align-items: center;
	gap: 9px;
}

.capline-login__brandbar-logo {
	height: 26px;
	width: auto;
}

.capline-login__brandbar-name {
	color: var(--cap-text);
	font-size: 15px;
	font-weight: 600;
	letter-spacing: -0.01em;
}

.capline-login__card {
	width: 100%;
	max-width: 360px;
	animation: capline-rise 0.4s ease-out both;
}

/* Badge + dotted grid */
.capline-login__badge-wrap {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 92px;
	margin-bottom: 14px;
}

.capline-login__grid {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 200px;
	height: 130px;
	transform: translate(-50%, -50%);
	background-image: radial-gradient(var(--cap-grid-dot) 1.2px, transparent 1.2px);
	background-size: 15px 15px;
	-webkit-mask-image: radial-gradient(ellipse 55% 60% at center, #000 25%, transparent 72%);
	mask-image: radial-gradient(ellipse 55% 60% at center, #000 25%, transparent 72%);
	pointer-events: none;
}

.capline-login__badge {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 54px;
	height: 54px;
	border-radius: 16px;
	color: #fff;
	background: linear-gradient(160deg, var(--cap-accent), var(--cap-primary));
	box-shadow: 0 14px 26px rgba(37, 99, 235, 0.38);
}

.capline-login__badge svg {
	width: 26px;
	height: 26px;
}

/* Section headings */
.capline-login__card-head {
	margin-bottom: 24px;
	text-align: center;
}

.capline-login__card-title {
	margin: 0 0 6px;
	color: var(--cap-text);
	font-size: 22px;
	font-weight: 700;
	line-height: 1.25;
	letter-spacing: -0.01em;
}

.capline-login__card-subtitle {
	margin: 0;
	color: var(--cap-muted);
	font-size: 13px;
	line-height: 1.5;
}

.capline-login .page-card-head {
	display: none;
}

.capline-login .login-content.page-card {
	padding: 0;
	border: 0;
	background: transparent;
	box-shadow: none;
}

.capline-login .page-card-body {
	padding: 0;
}

/* ---------- Form fields ---------- */
.capline-login .form-group {
	margin-bottom: 0.9rem;
}

.capline-login .form-label {
	display: block;
	margin-bottom: 0.4rem;
	color: var(--cap-text);
	font-size: 0.8rem;
	font-weight: 600;
}

.capline-field {
	position: relative;
}

.capline-field__icon {
	position: absolute;
	top: 50%;
	left: 13px;
	transform: translateY(-50%);
	display: flex;
	color: var(--cap-muted);
	pointer-events: none;
}

.capline-field__icon svg {
	width: 18px;
	height: 18px;
}

.capline-login .form-control {
	height: 2.85rem;
	padding: 0.65rem 0.9rem;
	border: 1px solid var(--cap-input-border);
	border-radius: 10px;
	background: var(--cap-input-bg);
	color: var(--cap-text);
	font-size: 0.92rem;
	box-shadow: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.capline-login .form-control.capline-input {
	padding-left: 40px;
}

.capline-login .password-field .form-control.capline-input {
	padding-right: 56px;
}

.capline-login .form-control::placeholder {
	color: var(--cap-muted);
	opacity: 0.75;
}

.capline-login .form-control:focus {
	border-color: var(--cap-primary);
	box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.16);
	outline: none;
}

.capline-login .field-icon {
	display: none;
}

.capline-login .toggle-password {
	position: absolute;
	top: 50%;
	right: 0.85rem;
	transform: translateY(-50%);
	color: var(--cap-muted);
	font-size: 0.78rem;
	font-weight: 600;
	cursor: pointer;
	user-select: none;
}

/* ---------- Remember / forgot row ---------- */
.capline-form-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 0.6rem;
}

.capline-remember {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0;
	color: var(--cap-muted);
	font-size: 0.8rem;
	font-weight: 500;
	cursor: pointer;
}

.capline-remember__input {
	width: 15px;
	height: 15px;
	margin: 0;
	accent-color: var(--cap-primary);
	cursor: pointer;
}

.capline-forgot-link,
.capline-login .sign-up-message a,
.capline-login .blue {
	color: var(--cap-primary);
	font-size: 0.8rem;
	font-weight: 600;
	text-decoration: none;
}

.capline-forgot-link:hover,
.capline-login .sign-up-message a:hover {
	color: var(--cap-primary-dark);
	text-decoration: underline;
}

/* ---------- Buttons ---------- */
.capline-login .page-card-actions {
	padding: 0;
	margin-top: 1.4rem;
}

.capline-login .btn-primary,
.capline-login .btn-login,
.capline-login .btn-forgot,
.capline-login .btn-signup {
	display: block;
	width: 100%;
	height: 2.85rem;
	border: 0;
	border-radius: 10px;
	background: var(--cap-primary);
	color: #fff;
	font-size: 0.92rem;
	font-weight: 600;
	box-shadow: 0 12px 24px rgba(37, 99, 235, 0.26);
	transition: background 0.2s ease, transform 0.1s ease, box-shadow 0.2s ease;
}

.capline-login .btn-primary:hover,
.capline-login .btn-login:hover,
.capline-login .btn-forgot:hover,
.capline-login .btn-signup:hover,
.capline-login .btn-primary:focus,
.capline-login .btn-login:focus {
	background: var(--cap-primary-dark);
	color: #fff;
	box-shadow: 0 14px 28px rgba(37, 99, 235, 0.32);
}

.capline-login .btn-primary:active,
.capline-login .btn-login:active,
.capline-login .btn-forgot:active,
.capline-login .btn-signup:active {
	transform: scale(0.97);
}

.capline-login .sign-up-message {
	margin-top: 1.2rem;
	color: var(--cap-muted);
	font-size: 0.85rem;
	text-align: center;
}

.capline-login section {
	display: none;
}

/* ---------- Right: orbit visual ---------- */
.capline-visual {
	display: none;
}

@media (min-width: 992px) {
	.capline-visual {
		display: flex;
	}
}

.capline-visual__card {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: 44px 40px 32px;
	border-radius: 22px;
	background: var(--cap-visual-bg);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
	overflow: hidden;
	animation: capline-rise 0.4s ease-out both;
}

.capline-visual__head {
	text-align: center;
}

.capline-visual__title {
	margin: 0;
	color: var(--cap-text);
	font-size: 26px;
	font-weight: 700;
	letter-spacing: -0.02em;
}

.capline-visual__title span {
	color: var(--cap-primary);
}

.capline-orbit {
	position: relative;
	width: 340px;
	height: 340px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.orbit-ring {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	border: 1px solid var(--cap-ring);
	border-radius: 50%;
	pointer-events: none;
}

.orbit-ring--1 {
	width: 168px;
	height: 168px;
}

.orbit-ring--2 {
	width: 268px;
	height: 268px;
}

.orbit-ring--3 {
	width: 340px;
	height: 340px;
	opacity: 0.55;
}

.orbit-core {
	position: relative;
	z-index: 3;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 86px;
	height: 86px;
	border-radius: 50%;
	background: linear-gradient(160deg, var(--cap-accent), var(--cap-primary));
	box-shadow: 0 16px 36px rgba(37, 99, 235, 0.5);
}

.orbit-core__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: #fff;
}

.orbit-core__inner img {
	max-width: 42px;
	max-height: 42px;
	width: auto;
	height: auto;
}

.orbit-layer {
	position: absolute;
	top: 50%;
	left: 50%;
	width: calc(var(--radius) * 2);
	height: calc(var(--radius) * 2);
	margin-top: calc(var(--radius) * -1);
	margin-left: calc(var(--radius) * -1);
	z-index: 2;
	animation: capline-orbit var(--dur) linear infinite;
}

.orbit-layer--inner {
	--radius: 84px;
	--dur: 22s;
}

.orbit-layer--outer {
	--radius: 134px;
	--dur: 38s;
	animation-direction: reverse;
}

.orbit-item {
	position: absolute;
	top: 0;
	left: 50%;
	width: 42px;
	height: 42px;
	margin-left: -21px;
	transform: rotate(var(--angle));
	transform-origin: 21px var(--radius);
}

.orbit-badge-tilt {
	width: 100%;
	height: 100%;
	transform: rotate(calc(var(--angle) * -1));
}

.orbit-badge {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	background: var(--cap-badge-bg);
	box-shadow: 0 8px 18px rgba(2, 40, 120, 0.18);
	animation: capline-orbit-rev var(--dur) linear infinite;
}

.orbit-layer--outer .orbit-badge {
	animation-direction: reverse;
}

.orbit-badge svg {
	width: 22px;
	height: 22px;
	display: block;
}

.capline-visual__foot {
	width: 100%;
	max-width: 380px;
	text-align: center;
}

.capline-visual__caption {
	margin: 0;
	color: var(--cap-caption);
	font-size: 13px;
	font-style: italic;
	line-height: 1.6;
}

.capline-dots {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	margin-top: 18px;
}

.capline-dot {
	width: 8px;
	height: 8px;
	border-radius: 9px;
	background: var(--cap-dot);
	transition: width 0.3s ease, background 0.3s ease;
}

.capline-dot--active {
	width: 22px;
	background: var(--cap-primary);
}

/* ---------- Animations ---------- */
@keyframes capline-orbit {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

@keyframes capline-orbit-rev {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(-360deg);
	}
}

@keyframes capline-rise {
	from {
		opacity: 0;
		transform: translateY(16px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes capline-shake {
	0%,
	100% {
		transform: translateX(0);
	}
	20%,
	60% {
		transform: translateX(-6px);
	}
	40%,
	80% {
		transform: translateX(6px);
	}
}

.capline-login .login-content.page-card.invalid-login {
	animation: capline-shake 0.3s ease;
}

@media (prefers-reduced-motion: reduce) {
	.orbit-layer,
	.orbit-badge,
	.capline-login__card,
	.capline-visual__card,
	.capline-login .login-content.page-card.invalid-login {
		animation: none !important;
	}

	.capline-login__card,
	.capline-visual__card {
		opacity: 1;
		transform: none;
	}
}
