/* Wye Gateway Certifications - frontend portal styles */
.wgc-portal, .wgc-auth-wrap, .wgc-card { box-sizing: border-box; }
.wgc-portal *, .wgc-auth-wrap *, .wgc-card * { box-sizing: border-box; }

:root {
	--wgc-bg: #f8f8f8;
	--wgc-card: #ffffff;
	--wgc-ink: #3b3b3b;
	--wgc-muted: #6b6b6b;
	--wgc-border: #e4e4e4;
	--wgc-primary: #df202e;
	--wgc-primary-dark: #b71b27;
	--wgc-dark: #3b3b3b;
	--wgc-radius: 14px;
	--wgc-shadow: 0 10px 30px rgba(59, 59, 59, 0.10);
}

html body{
    background: linear-gradient(to bottom, #020202 100px, transparent 100px);
}


/* ---------- Auth ---------- */
.wgc-auth-wrap {
	display: flex;
	justify-content: center;
	padding: 32px 16px;
	background: var(--wgc-bg);
	border-radius: var(--wgc-radius);
}
html .page-content .wgc-auth-wrap a,
html .page-content .wgc-portal a {
    text-decoration: none;
}
.wgc-auth-card { width: 100%; max-width: 440px; }
.wgc-auth-head { text-align: center; margin-bottom: 18px; }
.wgc-auth-head h2 { margin: 8px 0 4px; color: var(--wgc-ink); font-size: 24px; }
.wgc-badge {
	display: inline-block;
	background: rgba(223, 32, 46, 0.1);
	color: var(--wgc-primary-dark);
	font-size: 12px; font-weight: 600;
	padding: 4px 12px; border-radius: 999px;
	text-transform: uppercase; letter-spacing: 0.04em;
}
.wgc-auth-foot { text-align: center; margin-top: 16px; color: var(--wgc-muted); font-size: 14px; }

/* ---------- Cards ---------- */
.wgc-card {
	background: var(--wgc-card);
	border: 1px solid var(--wgc-border);
	border-radius: var(--wgc-radius);
	box-shadow: var(--wgc-shadow);
	padding: 24px;
	margin-bottom: 20px;
}
.wgc-card-title { margin: 0 0 16px; font-size: 18px; color: var(--wgc-ink); }
.wgc-text-center { text-align: center; }

/* ---------- Forms ---------- */
.wgc-form { display: flex; flex-direction: column; gap: 14px; }
.wgc-field { display: flex; flex-direction: column; gap: 6px; font-size: 14px; }
.wgc-field > span { font-weight: 600; color: var(--wgc-ink); }
.wgc-field input,
.wgc-field textarea,
.wgc-field select {
	width: 100%;
	padding: 11px 13px;
	border: 1px solid var(--wgc-border);
	border-radius: 10px;
	font-size: 14px;
	background: #fff;
	color: var(--wgc-ink);
	transition: border-color .15s, box-shadow .15s;
}
.wgc-field input:focus,
.wgc-field textarea:focus,
.wgc-field select:focus {
	outline: none;
	border-color: var(--wgc-primary);
	box-shadow: 0 0 0 3px rgba(223, 32, 46, 0.15);
}
.wgc-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.wgc-row-between { display: flex; align-items: center; justify-content: space-between; font-size: 14px; }
.wgc-checkbox { display: inline-flex; align-items: center; gap: 6px; color: var(--wgc-muted); }
.wgc-hr { border: none; border-top: 1px solid var(--wgc-border); margin: 6px 0; }
.wgc-muted { color: var(--wgc-muted); }
.wgc-link { color: var(--wgc-primary); text-decoration: none; }
.wgc-link:hover { text-decoration: underline; }

/* ---------- Buttons ---------- */
.wgc-btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: 8px; cursor: pointer;
	border: 1px solid transparent; border-radius: 10px;
	padding: 11px 18px; font-size: 14px; font-weight: 600;
	text-decoration: none; line-height: 1;
	transition: background .15s, transform .05s, box-shadow .15s;
}
.wgc-btn:active { transform: translateY(1px); }
.wgc-btn-primary { background: var(--wgc-primary); color: #fff; }
.wgc-btn-primary:hover { background: var(--wgc-primary-dark); color: #fff; }
.wgc-btn-ghost { background: #fff; color: var(--wgc-ink); border-color: var(--wgc-border); }
.wgc-btn-ghost:hover { background: #f8fafc; }
.wgc-btn-danger { background: #fee2e2; color: #b91c1c; }
.wgc-btn-danger:hover { background: #fecaca; }
.wgc-btn-block { width: 100%; }
.wgc-btn-sm { padding: 7px 12px; font-size: 13px; }
.wgc-btn-group { display: flex; gap: 10px; flex-wrap: wrap; }
.wgc-justify-center { justify-content: center; }
.wgc-btn[disabled] { opacity: .6; cursor: not-allowed; }

/* ---------- Alerts ---------- */
.wgc-alert { padding: 12px 14px; border-radius: 10px; font-size: 14px; margin-bottom: 14px; }
.wgc-alert-success { background: #dcfce7; color: #166534; }
.wgc-alert-error { background: #fee2e2; color: #991b1b; }
.wgc-alert-info { background: #e0f2fe; color: #075985; }
.wgc-form-msg:empty { display: none; }
.wgc-form-msg { font-size: 14px; padding: 4px 0; }
.wgc-form-msg.is-error { color: #b91c1c; }
.wgc-form-msg.is-success { color: #166534; }

/* ---------- Portal layout ---------- */
.wgc-portal {
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 22px;
	background: var(--wgc-bg);
	padding: 22px;
	border-radius: var(--wgc-radius);
	margin-bottom: 30px;
}
.wgc-portal-side {
	background: var(--wgc-card);
	border: 1px solid var(--wgc-border);
	border-radius: var(--wgc-radius);
	box-shadow: var(--wgc-shadow);
	padding: 18px;
	height: fit-content;
	position: sticky; top: 20px;
}
.wgc-portal-user { display: flex; gap: 12px; align-items: center; padding-bottom: 16px; border-bottom: 1px solid var(--wgc-border); margin-bottom: 12px; }
.wgc-portal-user strong { display: block; color: var(--wgc-ink); font-size: 15px; }
.wgc-portal-user .wgc-muted { font-size: 12px; }
.wgc-avatar {
	width: 44px; height: 44px; border-radius: 12px;
	background: var(--wgc-primary); color: #fff;
	display: flex; align-items: center; justify-content: center;
	font-weight: 700; font-size: 18px; flex-shrink: 0;
}
.wgc-portal-nav { display: flex; flex-direction: column; gap: 4px; }
.wgc-nav-link {
	padding: 10px 12px; border-radius: 9px;
	color: var(--wgc-ink); text-decoration: none; font-size: 14px; font-weight: 500;
}
.wgc-nav-link:hover { background: #f8f8f8; }
.wgc-nav-link.is-active { background: var(--wgc-primary); color: #fff; }
.wgc-nav-logout { color: #b91c1c; margin-top: 8px; }

/* ---------- Stats ---------- */
.wgc-page-head h2 { margin: 0 0 4px; color: var(--wgc-ink); }
.wgc-page-head { margin-bottom: 18px; }
.wgc-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 20px; }
.wgc-stat {
	background: var(--wgc-card);
	border: 1px solid var(--wgc-border);
	border-left: 4px solid var(--wgc-primary);
	border-radius: 12px; padding: 18px;
	box-shadow: var(--wgc-shadow);
	display: flex; flex-direction: column; gap: 4px;
}
.wgc-stat-num { font-size: 28px; font-weight: 700; color: var(--wgc-ink); }
.wgc-stat-label { font-size: 13px; color: var(--wgc-muted); }
.wgc-stat-green { border-left-color: #16a34a; }
.wgc-stat-amber { border-left-color: #d97706; }
.wgc-stat-red { border-left-color: #dc2626; }
.wgc-quick-actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* ---------- Table ---------- */
.wgc-table-wrap { overflow-x: auto; }
.wgc-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.wgc-table th, .wgc-table td { text-align: left; padding: 12px 14px; border-bottom: 1px solid var(--wgc-border); vertical-align: middle; }
.wgc-table th { font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--wgc-muted); }
.wgc-table tbody tr:hover { background: #f8fafc; }
.wgc-sub { font-size: 12px; color: var(--wgc-muted); }
.wgc-col-actions { white-space: nowrap; text-align: right; }
.wgc-empty { text-align: center; padding: 32px; color: var(--wgc-muted); }

/* ---------- Status & pills ---------- */
.wgc-status { display: inline-block; padding: 4px 10px; border-radius: 999px; font-size: 12px; font-weight: 600; }
.wgc-status-pending { background: #fef9c3; color: #854d0e; }
.wgc-status-approved { background: #dcfce7; color: #166534; }
.wgc-status-rejected { background: #fee2e2; color: #991b1b; }
.wgc-status-expired { background: #f0f0f0; color: #6b6b6b; }
.wgc-pill { display: inline-block; padding: 2px 8px; border-radius: 999px; font-size: 11px; font-weight: 600; margin-left: 6px; }
.wgc-pill-red { background: #fee2e2; color: #b91c1c; }
.wgc-pill-amber { background: #fef3c7; color: #92400e; }

/* ---------- Responsive ---------- */
@media (max-width: 860px) {
	.wgc-portal { grid-template-columns: 1fr; }
	.wgc-portal-side { position: static; }
	.wgc-portal-nav { flex-direction: row; flex-wrap: wrap; }
	.wgc-stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
	.wgc-grid-2 { grid-template-columns: 1fr; }
	.wgc-stats-grid { grid-template-columns: 1fr; }
}
