/* ==========================================================================
   Paragraphics Login – login.css
   Replaces WP's login stylesheet entirely. Dashicons re-enqueued via PHP.
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap');

:root {
	--pgli-btn-bg:       #0d0d0d;
	--pgli-btn-hover-bg: #333333;
	--pgli-panel-w:      62.5vw;
	--pgli-form-w:       360px;
	--pgli-font:         'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* --------------------------------------------------------------------------
   Hard reset
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }

/* --------------------------------------------------------------------------
   Body — flex row container
   DOM order: #pgli-form-col (left) then #pgli-panel (right)
   -------------------------------------------------------------------------- */
body.pgli-active {
	font-family: var(--pgli-font);
	font-size: 16px;
	color: #1d2327;
	background: #fff;
	display: flex;
	flex-direction: row;        /* form left, panel right */
	align-items: stretch;
	min-height: 100vh;
	height: 100vh;
	overflow: hidden;
}

body.pgli-active.pgli-panel-left {
	flex-direction: row-reverse; /* panel left, form right */
}

/* --------------------------------------------------------------------------
   Form column — 45vw
   -------------------------------------------------------------------------- */
#pgli-form-col {
	flex: 1 1 auto;
	height: 100vh;
	overflow-y: auto;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	padding: 30px;
	background: #fff;
}

/* --------------------------------------------------------------------------
   Image panel — 55vw
   -------------------------------------------------------------------------- */
#pgli-panel {
	flex: 0 0 var(--pgli-panel-w);
	width: var(--pgli-panel-w);
	height: 100vh;
	position: sticky;
	top: 0;
	align-self: flex-start;
	background-color: #0d1b2a;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

/* WP's original #login — hidden, content moved to #pgli-form-col */
body.pgli-active #login { display: none !important; }

/* --------------------------------------------------------------------------
   Logo & site name
   -------------------------------------------------------------------------- */
#pgli-header {
	width: 100%;
	max-width: var(--pgli-form-w);
	margin-bottom: 48px;
	flex-shrink: 0;
}

.pgli-logo-link {
	display: inline-block;
	margin-bottom: 16px;
	text-decoration: none;
	line-height: 1;
}

.pgli-logo-img,
.pgli-logo-svg svg {
	display: block;
	max-height: 75px;
	max-width: 100%;
	width: auto;
	height: auto;
}

.pgli-logo-svg svg { fill: #0d0d0d; }

.pgli-site-name {
	font-family: var(--pgli-font);
	font-size: 36px;
	font-weight: 700;
	color: #0d0d0d;
	line-height: 1.15;
	margin: 0;
	padding: 0;
}

/* --------------------------------------------------------------------------
   Form section heading (Log In / Create an Account / Reset Password)
   -------------------------------------------------------------------------- */
body.pgli-active .login-action-login        #loginform::before        { content: 'Log In'; }
body.pgli-active .login-action-register     #registerform::before     { content: 'Create an Account'; }
body.pgli-active .login-action-lostpassword #lostpasswordform::before { content: 'Reset Password'; }

body.pgli-active #loginform::before,
body.pgli-active #registerform::before,
body.pgli-active #lostpasswordform::before {
	display: block;
	font-family: var(--pgli-font);
	font-size: 26px;
	font-weight: 600;
	color: #0d0d0d;
	margin-bottom: 28px;
}

/* --------------------------------------------------------------------------
   Form element — overall wrapper
   -------------------------------------------------------------------------- */
body.pgli-active #loginform,
body.pgli-active #registerform,
body.pgli-active #lostpasswordform {
	display: block;
	width: 100%;
	max-width: var(--pgli-form-w);
	margin: 0;
	padding: 0;
	background: transparent;
	border: none;
	box-shadow: none;
	border-radius: 0;
}

/* --------------------------------------------------------------------------
   Field row wrappers
   WP uses <p class="login-username">, <div class="user-pass-wrap">,
   <p class="login-remember">, <p class="login-submit">
   -------------------------------------------------------------------------- */
body.pgli-active .login-username,
body.pgli-active .user-pass-wrap,
body.pgli-active .login-remember,
body.pgli-active .login-submit {
	display: block;
	width: 100%;
	margin: 0 0 20px;
	padding: 0;
	float: none;
	clear: both;
}

body.pgli-active .login-submit { margin-bottom: 0; }

/* --------------------------------------------------------------------------
   Labels
   -------------------------------------------------------------------------- */
body.pgli-active #loginform label,
body.pgli-active #registerform label,
body.pgli-active #lostpasswordform label {
	display: block;
	font-family: var(--pgli-font);
	font-size: 14px;
	font-weight: 400;
	color: #0d0d0d;
	margin: 0 0 6px;
	cursor: default;
}

/* --------------------------------------------------------------------------
   Text / email inputs
   -------------------------------------------------------------------------- */
body.pgli-active #loginform input[type="text"],
body.pgli-active #loginform input[type="email"],
body.pgli-active #registerform input[type="text"],
body.pgli-active #registerform input[type="email"],
body.pgli-active #lostpasswordform input[type="text"],
body.pgli-active #lostpasswordform input[type="email"] {
	display: block;
	width: 100%;
	font-family: var(--pgli-font);
	font-size: 15px;
	color: #0d0d0d;
	background: #fff;
	border: 1.5px solid #d0d0d0;
	border-radius: 6px;
	padding: 10px 14px;
	margin: 0;
	box-shadow: none;
	outline: none;
	transition: border-color 0.18s ease, box-shadow 0.18s ease;
	-webkit-appearance: none;
	appearance: none;
}

/* --------------------------------------------------------------------------
   Password field — .user-pass-wrap > label + .wp-pwd
   .wp-pwd holds: input[type=password] + button.wp-hide-pw + #login-message
   -------------------------------------------------------------------------- */
body.pgli-active .user-pass-wrap > label {
	display: block;
	margin-bottom: 6px;
}

body.pgli-active .wp-pwd {
	position: relative;
	display: block;
	width: 100%;
}

body.pgli-active .wp-pwd input[type="password"],
body.pgli-active .wp-pwd input[type="text"] {
	display: block;
	width: 100%;
	font-family: var(--pgli-font);
	font-size: 15px;
	color: #0d0d0d;
	background: #fff;
	border: 1.5px solid #d0d0d0;
	border-radius: 6px;
	padding: 10px 42px 10px 14px; /* right padding for eye button */
	margin: 0;
	box-shadow: none;
	outline: none;
	transition: border-color 0.18s ease, box-shadow 0.18s ease;
	-webkit-appearance: none;
	appearance: none;
}

/* Eye toggle button — sits inside .wp-pwd, top-right of the input */
body.pgli-active .wp-hide-pw {
	position: absolute;
	top: 10px;
	right: 0;
	bottom: auto;
	width: 40px;
	padding: 0;
	margin: 0;
	background: transparent;
	border: none;
	border-radius: 0 6px 6px 0;
	box-shadow: none;
	color: #757575;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	min-height: 0;
	height: auto; /* override any height:auto !important from button resets */
}

body.pgli-active .wp-hide-pw:hover,
body.pgli-active .wp-hide-pw:focus {
	background: transparent;
	border: none;
	box-shadow: none;
	color: #0d0d0d;
	outline: 2px solid transparent;
}

body.pgli-active .wp-hide-pw .dashicons {
	font-size: 18px;
	width: 18px;
	height: 18px;
	line-height: 1;
}

/* Hide the "Show password" text label next to the icon */
body.pgli-active .wp-hide-pw .text { display: none; }

/* Caps lock notice — absolutely positioned inside .wp-pwd */
body.pgli-active #login-message {
	display: block;
	background: transparent;
	border: none;
	box-shadow: none;
	padding: 0;
	margin: 0;
}

body.pgli-active #caps-warning {
	display: none !important;
	position: relative;
	padding: 0;
	margin: 10px 0 0;
	align-items: center;
	width: 100%;
	font-family: var(--pgli-font);
	font-size: 13px;
	font-weight: 600;
	color: #646970;
	pointer-events: none;
}

body.pgli-active #caps-warning[style*="block"] {
	display: flex !important;
}

body.pgli-active #caps-warning .caps-icon {
	width: 14px;
	height: 14px;
	margin-right: 5px;
	flex-shrink: 0;
	fill: currentColor;
}

/* Focus states */
body.pgli-active #loginform input[type="text"]:focus,
body.pgli-active #loginform input[type="email"]:focus,
body.pgli-active #registerform input[type="text"]:focus,
body.pgli-active #registerform input[type="email"]:focus,
body.pgli-active #lostpasswordform input[type="text"]:focus,
body.pgli-active #lostpasswordform input[type="email"]:focus,
body.pgli-active .wp-pwd input:focus {
	border-color: var(--pgli-btn-bg);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--pgli-btn-bg) 12%, transparent);
}

/* --------------------------------------------------------------------------
   Remember Me
   -------------------------------------------------------------------------- */
body.pgli-active .login-remember,
body.pgli-active .forgetmenot {
	margin-bottom: 20px;
}

body.pgli-active .forgetmenot {
	display: flex;
	align-items: center;
}

body.pgli-active .forgetmenot label {
	line-height: 1;
	margin: 0 !important;
	font-size: 14px;
	font-weight: 400;
	color: #0d0d0d;
	cursor: pointer;
	display: inline;
}

body.pgli-active .forgetmenot input {
	margin: 0 6px 0 0;
	accent-color: var(--pgli-btn-bg);
}

/* --------------------------------------------------------------------------
   Submit button
   -------------------------------------------------------------------------- */
body.pgli-active input[type="submit"],
body.pgli-active .button-primary,
body.pgli-active .wp-core-ui .button-primary {
	display: block;
	width: 100%;
	font-family: var(--pgli-font);
	font-size: 16px;
	font-weight: 600;
	color: #fff;
	background: var(--pgli-btn-bg);
	border: 2px solid var(--pgli-btn-bg);
	border-radius: 6px;
	padding: 11px 20px;
	margin: 0;
	cursor: pointer;
	text-align: center;
	text-shadow: none;
	box-shadow: none;
	outline: none;
	height: auto;
	line-height: 1.4;
	transition: background 0.18s ease, border-color 0.18s ease;
	-webkit-appearance: none;
	appearance: none;
}

body.pgli-active input[type="submit"]:hover,
body.pgli-active input[type="submit"]:focus,
body.pgli-active .wp-core-ui .button-primary:hover,
body.pgli-active .wp-core-ui .button-primary:focus {
	background: var(--pgli-btn-hover-bg);
	border-color: var(--pgli-btn-hover-bg);
	box-shadow: none;
	color: #fff;
}

/* --------------------------------------------------------------------------
   Nav links (#nav / #backtoblog)
   -------------------------------------------------------------------------- */
body.pgli-active #nav,
body.pgli-active #backtoblog {
	display: block;
	width: 100%;
	max-width: var(--pgli-form-w);
	margin: 20px 0 0;
	padding: 0;
	font-family: var(--pgli-font);
	font-size: 14px;
	text-align: left;
	background: transparent;
	border: none;
	box-shadow: none;
	float: none;
	clear: both;
}

body.pgli-active #nav a,
body.pgli-active #backtoblog a {
	color: #0d0d0d;
	text-decoration: underline;
	text-underline-offset: 2px;
}

body.pgli-active #nav a:hover,
body.pgli-active #backtoblog a:hover { opacity: 0.6; }

/* --------------------------------------------------------------------------
   Error / info messages (above the form)
   -------------------------------------------------------------------------- */
body.pgli-active #login_error,
body.pgli-active .message,
body.pgli-active .success {
	display: block;
	max-width: var(--pgli-form-w);
	width: 100%;
	border-left: 4px solid #d63638;
	background: #fcf0f1;
	border-radius: 0 4px 4px 0;
	font-family: var(--pgli-font);
	font-size: 14px;
	padding: 12px 16px;
	margin: 0 0 20px;
	box-shadow: none;
}

body.pgli-active .message,
body.pgli-active .success {
	border-left-color: #00a32a;
	background: #edfaef;
}

/* --------------------------------------------------------------------------
   Screen reader utilities
   -------------------------------------------------------------------------- */
.screen-reader-text {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	margin: -1px !important;
	padding: 0 !important;
	overflow: hidden !important;
	clip: rect(0,0,0,0) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

#reg_passmail {
	font-size: 14px;
	font-weight: 600;
	margin: 10px 0 30px !important;
}

/* --------------------------------------------------------------------------
   Responsive — ≤ 1000px: image becomes top banner, form stacks below
   -------------------------------------------------------------------------- */
@media (max-width: 1000px) {
	body.pgli-active,
	body.pgli-active.pgli-panel-left {
		flex-direction: column;
		height: auto;
		overflow: auto;
	}

	#pgli-panel {
		order: -1;
		flex: 0 0 20vh;
		width: 100%;
		height: 20vh;
		min-height: 0;
		position: relative;
		top: auto;
		align-self: auto;
	}

	#pgli-form-col {
		flex: 1 1 auto;
		height: auto;
		min-height: auto;
		overflow-y: visible;
		justify-content: flex-start;
		padding: 60px;
	}

	.pgli-site-name {
		font-size: 25px;
	}

	.pgli-logo-img,
	.pgli-logo-svg svg {
		max-height: 40px;
	}

	#pgli-header,
	body.pgli-active #loginform,
	body.pgli-active #registerform,
	body.pgli-active #lostpasswordform,
	body.pgli-active #nav,
	body.pgli-active #backtoblog,
	body.pgli-active #login_error,
	body.pgli-active .message {
		max-width: 400px;
		margin-left: auto;
		margin-right: auto;
	}
}

@media (max-width: 480px) {
	#pgli-form-col { padding: 36px 24px; }
}

/* ==========================================================================
   Pro — panel position variants
   ========================================================================== */

/* --- Top --- */
body.pgli-active.pgli-panel-top {
	flex-direction: column;
	height: auto;
	overflow: auto;
}

body.pgli-active.pgli-panel-top #pgli-panel {
	order: -1;
	flex: 0 0 40vh;
	width: 100%;
	height: 40vh;
	position: relative;
	top: auto;
	align-self: auto;
}

body.pgli-active.pgli-panel-top #pgli-form-col {
	flex: 1 1 auto;
	height: auto;
	min-height: auto;
	overflow-y: visible;
	width: 100%;
	padding: 60px;
	justify-content: center;
	align-items: center;
}

body.pgli-active.pgli-panel-top #pgli-header,
body.pgli-active.pgli-panel-top #loginform,
body.pgli-active.pgli-panel-top #registerform,
body.pgli-active.pgli-panel-top #lostpasswordform,
body.pgli-active.pgli-panel-top #nav,
body.pgli-active.pgli-panel-top #backtoblog {
	max-width: 400px;
	margin-left: auto;
	margin-right: auto;
}

/* --- Bottom --- */
body.pgli-active.pgli-panel-bottom {
	flex-direction: column;
	height: auto;
	overflow: auto;
}

body.pgli-active.pgli-panel-bottom #pgli-panel {
	order: 1;
	flex: 0 0 40vh;
	width: 100%;
	height: 40vh;
	position: relative;
	align-self: auto;
}

body.pgli-active.pgli-panel-bottom #pgli-form-col {
	flex: 1 1 auto;
	height: auto;
	min-height: auto;
	overflow-y: visible;
	width: 100%;
	padding: 60px;
	justify-content: center;
	align-items: center;
}

body.pgli-active.pgli-panel-bottom #pgli-header,
body.pgli-active.pgli-panel-bottom #loginform,
body.pgli-active.pgli-panel-bottom #registerform,
body.pgli-active.pgli-panel-bottom #lostpasswordform,
body.pgli-active.pgli-panel-bottom #nav,
body.pgli-active.pgli-panel-bottom #backtoblog {
	max-width: 400px;
	margin-left: auto;
	margin-right: auto;
}

/* --- None --- */
body.pgli-active.pgli-panel-none #pgli-panel {
	display: none;
}

body.pgli-active.pgli-panel-none #pgli-form-col {
	flex: 1 1 auto;
	width: 100%;
	justify-content: center;
	align-items: center;
}

body.pgli-active.pgli-panel-none #pgli-header,
body.pgli-active.pgli-panel-none #loginform,
body.pgli-active.pgli-panel-none #registerform,
body.pgli-active.pgli-panel-none #lostpasswordform,
body.pgli-active.pgli-panel-none #nav,
body.pgli-active.pgli-panel-none #backtoblog {
	max-width: 400px;
	margin-left: auto;
	margin-right: auto;
}

/* --- Overlay --- */
body.pgli-active.pgli-panel-overlay {
	display: block;
	position: relative;
	overflow: auto;
	height: auto;
}

body.pgli-active.pgli-panel-overlay #pgli-panel {
	position: fixed;
	inset: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
	flex: none;
}

/* #pgli-form-col is unused in overlay mode — hide it */
body.pgli-active.pgli-panel-overlay #pgli-form-col {
	display: none !important;
}

/* #pgli-overlay-box holds a copy of header + form content */
#pgli-overlay-box {
	display: none;
}

body.pgli-active.pgli-panel-overlay #pgli-overlay-box {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
	z-index: 10;
	min-height: 100vh;
	padding: 40px 30px;
}

/* The white card wraps header + form + nav links */
body.pgli-active.pgli-panel-overlay #pgli-overlay-box #pgli-header,
body.pgli-active.pgli-panel-overlay #pgli-overlay-box #loginform,
body.pgli-active.pgli-panel-overlay #pgli-overlay-box #registerform,
body.pgli-active.pgli-panel-overlay #pgli-overlay-box #lostpasswordform,
body.pgli-active.pgli-panel-overlay #pgli-overlay-box #nav,
body.pgli-active.pgli-panel-overlay #pgli-overlay-box #backtoblog,
body.pgli-active.pgli-panel-overlay #pgli-overlay-box #login_error,
body.pgli-active.pgli-panel-overlay #pgli-overlay-box .message {
	width: 100%;
	max-width: 380px;
}

/* Single white card containing everything */
body.pgli-active.pgli-panel-overlay #pgli-overlay-box {
	background: transparent;
}

body.pgli-active.pgli-panel-overlay #pgli-overlay-box::before {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
}

/* The actual card — wraps all inner content with white bg + shadow */
body.pgli-active.pgli-panel-overlay .pgli-overlay-card {
	background: #fff;
	border-radius: 12px;
	padding: 50px;
	box-shadow: 0 10px 20px rgba(0,0,0,0.125);
	width: 100%;
	max-width: 480px;
	display: flex;
	flex-direction: column;
}

body.pgli-active.pgli-panel-overlay .pgli-overlay-card #pgli-header {
	margin-bottom: 32px;
}

body.pgli-active.pgli-panel-overlay .pgli-overlay-card #loginform,
body.pgli-active.pgli-panel-overlay .pgli-overlay-card #registerform,
body.pgli-active.pgli-panel-overlay .pgli-overlay-card #lostpasswordform {
	max-width: 100% !important;
}

body.pgli-active.pgli-panel-overlay .pgli-overlay-card #nav,
body.pgli-active.pgli-panel-overlay .pgli-overlay-card #backtoblog {
	max-width: 100% !important;
}

/* ==========================================================================
   Pro — video panel
   ========================================================================== */
#pgli-panel {
	overflow: hidden;
}

#pgli-panel-video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
}

#pgli-panel { position: relative; }
