/* ============================================================
   SignUp.php — Prospect Signup Page Layout
   Design System v2.0 page-specific styles
   ============================================================ */

/* ====== PAGE FOOTER ====== */

.signup-page-footer {
	padding: 20px 0 8px;
	text-align: center;
}


.signup-dev-tools {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	margin-bottom: 16px;
}

.signup-dev-link {
	font-size: 12px;
	color: var(--ezs-gray-500, #9E9E9E);
}

/* ---- Page background ---- */
.signup-prospect-wrapper {
	max-width: 960px;
	margin: 0 auto;
	padding: 40px 24px 40px;
}

.signup-plans-grid-wrapper {
	max-width: 1000px;
	margin: 0 auto;
	padding: 40px 24px 60px;
}

/* ---- Light tint behind the page ---- */
.ezs-app.signup-page-bg {
	min-height: unset;
	background: var(--ezs-primary-50, #e9f4fb);
	padding-bottom: 40px;
}

/* ====== STANDARD (no-plan) FORM LAYOUT ====== */

.signup-standard-wrapper {
	max-width: 480px;
	margin: 0 auto;
	padding: 40px 24px 40px;
}

.signup-standard-wrapper .signup-form-panel-intro {
	margin-bottom: 20px;
}

.signup-standard-card {
	box-shadow: 0px 2px 8px rgba(0,0,0,0.12), 0px 1px 3px rgba(0,0,0,0.08);
	border-radius: 12px !important;
	overflow: hidden;
}

/* Legal footer under standard card — narrower to match card */
.signup-standard-wrapper .signup-legal-footer {
	max-width: 100%;
}

/* ====== UNIFIED CARD LAYOUT ====== */

.signup-unified-card {
	display: flex;
	overflow: hidden;
	border-radius: 12px;
	box-shadow: 0px 2px 8px rgba(0,0,0,0.12), 0px 1px 3px rgba(0,0,0,0.08);
}

/* Left: gradient plan panel */
.signup-plan-col {
	flex: 1 1 0;
	min-width: 0;
	background: linear-gradient(165deg, var(--ezs-primary-700, #1576b5), var(--ezs-primary-500, #1998d5));
	display: flex;
	flex-direction: column;
	justify-content: center;
}

/* Right: white form panel */
.signup-form-col {
	flex: 1 1 0;
	min-width: 0;
	background: white;
	display: flex;
	flex-direction: column;
}

/* ====== PLAN PANEL — LEFT ====== */

/* Header within gradient panel — no bg needed, panel handles it */
.signup-plan-header {
	padding: 32px 28px 24px;
}

/* Affiliate pill on gradient plan panel */
.signup-plan-affiliate-pill {
	display: inline-flex;
	align-items: center;
	background: rgba(255, 255, 255, 0.18);
	border: 1px solid rgba(255, 255, 255, 0.35);
	border-radius: 20px;
	padding: 3px 12px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.9);
	margin: 0 0 12px 0;
}

.signup-plan-header .signup-plan-name {
	font-size: 22px;
	font-weight: 500;
	color: white;
	margin: 0 0 20px 0;
	line-height: 1.3;
}

.signup-plan-price-row {
	display: flex;
	align-items: center;
	justify-content: center;
}

.signup-plan-price-label {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: rgba(255, 255, 255, 0.7);
	margin: 0 0 4px;
}

.signup-plan-tank-rate {
	font-size: 13px;
	color: rgba(255, 255, 255, 0.75);
	margin: 4px 0 0;
}

.signup-plan-price-badge {
	display: inline-flex;
	align-items: baseline;
	gap: 4px;
	background: rgba(255, 255, 255, 0.18);
	border: 1px solid rgba(255, 255, 255, 0.3);
	border-radius: 10px;
	padding: 8px 14px;
	position: relative;
}

/* Info icon anchored to top-right corner of price badge */
.signup-price-help-tip {
	position: absolute;
	top: -10px;
	right: -10px;
	margin: 0;
	padding: 0;
	background: var(--ezs-primary-600, #1565c0);
	border: 1px solid rgba(255, 255, 255, 0.4);
	border-radius: 50%;
	width: 22px;
	height: 22px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}

.signup-price-help-tip:hover {
	background: var(--ezs-primary-700, #0d47a1);
}

.signup-price-help-tip .material-icons {
	color: var(--ezs-primary-100, #bbdefb);
	font-size: 18px;
	line-height: 1;
	pointer-events: none;
}

.signup-plan-price-amount {
	font-size: 28px;
	font-weight: 600;
	line-height: 1;
	color: white;
}

.signup-plan-price-period {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.85);
}

/* Marketing content — shown directly in gradient panel */
.signup-plan-marketing {
	padding: 0 28px 24px;
	font-size: 14px;
	line-height: 1.7;
	color: rgba(255, 255, 255, 0.9);
	flex: 1;
	text-align: left;
}

.signup-plan-marketing ul {
	list-style: none;
	padding-left: 0;
	margin: 0;
}

.signup-plan-marketing ul li {
	padding: 4px 0 4px 26px;
	position: relative;
}

.signup-plan-marketing ul li::before {
	font-family: 'Material Icons';
	content: 'check_circle';
	font-size: 16px;
	color: rgba(255, 255, 255, 0.9);
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}


/* ====== FORM PANEL — RIGHT ====== */

/* Centered intro block — pill + heading above the form fields */
.signup-form-panel-intro {
	text-align: center;
	margin-bottom: 24px;
}

.signup-form-panel-title {
	font-size: 22px;
	font-weight: 400;
	color: var(--ezs-gray-900, #212121);
	margin: 8px 0 0;
	letter-spacing: -0.01em;
}

/* Affiliate pill inside form panel */
.signup-form-affiliate-pill {
	display: inline-flex;
	align-items: center;
	background: white;
	color: var(--ezs-primary-700, #1576b5);
	border: 1px solid var(--ezs-primary-200, #a8d4ef);
	border-radius: 20px;
	padding: 3px 12px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	white-space: nowrap;
}

.signup-form-panel-body {
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 28px 28px;
	overflow-y: auto;
}

/* Inner wrapper replacing RoundedDiv in prospect mode */
.signup-form-inner {
	font-size: 14px !important;
}

/* ---- Styled inputs within prospect form card ---- */
.signup-form-col input.BasicTextBox,
.signup-form-col select.ChooserBox {
	float: none !important;
	display: block !important;
	width: 100% !important;
	height: 44px;
	padding: 0 14px !important;
	border: 1px solid var(--ezs-outline-variant, #BDBDBD) !important;
	border-radius: var(--ezs-radius-md, 8px) !important;
	font-size: 14px !important;
	font-family: inherit !important;
	color: var(--ezs-gray-900, #212121) !important;
	background: #fff !important;
	box-sizing: border-box !important;
	transition: border-color 0.15s ease, box-shadow 0.15s ease !important;
	margin-bottom: 10px !important;
	box-shadow: none !important;
}

.signup-form-col input.BasicTextBox:focus,
.signup-form-col select.ChooserBox:focus {
	outline: none !important;
	border-color: var(--ezs-primary-500, #1998d5) !important;
	box-shadow: 0 0 0 3px var(--ezs-primary-100, #d2e9f7) !important;
}

.signup-form-col input.BasicTextBox::placeholder {
	color: var(--ezs-gray-500, #9E9E9E);
	font-size: 13px;
}

/* Zip code — allow narrower but still block */

/* ---- Google sign-in — full width, pill shape ---- */
.signup-google-wrapper {
	width: 100%;
	margin: 4px 0 8px;
}

/* Force the GSI iframe container to fill the wrapper */
.signup-google-wrapper > div,
.signup-google-wrapper iframe {
	width: 100% !important;
	max-width: 400px !important;
}

/* ---- Helper text below email/google choice ---- */
.signup-helper-text {
	font-size: 12px;
	color: var(--ezs-gray-500, #9E9E9E);
	text-align: center;
	margin: 10px 0 0;
}

.signup-back-link,
.signup-view-plans-link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 13px;
	color: var(--ezs-gray-500, #9E9E9E);
	text-decoration: none;
}

.signup-back-link {
	margin-bottom: 14px;
}

.signup-view-plans-link {
	margin-top: 10px;
}

.signup-back-link:hover,
.signup-view-plans-link:hover {
	color: var(--ezs-gray-700, #616161);
}

.signup-back-link .material-icons,
.signup-view-plans-link .material-icons {
	font-size: 15px;
}

/* ---- reCAPTCHA in prospect layout ---- */
.signup-recaptcha {
	margin-top: 16px !important;
}

/* ---- "or" divider ---- */
.signup-or-divider {
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 12px 0 16px;
	color: var(--ezs-gray-500, #9E9E9E);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.signup-or-divider::before,
.signup-or-divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background: var(--ezs-outline, #E0E0E0);
}

/* ---- "Sign Up With Email" button in prospect context ---- */
.signup-form-col .MediumButton[onclick*="standardSignup"] {
	width: 100%;
	height: 44px;
	background: transparent;
	color: var(--ezs-primary-600, #1888c8);
	border: 1.5px solid var(--ezs-primary-400, #4aadde);
	border-radius: 22px;
	font-size: 14px;
	font-weight: 500;
	font-family: inherit;
	cursor: pointer;
	transition: background 0.15s ease, border-color 0.15s ease;
}

.signup-form-col .MediumButton[onclick*="standardSignup"]:hover {
	background: var(--ezs-primary-50, #e9f4fb);
	border-color: var(--ezs-primary-600, #1888c8);
}

/* ---- Submit button ---- */
input[type=submit]#btnCreateAccount {
	margin-top: 24px;
}

.signup-form-col input[type=submit]#btnCreateAccount,
.signup-form-col input[type=submit]#btnLogin {
	display: block;
	width: 100%;
	height: 48px;
	background: var(--ezs-primary-500, #1998d5);
	color: white;
	border: none;
	border-radius: 24px;
	font-size: 15px;
	font-weight: 500;
	font-family: inherit;
	letter-spacing: 0.02em;
	cursor: pointer;
	margin-top: 24px;
	transition: background 0.15s ease, box-shadow 0.15s ease;
	box-shadow: 0px 1px 2px rgba(0,0,0,0.25), 0px 1px 3px rgba(0,0,0,0.12);
}

.signup-form-col input[type=submit]#btnCreateAccount:hover,
.signup-form-col input[type=submit]#btnLogin:hover {
	background: var(--ezs-primary-700, #1576b5);
	box-shadow: 0px 2px 6px rgba(0,0,0,0.25), 0px 1px 3px rgba(0,0,0,0.12);
}

/* ---- Show/hide password link ---- */
.signup-form-col #txtPassword + div a {
	font-size: 13px;
	color: var(--ezs-primary-500, #1998d5);
}

/* ---- Error message ---- */
.signup-form-col div[style*="color:red"] {
	background: #fdecea;
	border: 1px solid #f5c6c3;
	border-radius: 6px;
	padding: 10px 14px;
	font-size: 13px;
	color: #c0392b !important;
	margin-bottom: 14px;
}

/* ---- Affiliate name bold text inside form ---- */
.signup-form-col b {
	display: block;
	font-size: 14px;
	color: var(--ezs-gray-700, #616161);
	margin-bottom: 12px;
}

/* ---- "Creating account for another" notice ---- */
.signup-form-col span[style*="1998d5"] {
	display: block;
	margin-bottom: 12px;
	font-size: 13px !important;
}

/* ====== ALL-PLANS GRID ====== */

.signup-affiliate-pill {
	display: inline-flex;
	align-items: center;
	background: white;
	color: var(--ezs-primary-600, #1888c8);
	border: 1px solid var(--ezs-primary-200, #a8d4ef);
	border-radius: 20px;
	padding: 4px 14px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin-bottom: 12px;
}

.signup-plans-grid-heading {
	font-size: 28px;
	font-weight: 400;
	color: var(--ezs-gray-900, #212121);
	margin: 0 0 6px 0;
}

.signup-plans-grid-subheading {
	font-size: 15px;
	color: var(--ezs-gray-600, #757575);
	margin: 0 0 28px 0;
}

.signup-plans-grid {
	display: grid;
	grid-template-columns: repeat(var(--grid-cols, 3), 1fr);
	gap: 20px;
}

/* Plan selection card */
.signup-plan-select-card {
	color: inherit;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	transition: box-shadow 0.2s ease;
}

.signup-plan-select-card:hover {
	box-shadow: 0px 6px 16px rgba(0, 0, 0, 0.18), 0px 2px 6px rgba(0, 0, 0, 0.12);
}

.signup-plan-select-header {
	background: linear-gradient(145deg, var(--ezs-primary-700, #1576b5), var(--ezs-primary-500, #1998d5));
	padding: 20px 20px 18px;
}

.signup-plan-select-name {
	font-size: 17px;
	font-weight: 500;
	color: white;
	margin: 0 0 10px 0;
}

.signup-plan-select-price {
	font-size: 22px;
	font-weight: 600;
	color: white;
	line-height: 1;
}

.signup-plan-select-period {
	font-size: 13px;
	font-weight: 400;
	color: rgba(255, 255, 255, 0.85);
}


/* Body grows to fill card, pushing footer to bottom */
.signup-plan-select-body {
	padding: 16px 20px 20px;
	flex: 1;
}

.signup-plan-select-cta {
	display: block;
	width: 100%;
	padding: 10px;
	background: var(--ezs-primary-50, #e9f4fb);
	color: var(--ezs-primary-600, #1888c8) !important;
	text-align: center;
	border-radius: 20px;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.02em;
	transition: background 0.15s ease, color 0.15s ease;
	box-sizing: border-box;
	text-decoration: none !important;
}

.signup-plan-select-cta:hover {
	background: var(--ezs-primary-500, #1998d5);
	color: white !important;
}

/* ====== PLAN DETAILS MODAL BUTTON ====== */

/* Shared button style — used on grid cards */
.signup-plan-details-btn {
	flex: 1;
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 10px 8px 10px 20px;
	background: none;
	border: none;
	cursor: pointer;
	font-size: 13px;
	font-weight: 500;
	color: var(--ezs-gray-600, #757575);
	text-align: left;
	transition: color 0.15s ease, background 0.15s ease;
}

.signup-plan-details-btn:hover {
	color: var(--ezs-gray-800, #424242);
	background: var(--ezs-gray-50, #FAFAFA);
}

.signup-plan-details-btn .material-icons {
	font-size: 16px;
	color: inherit;
	flex-shrink: 0;
}

/* Grid card: details button footer — white secondary action */
.signup-plan-select-card .signup-plan-details-btn {
	width: 100%;
	background: white;
	border-top: 1px solid #F0F0F0;
	padding: 10px 20px;
	color: var(--ezs-gray-600, #757575);
	justify-content: center;
	font-size: 12px;
}

.signup-plan-select-card .signup-plan-details-btn .material-icons {
	color: inherit;
	font-size: 15px;
}

.signup-plan-select-card .signup-plan-details-btn:hover {
	background: var(--ezs-gray-50, #FAFAFA);
	color: var(--ezs-gray-800, #424242);
}

/* ====== FORM FIELD GROUPING ====== */

/* First + Last name side-by-side */
.signup-name-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}

.signup-name-row .BasicTextBox {
	margin-bottom: 0 !important;
}

/* Section label */
.signup-section-label {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ezs-gray-500, #9E9E9E);
	margin: 14px 0 8px;
	text-align: left;
}

/* ====== SIGN IN / CREATE ACCOUNT LINKS ====== */

.login-links {
	margin-top: 16px;
	text-align: center;
	font-size: 13px;
	color: var(--ezs-gray-600, #757575);
}

.login-links a {
	color: var(--ezs-primary-600, #1888c8);
	text-decoration: none;
}

.login-links a:hover {
	text-decoration: underline;
}

.login-links .login-links-divider {
	margin: 0 8px;
	color: var(--ezs-gray-400, #BDBDBD);
}

/* ====== LEGAL FOOTER ====== */

.signup-legal-footer {
	max-width: 912px;
	margin: 16px auto 0;
	font-size: 12px;
	color: var(--ezs-gray-500, #9E9E9E);
	text-align: center;
}

.signup-legal-footer a {
	color: inherit;
}

/* ====== POPULATE TEST DATA BUTTON ====== */

.signup-test-btn-wrapper {
	margin-top: 12px;
	text-align: center;
}

.signup-test-btn-wrapper button {
	font-size: 12px;
	color: var(--ezs-gray-500, #9E9E9E);
	background: none;
	border: 1px dashed var(--ezs-outline, #E0E0E0);
	border-radius: 6px;
	padding: 6px 14px;
	cursor: pointer;
}

.signup-test-btn-wrapper button:hover {
	background: var(--ezs-gray-100, #F5F5F5);
}

/* ====== MOBILE ====== */

@media (max-width: 767px) {
	.signup-unified-card {
		flex-direction: column;
		border-radius: 8px;
	}

	.signup-plan-col,
	.signup-form-col {
		flex: none;
		width: 100%;
	}

	.signup-plans-grid {
		grid-template-columns: 1fr;
	}

	.signup-prospect-wrapper,
	.signup-plans-grid-wrapper {
		padding: 20px 16px 40px;
	}

	.signup-name-row {
		grid-template-columns: 1fr;
	}
}

@media (min-width: 768px) and (max-width: 1023px) {
	.signup-plans-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ====== STANDARD DELIVERY CARD (no subscription) ====== */




.signup-standard-delivery-footer {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	border-top: 1px solid #F0F0F0;
	padding: 12px 20px 16px;
	background: white;
}

.signup-standard-delivery-footer .signup-plan-select-period {
	color: var(--ezs-gray-500, #9E9E9E) !important;
}

.signup-standard-delivery-price {
	font-size: 12px;
	font-weight: 500;
	color: var(--ezs-gray-600, #757575);
}

.signup-standard-delivery-sep {
	color: var(--ezs-gray-400, #BDBDBD);
}

.signup-standard-delivery-min {
	font-size: 12px;
	color: var(--ezs-gray-500, #9E9E9E);
}

.signup-price-check-label {
	font-size: 12px;
	color: var(--ezs-gray-600, #757575);
	margin: 0 0 6px;
	text-align: left;
}

.signup-standard-delivery-bottom-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-top: 10px;
}

.signup-standard-delivery-cta {
	flex-shrink: 0;
	width: auto !important;
	padding: 10px 20px !important;
	white-space: nowrap;
}

.signup-price-check-result {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 4px;
	font-size: 12px;
	transition: opacity 0.2s ease;
}

.signup-price-default-label {
	font-size: 11px;
	font-weight: 700;
	color: var(--ezs-primary-500, #1998d5);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	width: 100%;
	text-align: left;
}

.signup-price-specific-label {
	font-size: 11px;
	font-weight: 700;
	color: var(--ezs-primary-500, #1998d5);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	width: 100%;
	text-align: left;
}

/* ====== INLINE PRICE CHECK (no BagPrice set) ====== */

.signup-price-check {
	display: flex;
	gap: 6px;
	margin-bottom: 8px;
}

.signup-price-check-input {
	flex: 1;
	min-width: 0;
	height: 44px;
	padding: 0 14px;
	font-size: 14px;
	border: 1px solid var(--ezs-outline-variant, #BDBDBD);
	border-radius: var(--ezs-radius-md, 8px);
	outline: none;
	font-family: inherit;
	color: var(--ezs-gray-900, #212121);
	background: #fff;
	box-sizing: border-box;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.signup-price-check-input::placeholder {
	color: var(--ezs-gray-500, #9E9E9E);
	font-size: 13px;
}

.signup-price-check-input:focus {
	border-color: var(--ezs-primary-500, #1998d5);
	box-shadow: 0 0 0 3px var(--ezs-primary-100, #d2e9f7);
}

.signup-price-check-btn {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--ezs-primary-600, #1888c8);
	color: white;
	border: none;
	border-radius: var(--ezs-radius-md, 8px);
	cursor: pointer;
}

.signup-price-check-btn .material-icons {
	font-size: 18px;
}

.signup-price-check-btn:hover {
	background: var(--ezs-primary-700, #1570a8);
}

.signup-price-check-loading {
	color: var(--ezs-gray-500, #9E9E9E);
}

.signup-price-check-available {
	color: var(--ezs-success, #2E7D32);
	font-weight: 500;
}

.signup-price-check-unavailable {
	color: var(--ezs-gray-500, #9E9E9E);
}

.signup-price-check-tank {
	font-size: 12px;
	color: var(--ezs-gray-600, #757575);
	margin-top: 2px;
}

.signup-price-check-no-driver {
	font-size: 12px;
	color: var(--ezs-warning, #E65100);
	margin-top: 4px;
}

.signup-price-check-error {
	color: var(--ezs-error, #C62828);
	font-size: 12px;
}
