/**
 * DP Account Pages — Sign In / Account / Thank You
 *
 * Colour variables below are a starting point, pulled from the Donate Positive
 * plugin's "Redesign" appearance settings (primary navy / accent green).
 * Adjust to match the final Divi design once compared side-by-side.
 */
:root {
	--dp-primary:   #1a3353;
	--dp-accent:    #22c55e;
	--dp-accent-dark: #16a34a;
	--dp-danger:    #dc2626;
	--dp-warning:   #92400e;
	--dp-warning-bg: #fef3c7;
	--dp-warning-border: #fde68a;
	--dp-gray-50:   #f9fafb;
	--dp-gray-100:  #f3f4f6;
	--dp-gray-200:  #e5e7eb;
	--dp-gray-400:  #9ca3af;
	--dp-gray-500:  #6b7280;
	--dp-gray-600:  #4b5563;
	--dp-radius:    12px;
}

.dp-account-section {
	padding: 64px 24px;
	display: flex;
	justify-content: center;
}

/* Divi's fixed/floating nav overlaps the top of the page on desktop — push content down to clear it. */
@media (min-width: 601px) {
	.dp-account-section {
		padding-top: 214px;
	}
}

.dp-account-wrap {
	width: 100%;
	max-width: 760px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.dp-account-card {
	width: 100%;
	max-width: 440px;
	margin: 0 auto;
	background: #fff;
	border: 1px solid var(--dp-gray-200);
	border-radius: var(--dp-radius);
	padding: 40px;
}

.dp-account-card--center {
	max-width: 600px;
	text-align: center;
}

.dp-account-card h1,
.dp-account-wrap h1 {
	font-size: 1.75rem;
	margin: 0 0 8px;
	color: var(--dp-primary);
}

.dp-account-lead {
	color: var(--dp-gray-500);
	margin: 0 0 28px;
}

.dp-account-meta {
	margin: 16px 0 0;
	font-size: .9375rem;
	color: var(--dp-gray-500);
	text-align: center;
}

.dp-account-meta a {
	color: var(--dp-primary);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 3px;
}

/* ── Header row (dashboard) ───────────────────────────────────────── */
.dp-account-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 16px;
	flex-wrap: wrap;
}

/* ── Alerts ────────────────────────────────────────────────────────── */
.dp-alert {
	border-radius: 8px;
	padding: 10px 14px;
	font-size: .875rem;
	font-weight: 500;
	margin: 0 0 20px;
}
.dp-alert--error {
	background: #fef2f2;
	border: 1px solid #fecaca;
	color: var(--dp-danger);
}
.dp-alert--warning {
	background: var(--dp-warning-bg);
	border: 1px solid var(--dp-warning-border);
	color: var(--dp-warning);
}
.dp-alert--info {
	background: #eff6ff;
	border: 1px solid #bfdbfe;
	color: #1d4ed8;
}

/* ── Cards (dashboard) ────────────────────────────────────────────── */
.dp-card {
	background: #fff;
	border: 1px solid var(--dp-gray-200);
	border-radius: var(--dp-radius);
	padding: 28px;
}

.dp-card--empty {
	text-align: center;
}
.dp-card--empty h2 {
	color: var(--dp-primary);
	margin-top: 0;
}

.dp-card__top {
	margin-bottom: 16px;
}

.dp-card__title {
	font-size: 1.125rem;
	margin: 8px 0 0;
	color: var(--dp-primary);
}

.dp-card__row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	padding: 12px 0;
	border-top: 1px solid var(--dp-gray-100);
	font-size: .9375rem;
}

.dp-card__label {
	color: var(--dp-gray-500);
	font-weight: 500;
}

.dp-card__actions {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	margin-top: 20px;
}

.dp-card__actions--center {
	justify-content: center;
}

.dp-card__actions form {
	margin: 0;
}

/* ── Badges ────────────────────────────────────────────────────────── */
.dp-badge {
	display: inline-block;
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .02em;
	text-transform: uppercase;
	padding: 4px 10px;
	border-radius: 999px;
}
.dp-badge--success { background: #dcfce7; color: var(--dp-accent-dark); }
.dp-badge--warning  { background: var(--dp-warning-bg); color: var(--dp-warning); }
.dp-badge--error    { background: #fef2f2; color: var(--dp-danger); }
.dp-badge--info     { background: var(--dp-gray-100); color: var(--dp-gray-600); }

/* ── Licence key ───────────────────────────────────────────────────── */
.dp-licence-key {
	display: flex;
	align-items: center;
	gap: 10px;
}
.dp-licence-key code {
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
	font-size: .875rem;
	background: var(--dp-gray-50);
	border: 1px solid var(--dp-gray-200);
	border-radius: 6px;
	padding: 4px 8px;
}

/* ── Buttons / links ───────────────────────────────────────────────── */
.dp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	border-radius: 8px;
	padding: 11px 22px;
	font-size: .9375rem;
	font-weight: 600;
	text-decoration: none;
	border: 1px solid transparent;
	cursor: pointer;
	line-height: 1.2;
}
.dp-btn--primary {
	background: var(--dp-accent);
	color: #fff;
}
.dp-btn--primary:hover { background: var(--dp-accent-dark); }

.dp-btn--outline {
	background: #fff;
	border-color: var(--dp-gray-200);
	color: var(--dp-primary);
}
.dp-btn--outline:hover { border-color: var(--dp-primary); }

.dp-btn--ghost {
	background: transparent;
	color: var(--dp-gray-500);
}
.dp-btn--ghost:hover { color: var(--dp-primary); }

.dp-link-btn {
	background: none;
	border: none;
	padding: 0;
	font-size: .8125rem;
	font-weight: 600;
	color: var(--dp-primary);
	text-decoration: underline;
	text-underline-offset: 2px;
	cursor: pointer;
}

/* ── Success icon (Thank You) ─────────────────────────────────────── */
.dp-success-icon {
	width: 72px;
	height: 72px;
	background: #dcfce7;
	color: var(--dp-accent-dark);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 28px;
}
.dp-success-icon svg {
	width: 36px;
	height: 36px;
}

/* ── Steps (Thank You) ────────────────────────────────────────────── */
.dp-steps {
	background: var(--dp-gray-50);
	border: 1px solid var(--dp-gray-200);
	border-radius: var(--dp-radius);
	padding: 32px;
	text-align: left;
	margin-bottom: 36px;
}
.dp-steps h2 {
	font-size: 1.125rem;
	margin: 0 0 20px;
	color: var(--dp-primary);
}
.dp-steps__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 20px;
}
.dp-steps__list > li {
	display: flex;
	gap: 16px;
	align-items: flex-start;
}
.dp-steps__num {
	width: 28px;
	height: 28px;
	background: var(--dp-primary);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: .8125rem;
	font-weight: 700;
	flex-shrink: 0;
}
.dp-steps__title {
	font-weight: 600;
	margin: 0 0 3px;
}
.dp-steps__text {
	font-size: .9rem;
	color: var(--dp-gray-500);
	margin: 0 0 8px;
}
.dp-steps .dp-alert {
	margin: 0;
}

/* ── Login form (wp_login_form output) ────────────────────────────── */
#loginform p { margin: 0 0 16px; }
#loginform label {
	display: block;
	font-size: .875rem;
	font-weight: 600;
	color: var(--dp-primary);
	margin-bottom: 6px;
}
#loginform input[type="text"],
#loginform input[type="password"] {
	width: 100%;
	padding: 11px 14px;
	border: 1px solid var(--dp-gray-200);
	border-radius: 8px;
	font-size: .9375rem;
	box-sizing: border-box;
}
#loginform input[type="text"]:focus,
#loginform input[type="password"]:focus {
	outline: none;
	border-color: var(--dp-primary);
}
#loginform .login-remember label {
	display: flex;
	align-items: center;
	gap: 8px;
	font-weight: 400;
	color: var(--dp-gray-600);
}
#loginform .login-remember input { margin: 0; }
#loginform .login-submit {
	margin-top: 8px;
}
#loginform .button-primary {
	width: 100%;
	display: block;
	background: var(--dp-accent);
	color: #fff;
	border: none;
	border-radius: 8px;
	padding: 12px 22px;
	font-size: .9375rem;
	font-weight: 600;
	cursor: pointer;
}
#loginform .button-primary:hover { background: var(--dp-accent-dark); }

@media (max-width: 600px) {
	.dp-account-section { padding: 40px 16px; }
	.dp-account-card,
	.dp-card { padding: 24px; }
	.dp-card__row { flex-direction: column; align-items: flex-start; gap: 4px; }
}
