:root {
	--bg: #0b1117;
	--bg-2: #111a24;
	--ink: #e8edf2;
	--muted: #a4afbd;
	--accent: #1fb6a6;
	--accent-2: #ff8a3d;
	--accent-3: #7aa2c6;
	--card: #141c26;
	--card-strong: #1a2430;
	--border: #263343;
	--shadow: 0 30px 60px rgba(0, 0, 0, 0.45);
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

body {
	margin: 0;
	font-family: "IBM Plex Sans", "Segoe UI", sans-serif;
	color: var(--ink);
	background: radial-gradient(circle at 20% 20%, rgba(31, 182, 166, 0.12), transparent 45%),
		linear-gradient(135deg, var(--bg), var(--bg-2));
	min-height: 100vh;
}

h1,
h2,
h3,
h4 {
	font-family: "Space Grotesk", "Segoe UI", sans-serif;
	margin: 0 0 0.6rem;
}

p {
	margin: 0 0 1rem;
	color: var(--muted);
}

a {
	color: inherit;
	text-decoration: none;
}

.portal-body {
	position: relative;
	overflow-x: hidden;
}

.flash-stack {
	position: fixed;
	top: 24px;
	right: 24px;
	display: grid;
	gap: 10px;
	z-index: 10;
	max-width: min(360px, 90vw);
}

.flash {
	background: var(--card-strong);
	border: 1px solid var(--border);
	border-left: 4px solid var(--accent);
	border-radius: 12px;
	padding: 12px 14px;
	box-shadow: var(--shadow);
	font-size: 0.9rem;
}

.flash-error {
	border-left-color: #ff6b6b;
}

.flash-warning {
	border-left-color: #ffb84c;
}

.flash-success {
	border-left-color: #35d49a;
}

.bg-orb {
	position: fixed;
	border-radius: 50%;
	filter: blur(0px);
	opacity: 0.6;
	z-index: 0;
}

.orb-1 {
	width: 380px;
	height: 380px;
	background: radial-gradient(circle, rgba(31, 182, 166, 0.25), transparent 70%);
	top: -120px;
	left: -120px;
}

.orb-2 {
	width: 420px;
	height: 420px;
	background: radial-gradient(circle, rgba(255, 138, 61, 0.22), transparent 70%);
	bottom: -160px;
	right: -140px;
}

.orb-3 {
	width: 260px;
	height: 260px;
	background: radial-gradient(circle, rgba(122, 162, 198, 0.2), transparent 70%);
	top: 45%;
	right: 12%;
}

.portal-shell {
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 32px;
	padding: 32px;
	position: relative;
	z-index: 1;
}

.side-nav {
	background: var(--card);
	border: 1px solid var(--border);
	border-radius: 24px;
	padding: 24px;
	display: flex;
	flex-direction: column;
	gap: 24px;
	position: sticky;
	top: 24px;
	height: fit-content;
	box-shadow: var(--shadow);
}

.brand {
	display: flex;
	align-items: baseline;
	gap: 8px;
}

.brand-mark {
	background: var(--accent);
	color: #fff;
	padding: 6px 10px;
	border-radius: 12px;
	font-weight: 700;
	letter-spacing: 0.04em;
}

.brand-name {
	font-size: 1.1rem;
	font-weight: 600;
}

.nav-group {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.nav-link {
	padding: 10px 14px;
	border-radius: 12px;
	background: transparent;
	color: var(--muted);
	transition: all 0.2s ease;
}

.nav-link:hover {
	background: rgba(15, 110, 106, 0.12);
	color: var(--ink);
}

.side-card {
	background: var(--card-strong);
	border-radius: 18px;
	padding: 18px;
	border: 1px solid var(--border);
}

.portal-main {
	display: flex;
	flex-direction: column;
	gap: 28px;
}

.portal-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 24px;
}

.subtitle {
	max-width: 640px;
}

.header-actions {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}

.panel {
	background: var(--card-strong);
	border: 1px solid var(--border);
	border-radius: 24px;
	padding: 24px;
	box-shadow: var(--shadow);
}

.panel-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 20px;
}

.stats-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 16px;
}

.stat-card {
	background: var(--card);
	border-radius: 18px;
	padding: 16px;
	border: 1px solid var(--border);
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.stat-label {
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--muted);
}

.stat-value {
	font-size: 1.5rem;
	font-weight: 600;
}

.stat-note {
	font-size: 0.85rem;
	color: var(--muted);
}

.status-row {
	margin-top: 20px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 16px;
}

.status-card {
	background: var(--card);
	border-radius: 18px;
	padding: 18px;
	border: 1px solid var(--border);
	display: flex;
	flex-direction: column;
	gap: 12px;
	justify-content: space-between;
}

.status-actions {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.status-highlight {
	border-color: rgba(15, 110, 106, 0.4);
	background: linear-gradient(135deg, rgba(15, 110, 106, 0.18), rgba(20, 28, 38, 0.95));
}

.steps {
	display: grid;
	gap: 6px;
	font-size: 0.9rem;
	color: var(--muted);
}

.key-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.key-card {
	background: var(--card);
	border-radius: 18px;
	padding: 18px;
	border: 1px solid var(--border);
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.key-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}

.key-name {
	font-weight: 600;
}

.key-meta {
	display: grid;
	gap: 6px;
	font-size: 0.9rem;
	color: var(--muted);
}

.key-actions {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.inline-form {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	margin: 0;
}

.empty-state {
	padding: 24px;
	border-radius: 18px;
	border: 1px dashed var(--border);
	background: rgba(15, 20, 28, 0.65);
	text-align: center;
	display: grid;
	gap: 10px;
}

.plans {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
}

.plan-card {
	background: var(--card);
	border-radius: 18px;
	padding: 20px;
	border: 1px solid var(--border);
	display: grid;
	gap: 12px;
	position: relative;
}

.plan-card.plan-selected {
	border-color: var(--accent-2);
	box-shadow: 0 18px 40px rgba(255, 138, 61, 0.18);
}

.plan-featured {
	border: 2px solid var(--accent);
	background: linear-gradient(180deg, rgba(15, 110, 106, 0.18), rgba(20, 28, 38, 0.92));
}

.plan-featured.plan-selected {
	border-color: var(--accent-2);
}

.plan-badge {
	position: absolute;
	top: 16px;
	right: 16px;
	background: var(--accent);
	color: #fff;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 0.75rem;
}

.plan-price {
	font-size: 1.6rem;
	font-weight: 600;
	margin: 0;
}

.plan-price span {
	font-size: 0.9rem;
	color: var(--muted);
}

.plan-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 6px;
	color: var(--muted);
}

.plan-form {
	margin-top: auto;
}

.table {
	display: grid;
	gap: 12px;
}

.table-row {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 10px;
	padding: 12px 14px;
	border-radius: 14px;
	background: var(--card);
	border: 1px solid var(--border);
	align-items: center;
}

.table-head {
	background: transparent;
	border: none;
	padding: 0 4px 8px;
	font-size: 0.85rem;
	color: var(--muted);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.timeline {
	display: grid;
	gap: 14px;
}

.timeline-item {
	display: grid;
	grid-template-columns: 18px 1fr;
	gap: 12px;
	align-items: start;
}

.timeline-dot {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--accent-2);
	margin-top: 6px;
}

.timeline-time {
	font-size: 0.8rem;
	color: var(--muted);
}

.support-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.support-card {
	background: var(--card);
	border: 1px solid var(--border);
	border-radius: 18px;
	padding: 18px;
	display: grid;
	gap: 10px;
}

.referral-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.referral-card {
	background: var(--card);
	border: 1px solid var(--border);
	border-radius: 18px;
	padding: 18px;
	display: grid;
	gap: 12px;
}

.referral-card.stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	text-align: center;
}

.referral-link {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 10px;
}

.referral-link input {
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 10px 12px;
	background: rgba(10, 15, 22, 0.6);
	color: var(--ink);
	font-family: inherit;
}

.btn-primary,
.btn-ghost {
	border: none;
	border-radius: 12px;
	padding: 10px 16px;
	font-weight: 600;
	cursor: pointer;
	transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.btn-primary {
	background: linear-gradient(130deg, var(--accent), #0a7f79);
	color: #fff;
	box-shadow: 0 16px 32px rgba(15, 110, 106, 0.25);
}

.btn-ghost {
	background: rgba(122, 162, 198, 0.12);
	color: #d5e2ef;
}

.btn-primary:hover,
.btn-ghost:hover {
	transform: translateY(-1px);
}

.btn-primary:disabled,
.btn-ghost:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	box-shadow: none;
	transform: none;
}

.btn-full {
	width: 100%;
	justify-content: center;
}

.pill {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 600;
	background: rgba(31, 182, 166, 0.18);
	color: var(--accent);
}

.pill-muted {
	background: rgba(122, 162, 198, 0.15);
	color: #c5d4e3;
}

.pill-accent {
	background: rgba(255, 138, 61, 0.15);
	color: #c25a15;
}

.pill-live {
	background: rgba(15, 110, 106, 0.15);
	color: var(--accent);
}

.pill-warn {
	background: rgba(255, 138, 61, 0.18);
	color: #c25a15;
}

.pill-off {
	background: rgba(27, 60, 89, 0.12);
	color: var(--accent-3);
}

.eyebrow {
	display: inline-flex;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: 0.7rem;
	color: var(--accent-3);
	margin-bottom: 12px;
}

.fade-up {
	animation: fadeUp 0.7s ease both;
	animation-delay: var(--delay, 0s);
}

@keyframes fadeUp {
	from {
		opacity: 0;
		transform: translateY(14px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.login-shell {
	min-height: 100vh;
	display: grid;
	place-items: center;
	padding: 32px;
	position: relative;
	z-index: 1;
}

.login-card {
	display: grid;
	grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
	gap: 24px;
	background: var(--card-strong);
	border-radius: 28px;
	padding: 32px;
	border: 1px solid var(--border);
	box-shadow: var(--shadow);
	max-width: 980px;
	width: 100%;
}

.login-copy h1 {
	font-size: 2.2rem;
}

.login-benefits {
	display: grid;
	gap: 10px;
	margin-top: 20px;
}

.benefit {
	display: flex;
	align-items: center;
	gap: 10px;
	font-weight: 500;
}

.benefit-icon {
	background: rgba(15, 110, 106, 0.12);
	padding: 6px;
	border-radius: 12px;
}

.login-form {
	background: var(--card);
	border-radius: 20px;
	padding: 22px;
	border: 1px solid var(--border);
	display: grid;
	gap: 16px;
}

.form-title h2 {
	margin-bottom: 6px;
}

.field {
	display: grid;
	gap: 8px;
	font-size: 0.9rem;
}

.field input {
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 10px 12px;
	background: rgba(10, 15, 22, 0.6);
	color: var(--ink);
	font-family: inherit;
}

.select-field {
	display: inline-flex;
}

.select-field select {
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 9px 12px;
	background: rgba(10, 15, 22, 0.6);
	color: var(--ink);
	font-family: inherit;
	min-width: 170px;
}

.select-field select:focus {
	outline: none;
	border-color: rgba(31, 182, 166, 0.6);
	box-shadow: 0 0 0 2px rgba(31, 182, 166, 0.2);
}

.field input::placeholder,
.referral-link input::placeholder {
	color: rgba(164, 175, 189, 0.7);
}

.form-hint {
	display: flex;
	justify-content: space-between;
	font-size: 0.85rem;
	color: var(--muted);
}

.link {
	color: var(--accent);
}

.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.portal-body.modal-open {
	overflow: hidden;
}

.qr-modal,
.plan-modal {
	position: fixed;
	inset: 0;
	background: rgba(6, 10, 16, 0.72);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 20;
	padding: 20px;
}

.qr-backdrop,
.plan-backdrop {
	position: absolute;
	inset: 0;
}

.qr-modal[hidden],
.plan-modal[hidden] {
	display: none;
}

.qr-dialog,
.plan-dialog {
	background: var(--card-strong);
	border: 1px solid var(--border);
	border-radius: 20px;
	padding: 20px;
	width: min(420px, 92vw);
	display: grid;
	gap: 12px;
	box-shadow: var(--shadow);
	position: relative;
	z-index: 1;
}

.plan-summary {
	display: grid;
	gap: 10px;
	padding: 12px;
	border-radius: 16px;
	background: var(--card);
	border: 1px solid var(--border);
}

.plan-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 10px;
}

.plan-pay-form {
	margin-top: 4px;
}

.qr-image {
	background: rgba(10, 15, 22, 0.7);
	border: 1px dashed var(--border);
	border-radius: 16px;
	padding: 16px;
	display: grid;
	place-items: center;
}

.qr-image img {
	max-width: 100%;
	height: auto;
	border-radius: 8px;
	background: #fff;
	padding: 8px;
}

.qr-close,
.plan-close {
	position: absolute;
	top: 12px;
	right: 12px;
	border: none;
	background: transparent;
	color: var(--muted);
	font-size: 1.2rem;
	cursor: pointer;
}

@media (max-width: 1024px) {
	.portal-shell {
		grid-template-columns: 1fr;
	}

	.side-nav {
		position: static;
	}

	.portal-header {
		flex-direction: column;
		align-items: flex-start;
	}
}

@media (max-width: 860px) {
	.login-card {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 720px) {
	.portal-shell {
		padding: 20px;
	}

	.table-row {
		grid-template-columns: 1fr 1fr;
		grid-auto-rows: auto;
	}

	.referral-card.stats {
		grid-template-columns: 1fr;
	}

	.portal-header {
		gap: 12px;
	}
}
