/**
 * Webbiverse Island Design System — v1.0
 *
 * Shared visual foundation for all Webbiverse islands.
 * Provides: tokens, base styles, components, animations, login page.
 *
 * Colors are injected via PHP (class-island-hardening.php) so per-island
 * accent colors cascade automatically through color-mix() derivatives.
 *
 * @package webbiverse-island-core
 * @since   1.1.0
 */

/* ================================================================
   TOKEN COMPUTATION — derived from PHP-injected --wbv-accent
   ================================================================ */

:root {
	/* ─ Accent derivatives ─ */
	--wbv-accent-soft:  color-mix(in srgb, var(--wbv-accent) 15%, transparent);
	--wbv-accent-glow:  color-mix(in srgb, var(--wbv-accent) 45%, transparent);
	--wbv-accent-hover: color-mix(in srgb, var(--wbv-accent) 82%, white);
	--wbv-accent-deep:  color-mix(in srgb, var(--wbv-accent) 80%, black);

	/* ─ Surfaces ─ */
	--wbv-surface-glass:  rgba(255, 255, 255, 0.03);
	--wbv-surface-hover:  rgba(255, 255, 255, 0.06);
	--wbv-surface-active: rgba(255, 255, 255, 0.10);

	/* ─ Borders ─ */
	--wbv-border:        rgba(255, 255, 255, 0.08);
	--wbv-border-strong: rgba(255, 255, 255, 0.16);
	--wbv-border-accent: color-mix(in srgb, var(--wbv-accent) 30%, transparent);

	/* ─ Shadows ─ */
	--wbv-shadow:      0 4px 24px rgba(0, 0, 0, 0.30);
	--wbv-shadow-lg:   0 12px 48px rgba(0, 0, 0, 0.40);
	--wbv-shadow-glow: 0 0 30px var(--wbv-accent-glow);

	/* ─ Layout ─ */
	--wbv-radius:      12px;
	--wbv-radius-sm:   8px;
	--wbv-radius-lg:   20px;
	--wbv-radius-pill: 999px;
	--wbv-shell:       1200px;
	--wbv-gap:         1.5rem;

	/* ─ Motion ─ */
	--wbv-ease:       cubic-bezier(0.4, 0, 0.2, 1);
	--wbv-speed:      200ms;
	--wbv-speed-slow: 400ms;

	/* ─ Glass ─ */
	--wbv-glass-blur: 16px;
	--wbv-glass-bg:   rgba(2, 28, 64, 0.50);

	/* ─ Semantic ─ */
	--wbv-success: #22c55e;
	--wbv-warning: #f59e0b;
	--wbv-danger:  #ef4444;
	--wbv-info:    #3b82f6;
}


/* ================================================================
   BASE — intentionally minimal.  Each island theme owns its own
   body / a / ::selection styles.  The design system only provides
   tokens (above) and opt-in .wbv-* component classes (below).
   ================================================================ */


/* ================================================================
   TYPOGRAPHY — utility classes only (no bare element resets)
   ================================================================ */

.wbv-gradient-text {
	background: linear-gradient(135deg, var(--wbv-text, #fff) 40%, var(--wbv-accent) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.wbv-text-muted  { color: var(--wbv-text-muted, #94a3b8); }
.wbv-text-center  { text-align: center; }
.wbv-text-sm      { font-size: 0.875rem; }
.wbv-text-xs      { font-size: 0.75rem; }
.wbv-text-lg      { font-size: 1.125rem; }
.wbv-text-xl      { font-size: 1.5rem; }
.wbv-fw-500       { font-weight: 500; }
.wbv-fw-600       { font-weight: 600; }
.wbv-fw-700       { font-weight: 700; }


/* ================================================================
   LAYOUT HELPERS
   ================================================================ */

.wbv-shell {
	max-width: var(--wbv-shell);
	margin: 0 auto;
	padding: 0 1.5rem;
}

.wbv-flex        { display: flex; }
.wbv-flex-col    { flex-direction: column; }
.wbv-flex-center { align-items: center; justify-content: center; }
.wbv-flex-between { align-items: center; justify-content: space-between; }
.wbv-gap-sm      { gap: 0.5rem; }
.wbv-gap         { gap: var(--wbv-gap); }
.wbv-gap-lg      { gap: 2rem; }

.wbv-grid   { display: grid; gap: var(--wbv-gap); }
.wbv-grid-2 { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); }
.wbv-grid-3 { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.wbv-grid-4 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }


/* ================================================================
   CARDS — glassmorphic
   ================================================================ */

.wbv-card {
	background: var(--wbv-glass-bg);
	backdrop-filter: blur(var(--wbv-glass-blur));
	-webkit-backdrop-filter: blur(var(--wbv-glass-blur));
	border: 1px solid var(--wbv-border);
	border-radius: var(--wbv-radius);
	box-shadow: var(--wbv-shadow);
	transition:
		transform var(--wbv-speed) var(--wbv-ease),
		border-color var(--wbv-speed) var(--wbv-ease),
		box-shadow var(--wbv-speed) var(--wbv-ease);
}
.wbv-card:hover {
	transform: translateY(-2px);
	border-color: var(--wbv-border-accent);
	box-shadow: var(--wbv-shadow-lg);
}
.wbv-card-static:hover {
	transform: none;
}

.wbv-card-header {
	padding: 1.25rem 1.5rem;
	border-bottom: 1px solid var(--wbv-border);
	font-weight: 600;
}
.wbv-card-body   { padding: 1.5rem; }
.wbv-card-footer {
	padding: 1rem 1.5rem;
	border-top: 1px solid var(--wbv-border);
}


/* ================================================================
   BUTTONS
   ================================================================ */

.wbv-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.625rem 1.25rem;
	font-family: inherit;
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1;
	border: 1px solid transparent;
	border-radius: var(--wbv-radius-sm);
	cursor: pointer;
	transition: all var(--wbv-speed) var(--wbv-ease);
	text-decoration: none;
	white-space: nowrap;
}
.wbv-btn:focus-visible {
	outline: 2px solid var(--wbv-accent);
	outline-offset: 2px;
}

.wbv-btn-primary {
	background: var(--wbv-accent);
	color: #fff;
	border-color: var(--wbv-accent);
}
.wbv-btn-primary:hover {
	background: var(--wbv-accent-hover);
	border-color: var(--wbv-accent-hover);
	box-shadow: var(--wbv-shadow-glow);
	color: #fff;
}

.wbv-btn-ghost {
	background: transparent;
	color: var(--wbv-text, #fff);
	border-color: var(--wbv-border);
}
.wbv-btn-ghost:hover {
	background: var(--wbv-surface-hover);
	border-color: var(--wbv-accent);
	color: var(--wbv-accent);
}

.wbv-btn-soft {
	background: var(--wbv-accent-soft);
	color: var(--wbv-accent);
	border-color: transparent;
}
.wbv-btn-soft:hover {
	background: var(--wbv-accent-glow);
}

.wbv-btn-sm   { padding: 0.375rem 0.75rem; font-size: 0.8125rem; }
.wbv-btn-lg   { padding: 0.875rem 1.75rem; font-size: 1rem; border-radius: var(--wbv-radius); }
.wbv-btn-pill { border-radius: var(--wbv-radius-pill); }
.wbv-btn-icon { padding: 0.5rem; width: 2.25rem; height: 2.25rem; }


/* ================================================================
   BADGES
   ================================================================ */

.wbv-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	padding: 0.25rem 0.625rem;
	font-size: 0.75rem;
	font-weight: 500;
	border-radius: var(--wbv-radius-pill);
	background: var(--wbv-surface-glass);
	border: 1px solid var(--wbv-border);
	color: var(--wbv-text-muted, #94a3b8);
}
.wbv-badge-accent {
	background: var(--wbv-accent-soft);
	border-color: var(--wbv-border-accent);
	color: var(--wbv-accent);
}
.wbv-badge-success {
	background: color-mix(in srgb, var(--wbv-success) 15%, transparent);
	border-color: color-mix(in srgb, var(--wbv-success) 40%, transparent);
	color: var(--wbv-success);
}
.wbv-badge-warning {
	background: color-mix(in srgb, var(--wbv-warning) 15%, transparent);
	border-color: color-mix(in srgb, var(--wbv-warning) 40%, transparent);
	color: var(--wbv-warning);
}
.wbv-badge-danger {
	background: color-mix(in srgb, var(--wbv-danger) 15%, transparent);
	border-color: color-mix(in srgb, var(--wbv-danger) 40%, transparent);
	color: var(--wbv-danger);
}
.wbv-badge-info {
	background: color-mix(in srgb, var(--wbv-info) 15%, transparent);
	border-color: color-mix(in srgb, var(--wbv-info) 40%, transparent);
	color: var(--wbv-info);
}


/* ================================================================
   FORM INPUTS
   ================================================================ */

.wbv-input,
.wbv-textarea,
.wbv-select {
	width: 100%;
	padding: 0.625rem 0.875rem;
	font-family: inherit;
	font-size: 0.9375rem;
	color: var(--wbv-text);
	background: var(--wbv-surface-glass);
	border: 1px solid var(--wbv-border);
	border-radius: var(--wbv-radius-sm);
	outline: none;
	transition:
		border-color var(--wbv-speed) var(--wbv-ease),
		box-shadow var(--wbv-speed) var(--wbv-ease);
}
.wbv-input:focus,
.wbv-textarea:focus,
.wbv-select:focus {
	border-color: var(--wbv-accent);
	box-shadow: 0 0 0 3px var(--wbv-accent-soft);
}
.wbv-input::placeholder,
.wbv-textarea::placeholder {
	color: var(--wbv-text-muted);
	opacity: 0.6;
}
.wbv-textarea {
	resize: vertical;
	min-height: 5rem;
}
.wbv-label {
	display: block;
	margin-bottom: 0.375rem;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--wbv-text-muted);
}
.wbv-form-group {
	margin-bottom: 1.25rem;
}


/* ================================================================
   HEADER — sticky glassmorphic
   ================================================================ */

.wbv-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: color-mix(in srgb, var(--wbv-bg, #000a1a) 85%, transparent);
	backdrop-filter: blur(20px) saturate(180%);
	-webkit-backdrop-filter: blur(20px) saturate(180%);
	border-bottom: 1px solid var(--wbv-border);
	padding: 0 1.5rem;
}
.wbv-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: var(--wbv-shell);
	margin: 0 auto;
	height: 3.5rem;
}
.wbv-header-brand {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-weight: 600;
	font-size: 1.0625rem;
	color: var(--wbv-text);
	text-decoration: none;
}
.wbv-header-brand img,
.wbv-header-brand svg {
	height: 1.75rem;
	width: auto;
}
.wbv-island-label {
	font-size: 0.6875rem;
	font-weight: 600;
	color: var(--wbv-accent);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	background: var(--wbv-accent-soft);
	padding: 0.125rem 0.5rem;
	border-radius: var(--wbv-radius-pill);
}

.wbv-nav {
	display: flex;
	align-items: center;
	gap: 0.25rem;
	list-style: none;
	margin: 0;
	padding: 0;
}
.wbv-nav a {
	display: flex;
	align-items: center;
	gap: 0.375rem;
	padding: 0.5rem 0.875rem;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--wbv-text-muted);
	border-radius: var(--wbv-radius-sm);
	transition: all var(--wbv-speed) var(--wbv-ease);
}
.wbv-nav a:hover,
.wbv-nav a[aria-current="page"] {
	color: var(--wbv-text);
	background: var(--wbv-surface-hover);
}
.wbv-nav a[aria-current="page"] {
	color: var(--wbv-accent);
}


/* ================================================================
   HERO
   ================================================================ */

.wbv-hero {
	text-align: center;
	padding: 4rem 1.5rem;
	max-width: var(--wbv-shell);
	margin: 0 auto;
}
.wbv-hero-title {
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	margin-bottom: 1rem;
	background: linear-gradient(135deg, var(--wbv-text, #fff) 40%, var(--wbv-accent) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.wbv-hero-subtitle {
	font-size: clamp(1rem, 2vw, 1.25rem);
	color: var(--wbv-text-muted);
	max-width: 600px;
	margin: 0 auto 2rem;
}
.wbv-hero-actions {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}


/* ================================================================
   FOOTER
   ================================================================ */

.wbv-footer {
	border-top: 1px solid var(--wbv-border);
	padding: 2.5rem 1.5rem;
	margin-top: auto;
}
.wbv-footer-inner {
	max-width: var(--wbv-shell);
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.5rem;
}
.wbv-footer-brand {
	font-size: 0.8125rem;
	color: var(--wbv-text-muted, #94a3b8);
}
.wbv-footer-brand strong {
	color: var(--wbv-text);
}


/* ================================================================
   NETWORK BAR — cross-island navigation (auto-injected by PHP)
   ================================================================ */

.wbv-network-footer {
	background: color-mix(in srgb, var(--wbv-bg, #000a1a) 70%, black);
	border-top: 1px solid var(--wbv-border);
	padding: 1.25rem 1.5rem 1rem;
	text-align: center;
	position: relative;
	z-index: 1;
}

.wbv-network-label {
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--wbv-text-muted, #94a3b8);
	margin-bottom: 0.625rem;
}

.wbv-network-bar {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	flex-wrap: wrap;
	margin-bottom: 0.875rem;
}

.wbv-network-link {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	padding: 0.3125rem 0.75rem;
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--wbv-text-muted, #94a3b8);
	background: var(--wbv-surface-glass);
	border: 1px solid var(--wbv-border);
	border-radius: var(--wbv-radius-pill);
	transition: all var(--wbv-speed) var(--wbv-ease);
	text-decoration: none;
}
.wbv-network-link:hover {
	color: var(--wbv-text, #fff);
	background: var(--wbv-surface-hover);
	border-color: var(--wbv-accent);
	transform: translateY(-1px);
}

.wbv-network-copy {
	font-size: 0.75rem;
	color: color-mix(in srgb, var(--wbv-text-muted, #94a3b8), transparent 30%);
}
.wbv-network-copy strong {
	color: var(--wbv-text-muted, #94a3b8);
}


/* ================================================================
   TABLE
   ================================================================ */

.wbv-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.875rem;
}
.wbv-table th {
	text-align: left;
	padding: 0.75rem 1rem;
	font-weight: 600;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--wbv-text-muted);
	border-bottom: 1px solid var(--wbv-border);
}
.wbv-table td {
	padding: 0.75rem 1rem;
	border-bottom: 1px solid var(--wbv-border);
}
.wbv-table tr:hover td {
	background: var(--wbv-surface-glass);
}


/* ================================================================
   MISCELLANEOUS COMPONENTS
   ================================================================ */

/* ─ Spinner / Loading ─ */
.wbv-spinner {
	display: inline-block;
	width: 1.5rem;
	height: 1.5rem;
	border: 2px solid var(--wbv-border);
	border-top-color: var(--wbv-accent);
	border-radius: 50%;
	animation: wbv-spin 0.6s linear infinite;
}
.wbv-spinner-lg { width: 2.5rem; height: 2.5rem; border-width: 3px; }

/* ─ Progress ─ */
.wbv-progress {
	width: 100%;
	height: 6px;
	background: var(--wbv-surface-glass);
	border-radius: 3px;
	overflow: hidden;
}
.wbv-progress-bar {
	height: 100%;
	background: var(--wbv-accent);
	border-radius: 3px;
	transition: width 0.3s var(--wbv-ease);
}

/* ─ Avatar ─ */
.wbv-avatar {
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--wbv-border);
}
.wbv-avatar-lg    { width: 4rem; height: 4rem; }
.wbv-avatar-accent {
	border-color: var(--wbv-accent);
	box-shadow: 0 0 12px var(--wbv-accent-glow);
}

/* ─ Divider ─ */
.wbv-divider {
	border: none;
	border-top: 1px solid var(--wbv-border);
	margin: 1.5rem 0;
}

/* ─ Tag / Chip ─ */
.wbv-tag {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	padding: 0.1875rem 0.5rem;
	font-size: 0.6875rem;
	font-weight: 500;
	background: var(--wbv-surface-glass);
	border: 1px solid var(--wbv-border);
	border-radius: var(--wbv-radius-pill);
	color: var(--wbv-text-muted);
}

/* ─ Tooltip ─ */
[data-wbv-tip] {
	position: relative;
}
[data-wbv-tip]::after {
	content: attr(data-wbv-tip);
	position: absolute;
	bottom: 100%;
	left: 50%;
	transform: translateX(-50%) translateY(-6px);
	padding: 0.375rem 0.625rem;
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--wbv-text);
	background: var(--wbv-glass-bg);
	backdrop-filter: blur(12px);
	border: 1px solid var(--wbv-border);
	border-radius: var(--wbv-radius-sm);
	white-space: nowrap;
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--wbv-speed) var(--wbv-ease);
	z-index: 500;
}
[data-wbv-tip]:hover::after { opacity: 1; }

/* ─ Empty State ─ */
.wbv-empty {
	text-align: center;
	padding: 3rem 1.5rem;
	color: var(--wbv-text-muted);
}
.wbv-empty-icon {
	font-size: 2.5rem;
	margin-bottom: 0.75rem;
	opacity: 0.4;
}
.wbv-empty-title {
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--wbv-text);
	margin-bottom: 0.375rem;
}

/* ─ Skeleton loader ─ */
.wbv-skeleton {
	background: linear-gradient(
		90deg,
		var(--wbv-surface-glass) 25%,
		var(--wbv-surface-hover) 50%,
		var(--wbv-surface-glass) 75%
	);
	background-size: 200% 100%;
	animation: wbv-shimmer 1.5s ease-in-out infinite;
	border-radius: var(--wbv-radius-sm);
}

/* ─ Screenreader only ─ */
.wbv-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;
}


/* ================================================================
   SCROLLBAR — opt-in: add class="wbv-scrollbar" to a container
   ================================================================ */

.wbv-scrollbar::-webkit-scrollbar       { width: 8px; height: 8px; }
.wbv-scrollbar::-webkit-scrollbar-track { background: var(--wbv-bg, #000a1a); }
.wbv-scrollbar::-webkit-scrollbar-thumb {
	background: var(--wbv-border);
	border-radius: 4px;
}
.wbv-scrollbar::-webkit-scrollbar-thumb:hover {
	background: color-mix(in srgb, var(--wbv-accent) 60%, transparent);
}


/* ================================================================
   ANIMATIONS
   ================================================================ */

@keyframes wbv-fade-in {
	from { opacity: 0; transform: translateY(12px); }
	to   { opacity: 1; transform: translateY(0); }
}
@keyframes wbv-slide-up {
	from { opacity: 0; transform: translateY(24px); }
	to   { opacity: 1; transform: translateY(0); }
}
@keyframes wbv-scale-in {
	from { opacity: 0; transform: scale(0.95); }
	to   { opacity: 1; transform: scale(1); }
}
@keyframes wbv-pulse {
	0%, 100% { opacity: 1; }
	50%      { opacity: 0.6; }
}
@keyframes wbv-spin {
	to { transform: rotate(360deg); }
}
@keyframes wbv-shimmer {
	0%   { background-position: -200% 0; }
	100% { background-position:  200% 0; }
}
@keyframes wbv-glow-ring {
	0%, 100% { box-shadow: 0 0 12px var(--wbv-accent-glow); }
	50%      { box-shadow: 0 0 28px var(--wbv-accent-glow); }
}

.wbv-animate-fade  { animation: wbv-fade-in  0.4s var(--wbv-ease) both; }
.wbv-animate-slide { animation: wbv-slide-up 0.5s var(--wbv-ease) both; }
.wbv-animate-scale { animation: wbv-scale-in 0.3s var(--wbv-ease) both; }
.wbv-animate-pulse { animation: wbv-pulse    2s ease-in-out infinite; }
.wbv-animate-spin  { animation: wbv-spin     0.8s linear infinite; }

.wbv-delay-1 { animation-delay: 0.1s; }
.wbv-delay-2 { animation-delay: 0.2s; }
.wbv-delay-3 { animation-delay: 0.3s; }
.wbv-delay-4 { animation-delay: 0.4s; }
.wbv-delay-5 { animation-delay: 0.5s; }

@media (prefers-reduced-motion: reduce) {
	[class^="wbv-"],
	[class*=" wbv-"] {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}


/* ================================================================
   LOGIN PAGE — branded across all islands
   ================================================================ */

body.login {
	background: var(--wbv-bg, #000a1a) !important;
	font-family: var(--wbv-font, 'Inter', system-ui, sans-serif) !important;
}

/* Logo → styled text "Webbiverse" */
body.login #login h1 a {
	background-image: none !important;
	text-indent: 0 !important;
	overflow: visible !important;
	width: auto !important;
	height: auto !important;
	font-size: 1.75rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	background: linear-gradient(135deg, #fff 40%, var(--wbv-accent, #e65616) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

/* Messages */
body.login .message,
body.login .success {
	border-left: 3px solid var(--wbv-accent, #e65616);
	background: var(--wbv-glass-bg, rgba(2,28,64,0.50)) !important;
	color: var(--wbv-text, #fff);
	border-radius: var(--wbv-radius-sm, 8px);
	box-shadow: none;
}
body.login .notice-error,
body.login #login_error {
	border-left: 3px solid var(--wbv-danger, #ef4444);
	background: color-mix(in srgb, var(--wbv-danger, #ef4444) 12%, rgba(2,28,64,0.50)) !important;
	color: var(--wbv-text, #fff);
	border-radius: var(--wbv-radius-sm, 8px);
	box-shadow: none;
}
body.login #login_error a { color: var(--wbv-accent, #e65616); }

/* Form card */
body.login #loginform,
body.login #registerform,
body.login #lostpasswordform {
	background: var(--wbv-glass-bg, rgba(2,28,64,0.50)) !important;
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border: 1px solid var(--wbv-border, rgba(255,255,255,0.08)) !important;
	border-radius: var(--wbv-radius, 12px) !important;
	box-shadow: var(--wbv-shadow, 0 4px 24px rgba(0,0,0,0.30)) !important;
	padding: 1.75rem 2rem !important;
}

/* Labels */
body.login label {
	color: var(--wbv-text-muted, #94a3b8) !important;
	font-size: 0.875rem;
	font-weight: 500;
}

/* Text inputs */
body.login input[type="text"],
body.login input[type="password"],
body.login input[type="email"] {
	background: var(--wbv-surface-glass, rgba(255,255,255,0.03)) !important;
	border: 1px solid var(--wbv-border, rgba(255,255,255,0.08)) !important;
	color: var(--wbv-text, #fff) !important;
	border-radius: var(--wbv-radius-sm, 8px) !important;
	padding: 0.625rem 0.875rem !important;
	font-size: 0.9375rem !important;
	font-family: inherit !important;
	box-shadow: none !important;
}
body.login input[type="text"]:focus,
body.login input[type="password"]:focus,
body.login input[type="email"]:focus {
	border-color: var(--wbv-accent, #e65616) !important;
	box-shadow: 0 0 0 3px var(--wbv-accent-soft, rgba(230,86,22,0.15)) !important;
	outline: none !important;
}

/* Submit button */
body.login .button-primary {
	background: var(--wbv-accent, #e65616) !important;
	border-color: var(--wbv-accent, #e65616) !important;
	color: #fff !important;
	border-radius: var(--wbv-radius-sm, 8px) !important;
	font-family: inherit !important;
	font-weight: 500 !important;
	font-size: 0.9375rem !important;
	padding: 0.625rem 1.5rem !important;
	text-shadow: none !important;
	height: auto !important;
	line-height: 1.4 !important;
	transition: all 200ms ease !important;
}
body.login .button-primary:hover,
body.login .button-primary:focus {
	background: var(--wbv-accent-hover, #ff7b3a) !important;
	border-color: var(--wbv-accent-hover, #ff7b3a) !important;
	box-shadow: var(--wbv-shadow-glow, 0 0 24px rgba(230,86,22,0.35)) !important;
}

/* Footer links */
body.login #nav,
body.login #backtoblog {
	color: var(--wbv-text-muted, #94a3b8) !important;
}
body.login #nav a,
body.login #backtoblog a {
	color: var(--wbv-accent, #e65616) !important;
}
body.login #nav a:hover,
body.login #backtoblog a:hover {
	color: var(--wbv-accent-hover, #ff7b3a) !important;
}
body.login .privacy-policy-page-link a {
	color: var(--wbv-text-muted, #94a3b8) !important;
}

/* Password toggle */
body.login .wp-pwd .button.wp-hide-pw {
	color: var(--wbv-text-muted, #94a3b8) !important;
}
body.login .wp-pwd .button.wp-hide-pw:hover {
	color: var(--wbv-accent, #e65616) !important;
}

/* Remember-me checkbox */
body.login input[type="checkbox"] {
	background: var(--wbv-surface-glass, rgba(255,255,255,0.03)) !important;
	border-color: var(--wbv-border, rgba(255,255,255,0.08)) !important;
}
body.login input[type="checkbox"]:checked {
	background: var(--wbv-accent, #e65616) !important;
	border-color: var(--wbv-accent, #e65616) !important;
}
