/**
 * Checkout, Auth (login/register), My Account — JUNK Plastic Rehab
 */

/* ═══════════════════════════════════════
   SHARED: WooCommerce form field resets
═══════════════════════════════════════ */

.woocommerce-form-row,
.form-row {
	margin-bottom: 20px;
}

.woocommerce-form-row label,
.form-row label {
	display: block;
	font-size: var(--typo-input-size, 13px);
	font-weight: var(--typo-input-weight, 500);
	letter-spacing: var(--typo-input-ls, 0.04em);
	text-transform: var(--typo-input-transform, uppercase);
	color: var(--color-text-secondary);
	margin-bottom: 6px;
}

.woocommerce-Input,
.woocommerce-input-wrapper input,
.woocommerce-input-wrapper select,
.woocommerce-input-wrapper textarea {
	width: 100%;
	padding: 12px 16px;
	border: var(--border);
	border-radius: var(--radius-sm);
	font-family: var(--font-body);
	font-size: var(--typo-input-size, 15px);
	background-color: var(--color-bg);
	color: var(--color-text);
	transition: border-color var(--transition);
}

.woocommerce-Input:focus,
.woocommerce-input-wrapper input:focus,
.woocommerce-input-wrapper select:focus,
.woocommerce-input-wrapper textarea:focus {
	outline: none;
	border-color: var(--color-primary);
}

.woocommerce-form-row.validate-required .woocommerce-input-wrapper::after {
	content: none; /* suppress WC's inline asterisk duplication */
}

abbr.required { color: var(--color-error); }

/* ── Full-width button variant ── */
.btn--full,
.woocommerce-button.btn--full {
	display: block;
	width: 100%;
	text-align: center;
}

/* ═══════════════════════════════════════
   CHECKOUT PAGE
═══════════════════════════════════════ */

.checkout-page {
	padding-top: var(--section-spacing);
	padding-bottom: calc( var(--section-spacing) * 2 );
}

.checkout-page__title {
	grid-column: 1 / -1;
	margin-bottom: 40px;
}

.checkout-page__form {
	display: grid;
	grid-template-columns: 1fr 400px;
	column-gap: 60px;
	align-items: start;
}

/* Left column */
.checkout-page__fields {
	min-width: 0;
}

/* Right column: sticky order summary */
.checkout-page__summary {
	position: sticky;
	top: calc( var(--header-height-desktop, 72px) + 24px );
}

.checkout-page__summary-title {
	font-size: var(--typo-h5-size, 18px);
	font-weight: 600;
	margin-bottom: 20px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--color-border);
}

/* Two sub-sections inside left column */
#customer_details {
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 40px;
}

/* On single-column checkout (no shipping) */
#customer_details .woocommerce-billing-fields,
#customer_details .woocommerce-shipping-fields {
	min-width: 0;
}

.checkout-section h3 {
	font-size: var(--typo-button-size, 16px);
	font-weight: var(--typo-button-weight, 600);
	letter-spacing: var(--typo-button-ls, 0.04em);
	text-transform: var(--typo-button-transform, uppercase);
	margin-bottom: 24px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--color-border);
}

/* Inline fields: first/last name row */
.woocommerce-billing-fields .form-row-first,
.woocommerce-billing-fields .form-row-last,
.woocommerce-shipping-fields .form-row-first,
.woocommerce-shipping-fields .form-row-last {
	display: inline-block;
	width: calc(50% - 8px);
}

.woocommerce-billing-fields .form-row-first,
.woocommerce-shipping-fields .form-row-first {
	margin-right: 16px;
}

/* Shipping same as billing toggle */
#ship-to-different-address {
	margin-bottom: 24px;
}

#ship-to-different-address label {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: var(--typo-body-size, 14px);
	font-weight: 500;
	cursor: pointer;
	text-transform: none;
	letter-spacing: 0;
	color: var(--color-text);
}

#ship-to-different-address input[type="checkbox"] {
	width: 18px;
	height: 18px;
	cursor: pointer;
	accent-color: var(--color-primary);
}

/* Order review table (right column) */
.checkout-order-review table.shop_table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 24px;
}

.checkout-order-review table.shop_table th,
.checkout-order-review table.shop_table td {
	padding: 12px 0;
	border-bottom: 1px solid var(--color-border);
	font-size: var(--typo-button-size, 14px);
	vertical-align: middle;
}

.checkout-order-review table.shop_table th {
	color: var(--color-text-secondary);
	font-weight: 400;
	text-align: left;
}

.checkout-order-review table.shop_table td {
	text-align: right;
}

.checkout-order-review table.shop_table .order-total th,
.checkout-order-review table.shop_table .order-total td {
	font-size: var(--typo-body-size, 16px);
	font-weight: 600;
	color: var(--color-text);
	border-bottom: none;
	padding-top: 16px;
}

/* Product name in order review */
.checkout-order-review .product-name .product-quantity {
	color: var(--color-text-secondary);
	font-size: var(--typo-body_small-size, 13px);
}

/* Payment section */
#payment {
	margin-top: 32px;
}

#payment .payment_methods {
	list-style: none;
	padding: 0;
	margin: 0 0 20px;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	overflow: hidden;
}

#payment .payment_methods li {
	padding: 16px 20px;
	border-bottom: 1px solid var(--color-border);
}

#payment .payment_methods li:last-child {
	border-bottom: none;
}

#payment .payment_methods li label {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: var(--typo-body-size, 14px);
	font-weight: 500;
	cursor: pointer;
	text-transform: none;
	letter-spacing: 0;
	color: var(--color-text);
}

#payment .payment_methods li label img {
	max-height: 24px;
	width: auto;
	display: inline-block;
}

#payment .payment_box {
	padding: 16px 20px;
	background-color: var(--color-bg-alt);
	border-radius: var(--radius-sm);
	margin-top: 12px;
	font-size: var(--typo-body-size, 14px);
	color: var(--color-text-secondary);
}

/* Classic checkout + WooCommerce Block checkout place-order button */
#payment #place_order,
.wc-block-components-checkout-place-order-button {
	display: block;
	width: 100%;
	height: 52px;
	padding: 0 24px;
	background: var(--color-primary) !important;
	color: var(--color-text-light) !important;
	border: 1px solid var(--color-primary) !important;
	border-radius: var(--radius-sm) !important;
	font-family: var(--font-body) !important;
	font-size: var(--typo-button-size, 13px) !important;
	font-weight: var(--typo-button-weight, 600) !important;
	letter-spacing: var(--typo-button-ls, 0.06em) !important;
	text-transform: var(--typo-button-transform, uppercase) !important;
	cursor: pointer;
	transition: all var(--transition) !important;
}

#payment #place_order:hover,
.wc-block-components-checkout-place-order-button:hover {
	background: var(--color-primary-hover) !important;
	border-color: var(--color-primary-hover) !important;
}

/* Privacy + terms notice */
.woocommerce-terms-and-conditions-wrapper {
	font-size: var(--typo-caption-size, 12px);
	color: var(--color-text-secondary);
	margin-bottom: 20px;
	line-height: 1.5;
}

/* Checkout responsive */
@media ( max-width: 960px ) {
	.checkout-page__form {
		grid-template-columns: 1fr;
	}

	.checkout-page__summary {
		position: static;
		margin-top: 40px;
	}

	#customer_details {
		grid-template-columns: 1fr;
	}
}

@media ( max-width: 600px ) {
	.woocommerce-billing-fields .form-row-first,
	.woocommerce-billing-fields .form-row-last,
	.woocommerce-shipping-fields .form-row-first,
	.woocommerce-shipping-fields .form-row-last {
		display: block;
		width: 100%;
		margin-right: 0;
	}
}

/* ═══════════════════════════════════════
   AUTH PAGE (login / register)
═══════════════════════════════════════ */

.auth-page {
	padding-top: var(--section-spacing);
	padding-bottom: calc( var(--section-spacing) * 2 );
}

.auth-page__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 80px;
	align-items: stretch; /* equal-height columns so buttons can align */
}

/* Each column stretches to full grid height */
.auth-block {
	display: flex;
	flex-direction: column;
}

/* Form fills available height */
.auth-block__form {
	flex: 1;
	display: flex;
	flex-direction: column;
}

/* Actions wrapper (checkbox + submit) always floats to the bottom */
.auth-block__actions {
	margin-top: auto;
	padding-top: 24px;
}

.auth-block__title {
	font-size: var(--typo-h4-size, 24px);
	margin-bottom: 32px;
}

.auth-block--register {
	padding-left: 80px;
	border-left: 1px solid var(--color-border);
}

.form-row label {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
}

.form-row__lost-password {
	font-size: var(--typo-caption-size, 12px);
	font-weight: 400;
	text-transform: none;
	letter-spacing: 0;
	color: var(--color-text-secondary);
	text-decoration: underline;
}

.form-row__lost-password:hover {
	color: var(--color-primary);
}

.form-row--remember label {
	display: flex;
	align-items: center;
	justify-content: flex-start; /* override the space-between from .form-row label */
	gap: 10px;
	font-size: var(--typo-body_small-size, 13px);
	font-weight: 400;
	text-transform: none;
	letter-spacing: 0;
	color: var(--color-text);
	cursor: pointer;
}

.form-row--remember input[type="checkbox"] {
	flex-shrink: 0;
	width: 16px;
	height: 16px;
	accent-color: var(--color-primary);
	cursor: pointer;
	margin: 0; /* reset browser defaults that may shift it */
}

/* ── Password field: position the show/hide toggle inside the input ── */
.woocommerce-input-wrapper {
	position: relative;
	display: block;
}

/* Give password input room for the toggle button */
.woocommerce-Input--password {
	padding-right: 48px !important;
}

/* The toggle button injected by WooCommerce JS */
.show-password-input {
	position: absolute;
	right: 12px;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	padding: 4px;
	cursor: pointer;
	color: var(--color-text-secondary);
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	transition: color var(--transition);
}

.show-password-input:hover {
	color: var(--color-text);
}

/* Dashicons icon size */
.show-password-input .dashicons {
	font-size: 18px;
	width: 18px;
	height: 18px;
}

.auth-block__form .btn--primary {
	padding: 14px 32px;
}

.form-row__hint {
	font-size: var(--typo-body_small-size, 13px);
	color: var(--color-text-secondary);
	margin-bottom: 20px;
}

/* ── Privacy policy acceptance checkbox ── */
.form-row--privacy-accept {
	margin-bottom: 16px;
}

.form-row--privacy-accept label {
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
	gap: 10px;
	font-size: var(--typo-body_small-size, 13px);
	font-weight: 400;
	text-transform: none;
	letter-spacing: 0;
	color: var(--color-text);
	cursor: pointer;
	line-height: 1.5;
}

.form-row--privacy-accept input[type="checkbox"] {
	flex-shrink: 0;
	width: 16px;
	height: 16px;
	margin-top: 2px; /* align with first line of text */
	accent-color: var(--color-primary);
	cursor: pointer;
}

.form-row--privacy-accept a {
	color: var(--color-text);
	text-decoration: underline;
}

.form-row--privacy-accept a:hover {
	color: var(--color-primary);
}

@media ( max-width: 768px ) {
	.auth-page__grid {
		grid-template-columns: 1fr;
	}

	.auth-block--register {
		padding-left: 0;
		border-left: none;
		border-top: 1px solid var(--color-border);
		padding-top: 48px;
		margin-top: 48px;
	}
}

/* ═══════════════════════════════════════
   MY ACCOUNT PAGE
═══════════════════════════════════════ */

.account-page {
	padding-top: var(--section-spacing);
	padding-bottom: calc( var(--section-spacing) * 2 );
}

.account-page .container {
	display: grid;
	grid-template-columns: 220px 1fr;
	column-gap: 60px;
	align-items: start;
}

/* Nav */
.account-page__nav {
	position: sticky;
	top: calc( var(--header-height-desktop, 72px) + 24px );
}

.account-page__greeting {
	margin-bottom: 24px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--color-border);
}

.account-page__greeting-label {
	display: block;
	font-size: var(--typo-caption-size, 12px);
	text-transform: var(--typo-caption-transform, uppercase);
	letter-spacing: 0.08em;
	color: var(--color-text-secondary);
	margin-bottom: 4px;
}

.woocommerce-MyAccount-navigation ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.woocommerce-MyAccount-navigation li {
	border-bottom: 1px solid var(--color-border);
}

.woocommerce-MyAccount-navigation a {
	display: block;
	padding: 12px 0;
	font-size: var(--typo-button-size, 14px);
	color: var(--color-text);
	transition: color var(--transition);
}

.woocommerce-MyAccount-navigation a:hover,
.woocommerce-MyAccount-navigation .is-active a {
	color: var(--color-primary);
}

.woocommerce-MyAccount-navigation .is-active a {
	font-weight: 600;
}

/* Content area */
.account-page__content {
	min-width: 0;
}

.account-page__content .woocommerce-orders-table {
	width: 100%;
	border-collapse: collapse;
}

.account-page__content .woocommerce-orders-table th {
	font-size: var(--typo-caption-size, 12px);
	text-transform: var(--typo-caption-transform, uppercase);
	letter-spacing: 0.06em;
	color: var(--color-text-secondary);
	font-weight: 500;
	padding: 10px 12px;
	border-bottom: 1px solid var(--color-border);
	text-align: left;
}

.account-page__content .woocommerce-orders-table td {
	padding: 14px 12px;
	font-size: var(--typo-body-size, 14px);
	border-bottom: 1px solid var(--color-border);
	vertical-align: middle;
}

.account-page__content .woocommerce-orders-table .button {
	padding: 6px 16px;
	font-size: var(--typo-caption-size, 12px);
	letter-spacing: 0.04em;
	text-transform: var(--typo-button-transform, uppercase);
	background-color: transparent;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	text-decoration: none;
	transition: all var(--transition);
}

.account-page__content .woocommerce-orders-table .button:hover {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-text-light);
}

/* Address boxes */
.woocommerce-Addresses .woocommerce-Address {
	padding: 24px;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
}

.woocommerce-Addresses .woocommerce-Address-title {
	margin-bottom: 16px;
}

.woocommerce-Addresses .woocommerce-Address-title h3 {
	font-size: var(--typo-body-size, 15px);
	font-weight: 600;
	display: inline;
}

.woocommerce-Addresses .woocommerce-Address-title .edit {
	margin-left: 12px;
	font-size: var(--typo-caption-size, 12px);
	text-decoration: underline;
	color: var(--color-text-secondary);
}

/* Account form (edit account / edit address) */
.woocommerce-EditAccountForm .form-row,
.woocommerce-address-fields .form-row {
	margin-bottom: 20px;
}

/* Order details */
.woocommerce-order-details table,
.woocommerce-table--order-details {
	width: 100%;
	border-collapse: collapse;
}

.woocommerce-table--order-details th,
.woocommerce-table--order-details td {
	padding: 12px 0;
	border-bottom: 1px solid var(--color-border);
	font-size: var(--typo-body-size, 14px);
}

/* Account responsive */
@media ( max-width: 768px ) {
	.account-page .container {
		grid-template-columns: 1fr;
	}

	.account-page__nav {
		position: static;
		margin-bottom: 40px;
	}

	.woocommerce-MyAccount-navigation ul {
		display: flex;
		flex-wrap: wrap;
		gap: 4px;
	}

	.woocommerce-MyAccount-navigation li {
		border-bottom: none;
	}

	.woocommerce-MyAccount-navigation a {
		padding: 8px 14px;
		border: 1px solid var(--color-border);
		border-radius: var(--radius-sm);
		font-size: var(--typo-body_small-size, 13px);
	}

	.woocommerce-MyAccount-navigation .is-active a {
		background-color: var(--color-primary);
		border-color: var(--color-primary);
		color: var(--color-text-light);
	}
}
