:root {
	--bg: #0e1116;
	--card: #161b22;
	--border: #272e38;
	--fg: #e6edf3;
	--muted: #8b949e;
	--accent: #3ddc97;
	--accent-fg: #07130d;
	--danger: #ff6b6b;
}

* {
	box-sizing: border-box;
}

body {
	margin: 0;
	min-height: 100vh;
	background: var(--bg);
	color: var(--fg);
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding: 48px 16px;
}

.card {
	width: 100%;
	max-width: 640px;
	background: var(--card);
	border: 1px solid var(--border);
	border-radius: 14px;
	padding: 32px;
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
}

.head {
	display: flex;
	align-items: baseline;
	gap: 12px;
	border-bottom: 1px solid var(--border);
	padding-bottom: 16px;
	margin-bottom: 24px;
}

.brand {
	font-weight: 800;
	letter-spacing: 1px;
}

.sub {
	color: var(--muted);
	font-size: 13px;
}

h1 {
	font-size: 22px;
	margin: 0 0 16px;
}

h2 {
	font-size: 15px;
	margin: 24px 0 10px;
	color: var(--muted);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.muted {
	color: var(--muted);
}

.small {
	font-size: 12px;
}

.view.hidden {
	display: none;
}

.grant {
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: 8px 16px;
	margin: 0 0 8px;
	font-size: 14px;
}

.grant dt {
	color: var(--muted);
}

.grant dd {
	margin: 0;
	word-break: break-word;
}

.terms {
	max-height: 280px;
	overflow-y: auto;
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 16px;
	font-size: 13.5px;
	line-height: 1.6;
	background: #0c1015;
}

.terms p {
	margin: 0 0 12px;
}

.accept {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin: 18px 0;
	font-size: 14px;
	cursor: pointer;
}

.accept input {
	margin-top: 3px;
}

.btn {
	background: var(--accent);
	color: var(--accent-fg);
	border: none;
	border-radius: 8px;
	font-weight: 700;
	font-size: 15px;
	padding: 12px 20px;
	cursor: pointer;
}

.btn.small {
	font-size: 13px;
	padding: 8px 14px;
}

.btn:disabled {
	opacity: 0.45;
	cursor: not-allowed;
}

.btn:not(:disabled):hover {
	filter: brightness(1.05);
}

.token-row {
	display: flex;
	gap: 8px;
	align-items: center;
	margin: 8px 0;
}

.token {
	flex: 1;
	background: #0c1015;
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 12px 14px;
	font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
	font-size: 13px;
	word-break: break-all;
	color: var(--accent);
}

.steps {
	padding-left: 20px;
	line-height: 1.8;
	font-size: 14px;
}

.steps code {
	background: #0c1015;
	border: 1px solid var(--border);
	border-radius: 5px;
	padding: 1px 6px;
	font-size: 12.5px;
}

a {
	color: var(--accent);
}

.spinner {
	width: 28px;
	height: 28px;
	border: 3px solid var(--border);
	border-top-color: var(--accent);
	border-radius: 50%;
	margin: 8px 0 16px;
	animation: spin 0.8s linear infinite;
}

@keyframes spin {
	to {
		transform: rotate(360deg);
	}
}
