/* PeoplePath WordPress Snippets — shared base styles
   Color custom properties are injected dynamically via wp_add_inline_style.
   See pph_generate_styling_css() in pph-wordpress-snippets.php. */

:root {
	--font-weight-headings: 600;
	--text-transform-headings: none;
	--font-weight-text: 400;
	--font-size-base: 16px;
	--line-height: 1.6;
	--letter-spacing: 0;
	--letter-spacing-headings: 0;

	--input-height: 50px;
	--input-padding: 0 10px;
	--input-padding-with-icon: 0 10px 0 36px;
	--input-font-size: 16px;
	--input-border-radius: 0;
	--input-border-size: 1px;
	--input-checkbox-height: 22px;
	--input-checkbox-width: 22px;

	--button-font-size: 16px;
	--button-border-radius: 27px;
	--button-border-width: 1px;
	--button-border-style: solid;
	--button-font-weight: bold;
	--button-padding: 15px 40px;
	--button-min-width: 140px;
	--button-letter-spacing: 0;
	--button-transition: background .15s;
}

/* ── Accessibility utility ────────────────────────────────────────────────── */

/* Hides content visually but keeps it available to screen readers.
   Standard WordPress core pattern (also used by Twenty* themes). */
.iw-login .screen-reader-text,
.iw-reset .screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ── Snippet containers ───────────────────────────────────────────────────── */

.iw-login,
.iw-reset {
	font-size: var(--font-size-base);
	line-height: var(--line-height);
	font-weight: var(--font-weight-text);
	color: var(--color-text);
	letter-spacing: var(--letter-spacing);
}

.iw-login :focus-visible,
.iw-reset :focus-visible {
	outline: var(--color-focus-ring) auto 1px;
}

.iw-login a,
.iw-reset a {
	color: var(--color-link);
}

.iw-login a:hover,
.iw-reset a:hover {
	color: var(--color-link-hover);
	text-decoration: underline;
}

/* ── Headings (reset snippet uses h2) ────────────────────────────────────── */

.iw-reset h2 {
	font-weight: var(--font-weight-headings);
	font-style: normal;
	color: var(--color-text);
	text-transform: var(--text-transform-headings);
	letter-spacing: var(--letter-spacing-headings);
}

@media (min-width: 1440px) {
	.iw-reset h2 { font-size: 35px; }
}
@media (max-width: 1439px) {
	.iw-reset h2 { font-size: 32px; }
}

/* ── Error message ───────────────────────────────────────────────────────── */

.iw-login-error {
	background-color: white;
	padding: 10px 16px;
	color: red;
}
@media (min-width: 767px) {
	.iw-login-error {
		background-color: transparent;
		padding: 10px 0;
	}
}

/* ── Inputs ──────────────────────────────────────────────────────────────── */

.iw-input input, .iw-fieldWithIcon input {
	padding: var(--input-padding);
	font-size: var(--input-font-size);
	height: var(--input-height);
	line-height: var(--input-height);
	border: 1px solid var(--input-color-border);
	border-radius: var(--input-border-radius);
	display: block;
	margin-bottom: 15px;
	width: 100%;
}
.iw-fieldWithIcon input {
	padding: var(--input-padding-with-icon);
}

.iw-login input[type=text]:focus,
.iw-login input[type=password]:focus,
.iw-login select:focus,
.iw-login textarea:focus,
.iw-reset input[type=text]:focus,
.iw-reset input[type=password]:focus,
.iw-reset select:focus,
.iw-reset textarea:focus {
	border-color: #414141;
}

/* ── Buttons ─────────────────────────────────────────────────────────────── */

.iw-button {
	display: inline-block;
	box-sizing: border-box;
	padding: var(--button-padding);
	font-size: var(--button-font-size);
	font-weight: var(--button-font-weight);
	text-align: center;
	border-width: var(--button-border-width);
	border-style: var(--button-border-style);
	border-radius: var(--button-border-radius);
	text-transform: var(--button-text-transform);
	min-width: var(--button-min-width);
	letter-spacing: var(--button-letter-spacing);
	transition: var(--button-transition);
	cursor: pointer;
}
.iw-button:hover,
.iw-login a.iw-button:hover,
.iw-reset a.iw-button:hover {
	text-decoration: none;
}
.iw-button-primary {
	background-color: var(--button-primary-bg-color);
	color: var(--button-primary-text-color);
	border-color: var(--button-primary-border-color);
	border-radius: var(--button-primary-border-radius);
}
.iw-button-primary:hover {
	background-color: var(--button-primary-hover-bg-color);
	color: var(--button-primary-hover-text-color);
	border-color: var(--button-primary-hover-border-color);
}
.iw-button-primary:focus {
	border-color: #000000;
}
.iw-button-secondary {
	background-color: var(--button-secondary-bg-color);
	color: var(--button-secondary-text-color);
	border-color: var(--button-secondary-border-color);
	border-radius: var(--button-secondary-border-radius);
}
.iw-button-secondary:hover {
	background-color: var(--button-secondary-hover-bg-color);
	color: var(--button-secondary-hover-text-color);
	border-color: var(--button-secondary-hover-border-color);
}
.iw-button-secondary:focus {
	border-color: #000000;
}
.iw-button-tertiary {
	background-color: var(--button-tertiary-bg-color);
	color: var(--button-tertiary-text-color);
	border-color: var(--button-tertiary-border-color);
	border-radius: var(--button-tertiary-border-radius);
}
.iw-button-tertiary:hover {
	background-color: var(--button-tertiary-hover-bg-color);
	color: var(--button-tertiary-hover-text-color);
	border-color: var(--button-tertiary-hover-border-color);
}
.iw-button-tertiary:focus {
	border-color: #000000;
}
.iw-button-primary > a {
	color: #fff;
}

.iw-login a.iw-button-primary,
.iw-reset a.iw-button-primary {
	color: var(--button-primary-text-color);
}
.iw-login a.iw-button-primary:hover,
.iw-reset a.iw-button-primary:hover {
	color: var(--button-primary-hover-text-color);
}
.iw-login a.iw-button-secondary,
.iw-reset a.iw-button-secondary {
	color: var(--button-secondary-text-color);
}
.iw-login a.iw-button-secondary:hover,
.iw-reset a.iw-button-secondary:hover {
	color: var(--button-secondary-hover-text-color);
}
.iw-login a.iw-button-tertiary,
.iw-reset a.iw-button-tertiary {
	color: var(--button-tertiary-text-color);
}
.iw-login a.iw-button-tertiary:hover,
.iw-reset a.iw-button-tertiary:hover {
	color: var(--button-tertiary-hover-text-color);
}
