/* =============================================================
   SHOP FRONT & COMMERCIAL GLAZING SECTION  —  .sf-*
   Add this block to assets/css/main.css above your existing
   @media (max-width: 768px) { ... } block.
   ============================================================= */

/* Section wrapper — navy canvas, no bottom padding (image bleeds) */
.sf-section {
	background: var(--navy);
	padding: 100px 48px 0;
	overflow: hidden;
}

/* ── Header row ─────────────────────────────────────── */
.sf-header {
	margin-bottom: 64px;
}

.sf-title {
	font-family: var(--font-serif);
	font-size: clamp(3rem, 4.5vw, 5rem);
	font-weight: 300;
	line-height: 1.05;
	color: var(--ice);
	margin: 16px 0 0;
	max-width: 700px;
}

.sf-title em {
	font-style: italic;
	color: var(--steel-light);
}

/* ── Two-column body ────────────────────────────────── */
.sf-body {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: 80px;
	align-items: start;
}

/* ── Image stack (left column) ──────────────────────── */
.sf-image-stack {
	position: relative;
	height: 640px;
}

/* Primary: fills the full column height */
.sf-img-primary {
	position: absolute;
	inset: 0;
	overflow: hidden;
}

.sf-img-primary img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	filter: brightness(0.88);
}

/* Secondary: smaller image overlapping bottom-right corner */
.sf-img-secondary {
	position: absolute;
	bottom: -40px;
	right: -40px;
	width: 55%;
	height: 240px;
	overflow: hidden;
	border: 4px solid var(--navy);
	z-index: 2;
}

.sf-img-secondary img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Badge overlay — top-left of the primary image */
.sf-img-badge {
	position: absolute;
	top: 28px;
	left: 28px;
	background: rgba(13, 27, 42, 0.82);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border: 1px solid rgba(74, 127, 165, 0.35);
	padding: 16px 22px;
	z-index: 3;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.sf-badge-num {
	font-family: var(--font-serif);
	font-size: 2.2rem;
	font-weight: 300;
	color: var(--steel-light);
	line-height: 1;
}

.sf-badge-label {
	font-size: 0.68rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(242, 246, 249, 0.55);
}

/* ── Content column (right) ─────────────────────────── */
.sf-content {
	padding: 8px 0 80px;
}

/* Lead paragraph with left accent rule */
.sf-lead {
	font-size: 1rem;
	line-height: 1.9;
	color: rgba(242, 246, 249, 0.7);
	margin-bottom: 44px;
	border-left: 2px solid var(--steel);
	padding-left: 22px;
}

/* ── Feature list ───────────────────────────────────── */
.sf-features {
	list-style: none;
	margin: 0 0 44px;
	padding: 0;
	display: flex;
	flex-direction: column;
}

.sf-feature-item {
	display: flex;
	gap: 20px;
	padding: 24px 0;
	border-bottom: 1px solid rgba(214, 228, 238, 0.1);
	align-items: flex-start;
}

.sf-feature-item:first-child {
	border-top: 1px solid rgba(214, 228, 238, 0.1);
}

/* Icon box */
.sf-feat-icon {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	border: 1px solid rgba(74, 127, 165, 0.4);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--steel-light);
	margin-top: 2px;
}

.sf-feat-body {
	flex: 1;
}

.sf-feat-title {
	display: block;
	font-family: var(--font-serif);
	font-size: 1.1rem;
	font-weight: 400;
	color: var(--ice);
	margin-bottom: 6px;
	letter-spacing: 0.01em;
}

.sf-feat-desc {
	font-size: 0.87rem;
	line-height: 1.8;
	color: rgba(242, 246, 249, 0.55);
	margin: 0;
}

/* ── Trust bar ──────────────────────────────────────── */
.sf-trust-bar {
	display: flex;
	align-items: stretch;
	border: 1px solid rgba(74, 127, 165, 0.25);
	margin-bottom: 40px;
	background: rgba(255, 255, 255, 0.03);
}

.sf-trust-item {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: 20px 24px;
}

.sf-trust-num {
	font-family: var(--font-serif);
	font-size: 1.6rem;
	font-weight: 300;
	color: var(--steel-light);
	line-height: 1;
}

.sf-trust-label {
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(242, 246, 249, 0.45);
}

/* Divider between trust items */
.sf-trust-div {
	width: 1px;
	background: rgba(74, 127, 165, 0.25);
	flex-shrink: 0;
}

/* ── CTA buttons ────────────────────────────────────── */
.sf-actions {
	display: flex;
	gap: 24px;
	align-items: center;
	flex-wrap: wrap;
}

/* =============================================================
   RESPONSIVE OVERRIDES
   Drop each block inside the matching breakpoint in main.css
   ============================================================= */

/* ── Inside @media (max-width: 1100px) ── */
@media (max-width: 1100px) {
  .sf-body             { grid-template-columns: 1fr; gap: 0; }
  .sf-image-stack      { position: relative; height: 420px; margin-bottom: 0; }
  .sf-img-secondary    { bottom: -28px; right: -16px; width: 48%; height: 200px; border-width: 3px; }
  .sf-content          { padding: 56px 0 60px; }
  .sf-title            { font-size: clamp(2.6rem, 5vw, 4rem); }
}

/* ── Inside @media (max-width: 768px) ── */
@media (max-width: 768px) {
  .sf-section          { padding: 64px 24px 0; }
  .sf-header           { margin-bottom: 36px; }
  .sf-title            { font-size: clamp(2.2rem, 8vw, 3rem); margin-top: 12px; }
  .sf-image-stack      { height: 300px; }
  .sf-img-secondary    { display: none; }
  .sf-img-badge        { top: 16px; left: 16px; padding: 12px 16px; }
  .sf-badge-num        { font-size: 1.8rem; }
  .sf-content          { padding: 40px 0 48px; }
  .sf-lead             { font-size: 0.93rem; margin-bottom: 32px; padding-left: 16px; }
  .sf-feat-title       { font-size: 1rem; }
  .sf-feat-desc        { font-size: 0.84rem; }
  .sf-feature-item     { padding: 20px 0; gap: 16px; }
  .sf-features         { margin-bottom: 32px; }
  .sf-trust-bar        { flex-direction: column; border: 1px solid rgba(74,127,165,0.25); margin-bottom: 32px; }
  .sf-trust-item       { padding: 16px 20px; flex-direction: row; justify-content: space-between; align-items: center; }
  .sf-trust-num        { font-size: 1.3rem; }
  .sf-trust-div        { width: 100%; height: 1px; background: rgba(74,127,165,0.2); flex-shrink: 0; }
  .sf-actions          { flex-direction: column; gap: 12px; }
  .sf-actions a        { text-align: center; width: 100%; box-sizing: border-box; }

}

/* ── Inside @media (max-width: 480px) ── */
@media (max-width: 480px) {
  .sf-section          { padding: 48px 20px 0; }
  .sf-title            { font-size: clamp(2rem, 10vw, 2.6rem); }
  .sf-image-stack      { height: 240px; }
  .sf-img-badge        { top: 12px; left: 12px; padding: 10px 14px; }
  .sf-badge-num        { font-size: 1.5rem; }
  .sf-badge-label      { font-size: 0.62rem; }
  .sf-content          { padding: 32px 0 40px; }
  .sf-lead             { font-size: 0.88rem; line-height: 1.8; }
  .sf-feat-icon        { width: 30px; height: 30px; }
  .sf-feature-item     { gap: 12px; }
  .sf-trust-item       { flex-direction: column; align-items: flex-start; gap: 3px; padding: 14px 16px; }
  .sf-suburb-list      { font-size: 0.74rem; }
}

/* ── FORMINATOR OVERRIDES ─────────────────────────────── */
.contact-form-wrap .forminator-input,
.contact-form-wrap .forminator-textarea,
.contact-form-wrap .forminator-select,
.contact-form-wrap .forminator-input-with-limit {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  color: var(--ice) !important;
  font-family: var(--font-sans) !important;
  font-size: 0.9rem !important;
  padding: 13px 15px !important;
  border-radius: var(--radius) !important;
  width: 100% !important;
}

.contact-form-wrap .forminator-input::placeholder,
.contact-form-wrap .forminator-textarea::placeholder {
  color: rgba(242,246,249,0.28) !important;
}

.contact-form-wrap .forminator-input:focus,
.contact-form-wrap .forminator-textarea:focus {
  border-color: var(--steel) !important;
  outline: none !important;
}

.contact-form-wrap .forminator-label,
.contact-form-wrap .forminator-field-label,
.contact-form-wrap label {
  color: rgba(242,246,249,0.5) !important;
  font-size: 0.68rem !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
}

.contact-form-wrap .forminator-btn-submit {
  background: var(--steel) !important;
  color: var(--ice) !important;
  border: none !important;
  width: 100% !important;
  font-family: var(--font-sans) !important;
  font-size: 0.82rem !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  padding: 15px 24px !important;
  border-radius: var(--radius) !important;
  cursor: pointer !important;
  transition: background var(--transition) !important;
}

.contact-form-wrap .forminator-btn-submit:hover {
  background: var(--steel-light) !important;
}