/* ============================================================
   Luxury Garden Rooms — Enquiry Form
   Palette: Navy  #12232e  |  Off-white  #F5F5F3
            Mid   #1e3448  |  Pill bg    #EAEAE8
   Fonts:   Cormorant Garamond (display) + Jost (body)
   ============================================================ */

:root {
	--lgr-navy:        #12232e;
	--lgr-navy-mid:    #1e3448;
	--lgr-bg:          #F5F5F3;
	--lgr-white:       #FFFFFF;
	--lgr-text:        #12232e;
	--lgr-text-mid:    #4a6070;
	--lgr-text-light:  #7a8e99;
	--lgr-border:      #DDD9D4;
	--lgr-pill-bg:     #EAEAE8;

	--lgr-font-display: 'Cormorant Garamond', Georgia, serif;
	--lgr-font-body:    'Jost', system-ui, sans-serif;

	--lgr-radius:    4px;
	--lgr-radius-lg: 8px;
	--lgr-shadow:    0 2px 16px rgba(18, 35, 46, 0.07);
	--lgr-transition: 0.2s ease;
}

/* ── Wrapper ───────────────────────────────────────────────── */
.lgr-form-wrapper {
	font-family: var(--lgr-font-body);
	color: var(--lgr-text);
	background: var(--lgr-white);
	border-radius: var(--lgr-radius-lg);
	box-shadow: var(--lgr-shadow);
	max-width: 900px;
	margin: 0 auto;
	overflow: hidden;
}

/* ── Progress Bar ──────────────────────────────────────────── */
.lgr-progress {
	background: var(--lgr-navy);
	padding: 24px 48px;
}

.lgr-progress-steps {
	display: flex;
	align-items: center;
	justify-content: center;
}

.lgr-progress-step {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 7px;
	opacity: 0.4;
	transition: opacity var(--lgr-transition);
}

.lgr-progress-step.active,
.lgr-progress-step.completed { opacity: 1; }

.lgr-step-number {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 1px solid rgba(255,255,255,0.35);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	font-weight: 400;
	color: rgba(255,255,255,0.6);
	transition: background var(--lgr-transition), border-color var(--lgr-transition), color var(--lgr-transition);
}

.lgr-progress-step.active .lgr-step-number {
	background: rgba(255,255,255,0.15);
	border-color: rgba(255,255,255,0.8);
	color: #fff;
}
.lgr-progress-step.completed .lgr-step-number {
	background: rgba(255,255,255,0.2);
	border-color: rgba(255,255,255,0.6);
	color: #fff;
}

.lgr-step-label {
	font-size: 10px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.45);
	font-weight: 400;
}
.lgr-progress-step.active .lgr-step-label  { color: rgba(255,255,255,0.9); }
.lgr-progress-step.completed .lgr-step-label { color: rgba(255,255,255,0.65); }

.lgr-progress-divider {
	width: 56px;
	height: 1px;
	background: rgba(255,255,255,0.14);
	margin: 0 20px;
	margin-bottom: 20px;
}

/* ── Step Container ────────────────────────────────────────── */
.lgr-step {
	display: none;
	padding: 52px 48px 44px;
	animation: lgrFadeIn 0.3s ease;
}
.lgr-step.lgr-step-active { display: block; }

@keyframes lgrFadeIn {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ── Step Header ───────────────────────────────────────────── */
.lgr-step-eyebrow {
	font-size: 10px;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--lgr-text-light);
	font-weight: 400;
	margin: 0 0 12px;
}

.lgr-step-title {
	font-family: var(--lgr-font-display);
	font-size: 42px;
	font-weight: 400;
	color: var(--lgr-navy);
	margin: 0 0 10px;
	line-height: 1.1;
	letter-spacing: 0.01em;
}

.lgr-step-subtitle {
	font-size: 15px;
	color: var(--lgr-text-mid);
	font-weight: 300;
	margin: 0 0 40px;
	line-height: 1.65;
}

/* ── Model Grid ────────────────────────────────────────────── */
.lgr-model-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 18px;
}

.lgr-model-card {
	background: var(--lgr-bg);
	border: 1px solid transparent;
	border-radius: var(--lgr-radius);
	padding: 0;
	cursor: pointer;
	text-align: left;
	transition: border-color var(--lgr-transition), box-shadow var(--lgr-transition), transform var(--lgr-transition);
	overflow: hidden;
}
.lgr-model-card:hover {
	border-color: var(--lgr-navy);
	box-shadow: var(--lgr-shadow);
	transform: translateY(-2px);
}
.lgr-model-card.selected {
	border-color: var(--lgr-navy);
	box-shadow: 0 0 0 2px rgba(18,35,46,0.1);
}

.lgr-model-card-inner { padding: 32px 28px 0; }

/* Model heading — large serif matching site */
.lgr-model-badge {
	display: block;
	font-family: var(--lgr-font-display);
	font-size: 30px;
	font-weight: 500;
	color: var(--lgr-navy);
	margin-bottom: 8px;
}

.lgr-model-tagline {
	font-size: 13px;
	color: var(--lgr-text-mid);
	font-weight: 300;
	margin: 0 0 20px;
	line-height: 1.6;
}

/* Pill specs — stacked column exactly like screenshot */
.lgr-model-specs {
	display: flex;
	flex-direction: column;
	gap: 7px;
	margin-bottom: 22px;
}

.lgr-spec          { display: block; }
.lgr-spec-label    { display: none; }
.lgr-spec-divider  { display: none; }

.lgr-spec-value {
	display: inline-block;
	background: var(--lgr-pill-bg);
	color: var(--lgr-navy);
	font-size: 13px;
	font-weight: 400;
	padding: 7px 14px;
	border-radius: 3px;
	letter-spacing: 0.01em;
}

.lgr-model-cta {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 500;
	color: var(--lgr-text-light);
	border-top: 1px solid var(--lgr-border);
	width: calc(100% + 56px);
	margin-left: -28px;
	padding: 13px 28px;
	transition: color var(--lgr-transition), gap var(--lgr-transition);
}
.lgr-model-card:hover .lgr-model-cta { color: var(--lgr-navy); gap: 10px; }

.lgr-arrow { transition: transform var(--lgr-transition); display: inline-block; }
.lgr-model-card:hover .lgr-arrow { transform: translateX(4px); }

/* ── Variant Grid ──────────────────────────────────────────── */
.lgr-variant-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
	margin-bottom: 32px;
}

.lgr-variant-card {
	background: var(--lgr-bg);
	border: 1px solid transparent;
	border-radius: var(--lgr-radius);
	padding: 28px 24px 20px;
	cursor: pointer;
	text-align: left;
	position: relative;
	transition: border-color var(--lgr-transition), box-shadow var(--lgr-transition), background var(--lgr-transition);
}
.lgr-variant-card:hover {
	border-color: var(--lgr-navy);
	background: var(--lgr-white);
	box-shadow: var(--lgr-shadow);
}
.lgr-variant-card.selected {
	border-color: var(--lgr-navy);
	background: var(--lgr-white);
	box-shadow: 0 0 0 2px rgba(18,35,46,0.08);
}

.lgr-variant-check {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: var(--lgr-navy);
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity var(--lgr-transition);
}
.lgr-variant-card.selected .lgr-variant-check { opacity: 1; }
.lgr-variant-check::after {
	content: '';
	width: 5px;
	height: 9px;
	border-right: 1.5px solid #fff;
	border-bottom: 1.5px solid #fff;
	transform: rotate(45deg) translateY(-1px);
}

.lgr-variant-name {
	font-family: var(--lgr-font-display);
	font-size: 22px;
	font-weight: 500;
	color: var(--lgr-navy);
	margin: 0 0 14px;
}

/* Pill specs in variants — same as model cards */
.lgr-variant-dims,
.lgr-variant-sqm,
.lgr-variant-price {
	display: block;
	background: var(--lgr-pill-bg);
	color: var(--lgr-navy);
	font-size: 13px;
	font-weight: 400;
	padding: 7px 14px;
	border-radius: 3px;
	margin-bottom: 7px;
	width: fit-content;
}

/* ── Selection Summary ─────────────────────────────────────── */
.lgr-selection-summary {
	display: flex;
	align-items: center;
	gap: 14px;
	background: var(--lgr-bg);
	border: 1px solid var(--lgr-border);
	border-radius: var(--lgr-radius);
	padding: 14px 18px;
	margin-bottom: 36px;
	flex-wrap: wrap;
}

.lgr-summary-label {
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--lgr-text-light);
	white-space: nowrap;
}

.lgr-summary-value {
	font-size: 14px;
	font-weight: 400;
	color: var(--lgr-navy);
	flex: 1;
}

.lgr-summary-change {
	background: none;
	border: 1px solid var(--lgr-border);
	border-radius: var(--lgr-radius);
	padding: 5px 14px;
	font-size: 10px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--lgr-text-mid);
	cursor: pointer;
	font-family: var(--lgr-font-body);
	transition: border-color var(--lgr-transition), color var(--lgr-transition);
}
.lgr-summary-change:hover { border-color: var(--lgr-navy); color: var(--lgr-navy); }

/* ── Contact Fields ────────────────────────────────────────── */
.lgr-fields-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 22px;
}

.lgr-field { display: flex; flex-direction: column; gap: 8px; }
.lgr-field-full { grid-column: 1 / -1; }

.lgr-field label {
	font-size: 10px;
	font-weight: 400;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--lgr-text-light);
}

.lgr-required { color: var(--lgr-navy); opacity: 0.4; }

.lgr-field input,
.lgr-field select,
.lgr-field textarea {
	font-family: var(--lgr-font-body);
	font-size: 14px;
	font-weight: 300;
	color: var(--lgr-navy);
	background: var(--lgr-bg);
	border: 1px solid var(--lgr-border);
	border-radius: var(--lgr-radius);
	padding: 12px 16px;
	width: 100%;
	box-sizing: border-box;
	transition: border-color var(--lgr-transition), box-shadow var(--lgr-transition), background var(--lgr-transition);
	-webkit-appearance: none;
	appearance: none;
}

.lgr-field select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%237a8e99' d='M5 6L0 0h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 36px;
}

.lgr-field textarea { resize: vertical; min-height: 110px; line-height: 1.65; }

.lgr-field input:focus,
.lgr-field select:focus,
.lgr-field textarea:focus {
	outline: none;
	border-color: var(--lgr-navy);
	background: var(--lgr-white);
	box-shadow: 0 0 0 3px rgba(18,35,46,0.06);
}

.lgr-field input::placeholder,
.lgr-field textarea::placeholder { color: var(--lgr-text-light); font-weight: 300; }

.lgr-field input.lgr-error,
.lgr-field select.lgr-error,
.lgr-field textarea.lgr-error { border-color: #B0392B; background: #FDF4F3; }

/* ── Form Footer ───────────────────────────────────────────── */
.lgr-form-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 36px;
	gap: 16px;
}

/* ── Buttons ───────────────────────────────────────────────── */
.lgr-btn-back {
	background: none;
	border: 1px solid var(--lgr-border);
	border-radius: var(--lgr-radius);
	padding: 12px 22px;
	font-family: var(--lgr-font-body);
	font-size: 11px;
	font-weight: 400;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--lgr-text-light);
	cursor: pointer;
	transition: border-color var(--lgr-transition), color var(--lgr-transition);
}
.lgr-btn-back:hover { border-color: var(--lgr-navy); color: var(--lgr-navy); }

.lgr-step-nav { display: flex; justify-content: flex-start; }

.lgr-btn-submit {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: var(--lgr-navy);
	color: #fff;
	border: none;
	border-radius: var(--lgr-radius);
	padding: 14px 40px;
	font-family: var(--lgr-font-body);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background var(--lgr-transition), transform var(--lgr-transition);
}
.lgr-btn-submit:hover:not(:disabled) { background: var(--lgr-navy-mid); transform: translateY(-1px); }
.lgr-btn-submit:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }

.lgr-btn-spinner {
	display: none;
	width: 14px;
	height: 14px;
	border: 1.5px solid rgba(255,255,255,0.3);
	border-top-color: #fff;
	border-radius: 50%;
	animation: lgrSpin 0.7s linear infinite;
}
.lgr-btn-submit.lgr-loading .lgr-btn-spinner { display: inline-block; }
.lgr-btn-submit.lgr-loading .lgr-btn-text   { opacity: 0.7; }
@keyframes lgrSpin { to { transform: rotate(360deg); } }

/* ── Privacy Note ──────────────────────────────────────────── */
.lgr-privacy-note {
	font-size: 11px;
	color: var(--lgr-text-light);
	font-weight: 300;
	margin-top: 20px;
	line-height: 1.7;
}
.lgr-privacy-note a { color: var(--lgr-text-light); text-decoration: underline; }

/* ── Global Error ──────────────────────────────────────────── */
.lgr-global-error {
	margin: 0 48px 24px;
	background: #FDF3F2;
	border: 1px solid #DDBBBA;
	border-radius: var(--lgr-radius);
	padding: 13px 18px;
	font-size: 13px;
	color: #7B2A25;
	font-weight: 300;
}

/* ── Success Screen ────────────────────────────────────────── */
.lgr-success {
	display: none;
	text-align: center;
	padding: 72px 48px;
}
.lgr-success.lgr-visible { display: block; animation: lgrFadeIn 0.5s ease; }

.lgr-success-icon {
	width: 54px;
	height: 54px;
	border-radius: 50%;
	background: var(--lgr-navy);
	color: #fff;
	font-size: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 28px;
}

.lgr-success-title {
	font-family: var(--lgr-font-display);
	font-size: 42px;
	font-weight: 400;
	color: var(--lgr-navy);
	margin: 0 0 16px;
}

.lgr-success-text {
	font-size: 15px;
	color: var(--lgr-text-mid);
	font-weight: 300;
	line-height: 1.75;
	max-width: 440px;
	margin: 0 auto 14px;
}

.lgr-success-ref {
	font-size: 11px;
	color: var(--lgr-text-light);
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 660px) {
	.lgr-step           { padding: 32px 24px; }
	.lgr-progress       { padding: 18px 24px; }
	.lgr-global-error   { margin: 0 24px 20px; }
	.lgr-success        { padding: 48px 24px; }
	.lgr-model-grid,
	.lgr-variant-grid,
	.lgr-fields-grid    { grid-template-columns: 1fr; }
	.lgr-step-title     { font-size: 32px; }
	.lgr-progress-divider { width: 24px; margin: 0 8px; margin-bottom: 20px; }
	.lgr-form-footer    { flex-direction: column-reverse; align-items: stretch; }
	.lgr-btn-submit     { justify-content: center; }
}
