/*
Theme Name: Saucon Insurance
Theme URI: https://sauconins.com
Author: Ledger Marketing
Author URI: https://ledgermarketing.com
Description: Custom full-site-editing (FSE) block theme for Saucon Insurance Company of Allentown, PA — a Lehigh Valley insurer since 1832. Warm, heritage, small-town brand built around the company's lantern mark. Self-building on activation.
Version: 1.0.0
Requires at least: 6.5
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: saucon
*/

/* ============================================================
   1. STRUCTURAL RESETS — kill block-gap strips (body bg leaks)
   ============================================================ */
.wp-site-blocks > * { margin-block: 0 !important; }
.wp-site-blocks main .alignfull { margin-block: 0 !important; }
.wp-site-blocks main > .alignfull:first-child { margin-block-start: 0 !important; }
:root { scroll-behavior: smooth; }
body { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }

.sic-eyebrow {
	font-family: var(--wp--preset--font-family--body);
	font-weight: 700;
	font-size: 0.78rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--wp--preset--color--brass);
}
.sic-lede { font-size: var(--wp--preset--font-size--large); color: var(--wp--preset--color--muted); line-height: 1.6; }
.sic-rule { width: 64px; height: 3px; background: var(--wp--preset--color--brass); border: 0; border-radius: 2px; }

/* ============================================================
   2. HEADER — utility bar + main bar + always-on Pay button
   ============================================================ */
.sic-topbar {
	background: var(--wp--preset--color--ink);
	color: var(--wp--preset--color--cream);
	font-size: 0.85rem;
}
.sic-topbar a { color: var(--wp--preset--color--cream); text-decoration: none; }
.sic-topbar a:hover { color: var(--wp--preset--color--periwinkle); }
.sic-topbar .sic-topbar-inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 1rem; padding-top: 0.5rem; padding-bottom: 0.5rem; flex-wrap: wrap;
	max-width: var(--wp--style--global--wide-size, 1200px);
	margin-inline: auto; padding-inline: clamp(1.25rem, 5vw, 4rem);
}
.sic-topbar strong { color: #fff; }
.sic-topbar a { display: inline-flex; align-items: center; gap: 0.35rem; }
.sic-topbar .sic-dot { color: var(--wp--preset--color--brass); margin: 0 0.5rem; }
.sic-ico { display: inline-flex; }
.sic-ico svg { width: 14px; height: 14px; fill: var(--wp--preset--color--brass); }

.sic-header {
	position: sticky; top: 0; z-index: 100;
	background: rgba(251,249,245,0.94);
	backdrop-filter: none; /* never backdrop-filter a sticky header — traps fixed overlay */
	border-bottom: 1px solid var(--wp--preset--color--line);
	box-shadow: 0 1px 0 rgba(28,31,48,0.04);
}
.sic-header-inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 1.25rem; padding-top: 0.7rem; padding-bottom: 0.7rem;
	max-width: var(--wp--style--global--wide-size, 1200px);
	margin-inline: auto; padding-inline: clamp(1.25rem, 5vw, 4rem);
}
.sic-logo img { display: block; height: 62px; width: auto; }
/* Kill WP flow-layout margin-block on flex children (was pushing the Pay button down) */
.sic-header-inner > *, .sic-header-right > * { margin-block: 0 !important; margin-top: 0 !important; }
.sic-header-right { display: flex; align-items: center; gap: 1.5rem; }

/* Nav links */
.sic-header .wp-block-navigation { font-family: var(--wp--preset--font-family--body); font-weight: 600; font-size: 0.98rem; }
.sic-header .wp-block-navigation a { color: var(--wp--preset--color--ink); }
.sic-header .wp-block-navigation a:hover,
.sic-header .wp-block-navigation .current-menu-item a { color: var(--wp--preset--color--indigo); }

/* Header Pay button — visible everywhere incl. mobile (NOT inside hamburger) */
.sic-pay-btn a, a.sic-pay-btn {
	display: inline-flex; align-items: center; gap: 0.5rem;
	background: var(--wp--preset--color--brass); color: #fff !important;
	font-family: var(--wp--preset--font-family--body); font-weight: 700;
	text-decoration: none; padding: 0.62rem 1.15rem; border-radius: 4px;
	font-size: 0.95rem; letter-spacing: 0.01em; line-height: 1; white-space: nowrap;
	box-shadow: 0 2px 0 var(--wp--preset--color--brass-dark);
	transition: background .15s ease, transform .15s ease;
}
.sic-pay-btn a:hover, a.sic-pay-btn:hover { background: var(--wp--preset--color--brass-dark); transform: translateY(-1px); }
.sic-pay-btn a svg, a.sic-pay-btn svg { width: 17px; height: 17px; fill: currentColor; }

/* ============================================================
   3. MOBILE NAV OVERLAY (core wins specificity — use body + !important)
   ============================================================ */
@media (max-width: 781px) {
	.sic-header-inner { flex-wrap: nowrap; }
	.sic-logo img { height: 48px; }
	.sic-header-right { gap: 0.6rem; }
	.sic-pay-btn a, a.sic-pay-btn { padding: 0.55rem 0.85rem; font-size: 0.85rem; }
	/* Keep Pay visible + left of the hamburger on mobile */
	body .sic-header-right a.sic-pay-btn { order: -1; }
}
@media (max-width: 900px) {
	.sic-foot-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
}
@media (max-width: 560px) {
	.sic-foot-grid { grid-template-columns: 1fr; }
	.sic-footer-bottom { flex-direction: column; }
}
body .wp-block-navigation__responsive-container.is-menu-open {
	background: var(--wp--preset--color--ink) !important;
	padding: clamp(3rem, 12vw, 5rem) clamp(1.5rem, 8vw, 4rem) !important;
	justify-content: center !important; align-items: flex-start !important;
}
body .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
	width: 100%; max-width: 460px; margin-inline: auto !important;
}
body .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
	gap: 0.2rem; width: 100%; align-items: center !important;
}
body .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item {
	align-items: center !important;   /* item is a flex column; inherits flex-end otherwise */
	width: 100%; text-align: center;
	border-bottom: 1px solid rgba(255,255,255,0.10);
}
body .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a {
	color: var(--wp--preset--color--cream) !important;
	font-family: var(--wp--preset--font-family--display) !important;
	font-size: 1.6rem !important; font-weight: 500 !important;
	padding: 0.85rem 0 !important; justify-content: center; width: 100%; text-align: center;
}
body .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a:hover {
	color: var(--wp--preset--color--brass) !important;
}
body .wp-block-navigation__responsive-container-close,
body .wp-block-navigation__responsive-container-open { color: var(--wp--preset--color--ink); }
body .is-menu-open .wp-block-navigation__responsive-container-close { color: var(--wp--preset--color--cream); }

/* Buttons used inside patterns */
.sic-btns { display: flex; gap: 0.9rem; flex-wrap: wrap; align-items: center; }
.sic-btn {
	display: inline-flex; align-items: center; gap: 0.55rem;
	background: var(--wp--preset--color--brass); color: #fff !important;
	font-family: var(--wp--preset--font-family--body); font-weight: 700; text-decoration: none;
	padding: 0.95rem 1.7rem; border-radius: 5px; font-size: 1.02rem; line-height: 1;
	box-shadow: 0 3px 0 var(--wp--preset--color--brass-dark); transition: transform .15s ease, background .15s ease;
}
.sic-btn:hover { transform: translateY(-2px); background: var(--wp--preset--color--brass-dark); }
.sic-btn svg { width: 18px; height: 18px; fill: currentColor; }
.sic-btn-ghost {
	display: inline-flex; align-items: center; gap: 0.5rem; font-weight: 600; text-decoration: none;
	border: 1.5px solid rgba(255,255,255,0.55); color: #fff !important;
	padding: 0.9rem 1.5rem; border-radius: 5px; transition: background .15s ease;
}
.sic-btn-ghost:hover { background: rgba(255,255,255,0.12); }
.sic-btn-dark {
	display: inline-flex; align-items: center; gap: 0.5rem; font-weight: 700; text-decoration: none;
	background: var(--wp--preset--color--indigo); color: #fff !important;
	padding: 0.95rem 1.7rem; border-radius: 5px; box-shadow: 0 3px 0 rgba(28,31,48,0.5); transition: transform .15s ease;
}
.sic-btn-dark:hover { transform: translateY(-2px); }
.sic-section-head { max-width: 640px; margin-inline: auto; text-align: center; }

/* ============================================================
   4. HERO — dark cover; force ALL heading levels white
   ============================================================ */
.sic-hero { position: relative; overflow: hidden; }
.sic-hero .sic-hero-media { position: absolute; inset: 0; }
.sic-hero .sic-hero-media img { width: 100%; height: 100%; object-fit: cover; }
.sic-hero :where(h1,h2,h3,h4,h5,h6,p,li,span,a.sic-plain) { color: #fff; }
.sic-hero .sic-eyebrow { color: var(--wp--preset--color--periwinkle); }
.sic-hero-inner { position: relative; z-index: 2; }

/* Generic dark band helper */
.sic-band-dark :where(h1,h2,h3,h4,h5,h6,p,li) { color: #fff; }
.sic-band-dark .sic-eyebrow { color: var(--wp--preset--color--brass); }

/* ============================================================
   5. PAY BAND — CTA on a same-color band must invert
   ============================================================ */
.sic-payband { position: relative; overflow: hidden; }
.sic-payband :where(h1,h2,h3,p,li) { color: #fff; }
.sic-payband .sic-eyebrow { color: var(--wp--preset--color--periwinkle); }
.sic-payband .sic-pay-lg a, .sic-payband a.sic-pay-lg {
	display: inline-flex; align-items: center; gap: .55rem;
	background: #fff !important; color: var(--wp--preset--color--brass-dark) !important;
	font-family: var(--wp--preset--font-family--body); font-weight: 700;
	text-decoration: none; padding: 1rem 2rem; border-radius: 5px; font-size: 1.1rem;
	box-shadow: 0 3px 0 rgba(0,0,0,0.18); transition: transform .15s ease;
}
.sic-payband .sic-pay-lg a:hover, .sic-payband a.sic-pay-lg:hover { transform: translateY(-2px); }
.sic-payband .sic-pay-lg svg { width: 20px; height: 20px; fill: currentColor; }

/* ============================================================
   6. PAGE HEADER BANDS (interior pages)
   ============================================================ */
.sic-pageheader { background: var(--wp--preset--color--ink); position: relative; overflow: hidden; }
.sic-pageheader::after {
	content:""; position:absolute; inset:0;
	background: radial-gradient(120% 140% at 85% -20%, rgba(154,160,210,0.22), transparent 60%);
	pointer-events:none;
}
.sic-pageheader :where(h1,h2,p,li) { color: #fff; position: relative; z-index: 2; }
.sic-pageheader .sic-eyebrow { color: var(--wp--preset--color--brass); position: relative; z-index: 2; }

/* ============================================================
   7. CARDS — content-height (no stretch)
   ============================================================ */
.sic-cards .wp-block-column, .sic-cards .wp-block-group.sic-card {
	background: #fff; border: 1px solid var(--wp--preset--color--line);
	border-radius: 10px; padding: 1.7rem !important; height: auto;
	box-shadow: 0 1px 2px rgba(28,31,48,0.04);
}
.sic-cards { align-items: start !important; max-width: 1120px; margin-inline: auto; }
.sic-card-icon {
	width: 46px; height: 46px; display: inline-flex; align-items: center; justify-content: center;
	background: var(--wp--preset--color--cream); border-radius: 9px; margin-bottom: 0.6rem;
}
.sic-card-icon svg { width: 24px; height: 24px; fill: var(--wp--preset--color--indigo); }
.sic-card h3 { margin: 0 0 0.4rem; font-size: 1.3rem; }
.sic-card p { color: var(--wp--preset--color--muted); font-size: 1rem; margin: 0; }

/* Agent / contact cards */
.sic-agent-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.4rem; align-items: start;
	max-width: var(--wp--style--global--wide-size, 1200px); margin-inline: auto; }
.sic-agent-town { color: var(--wp--preset--color--muted) !important; font-size: .9rem; margin: .15rem 0 .8rem; }
.sic-agent-contact a { color: var(--wp--preset--color--indigo); font-weight: 600; }
@media (max-width: 820px) { .sic-agent-grid { grid-template-columns: 1fr; } }
.sic-agents { align-items: start !important; }
.sic-agent {
	background:#fff; border:1px solid var(--wp--preset--color--line); border-radius:10px;
	padding:1.6rem !important; height:auto;
}
.sic-agent h3 { font-size:1.2rem; margin:0 0 .15rem; }
.sic-agent .sic-role { color:var(--wp--preset--color--brass); font-weight:700; font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; }
.sic-agent p { margin:.5rem 0 0; color:var(--wp--preset--color--muted); font-size:.98rem; }
.sic-agent a { text-decoration:none; }

/* ============================================================
   8. FEATURE ROWS / MISC
   ============================================================ */
.sic-stat-row { display: flex; gap: 2.5rem; flex-wrap: wrap; justify-content: center; text-align: center;
	max-width: var(--wp--style--global--wide-size, 1200px); margin-inline: auto; }
.sic-stat { flex: 1; min-width: 210px; }
.sic-stat .sic-statnum { font-family: var(--wp--preset--font-family--display); font-size: clamp(2.4rem,1.8rem+2.4vw,3.4rem); color: var(--wp--preset--color--indigo); font-weight:600; line-height:1; margin-bottom:.4rem; }
.sic-stat .sic-statlbl { color: var(--wp--preset--color--muted); font-size:.95rem; }
.sic-soft { background: var(--wp--preset--color--cream); }
.sic-quote { font-family: var(--wp--preset--font-family--display); font-size: clamp(1.4rem,1.1rem+1.4vw,2rem); line-height:1.35; color: var(--wp--preset--color--ink); }

/* Split (image + body) */
.sic-split { display: grid; grid-template-columns: 1fr 1.15fr; gap: clamp(1.5rem,4vw,3.5rem); align-items: center;
	max-width: var(--wp--style--global--wide-size, 1200px); margin-inline: auto; }
.sic-split-media img { width: 100%; height: 100%; object-fit: cover; border-radius: 12px; box-shadow: 0 10px 30px rgba(28,31,48,0.12); }
.sic-split-body h2 { margin: .3rem 0 .8rem; }
.sic-split-body p { color: var(--wp--preset--color--muted); margin: 0 0 1rem; }
@media (max-width: 820px) { .sic-split { grid-template-columns: 1fr; } .sic-split-media img { max-height: 320px; } }

.sic-timeline { margin-top: 1.5rem; display: grid; gap: .9rem; }
.sic-tl { display: grid; grid-template-columns: 76px 1fr; gap: 1rem; align-items: baseline; }
.sic-tl-year { font-family: var(--wp--preset--font-family--display); font-weight: 600; color: var(--wp--preset--color--brass); font-size: 1.35rem; }
.sic-tl span:last-child { color: var(--wp--preset--color--muted); }

.sic-lead-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; margin-top: 1.6rem; }
.sic-lead-head { font-family: var(--wp--preset--font-family--body) !important; text-transform: uppercase; letter-spacing: .12em; font-size: .78rem !important; color: var(--wp--preset--color--brass); font-weight: 700; margin: 0 0 .8rem; }
.sic-lead-list { list-style: none; margin: 0; padding: 0; }
.sic-lead-list li { padding: .5rem 0; border-bottom: 1px solid var(--wp--preset--color--line); color: var(--wp--preset--color--ink); }
@media (max-width: 640px) { .sic-lead-grid { grid-template-columns: 1fr; gap: 1.6rem; } }

.sic-contact-line { display:flex; gap:.7rem; align-items:flex-start; }
.sic-contact-line svg { width:20px; height:20px; fill: var(--wp--preset--color--brass); flex:0 0 auto; margin-top:3px; }
.sic-contact-line a { text-decoration:none; color: var(--wp--preset--color--ink); }
.sic-contact-line a:hover { color: var(--wp--preset--color--indigo); }
.sic-contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(1.5rem,4vw,3rem); align-items: stretch;
	max-width: var(--wp--style--global--wide-size, 1200px); margin-inline: auto; }
.sic-contact-info h2 { margin: 0 0 1.1rem; }
.sic-contact-note { color: var(--wp--preset--color--muted); margin-top: 1.2rem; border-left: 3px solid var(--wp--preset--color--brass); padding-left: 1rem; }
.sic-contact-map { min-height: 340px; }
@media (max-width: 820px) { .sic-contact-grid { grid-template-columns: 1fr; } }

/* ============================================================
   9. FOOTER
   ============================================================ */
.sic-footer { background: var(--wp--preset--color--ink); color: var(--wp--preset--color--cream); }
.sic-footer-inner { max-width: var(--wp--style--global--wide-size, 1200px); margin-inline: auto; padding: clamp(3rem,6vw,4.5rem) clamp(1.25rem,5vw,4rem) 1.6rem; }
.sic-foot-grid { display: grid; grid-template-columns: 1.6fr 1fr 1.2fr 1.1fr; gap: 2.5rem; }
.sic-foot-brand p { color: var(--wp--preset--color--periwinkle); font-size: .95rem; max-width: 32ch; margin: 1rem 0 1.3rem; }
.sic-foot-col ul { list-style: none; margin: 0; padding: 0; }
.sic-foot-col li { margin: 0 0 .55rem; }
.sic-foot-col .sic-contact-line { margin: 0 0 .7rem; font-size: .95rem; color: var(--wp--preset--color--periwinkle); }
.sic-foot-col .sic-contact-line a, .sic-foot-col .sic-contact-line span { color: var(--wp--preset--color--periwinkle); }
.sic-footer-bottom { display: flex; justify-content: space-between; flex-wrap: wrap; gap: .6rem; margin-top: 2.5rem; padding-top: 1.4rem; }
.sic-footer :where(h1,h2,h3,h4,p,li,a) { color: var(--wp--preset--color--cream); }
.sic-footer a { text-decoration: none; }
.sic-footer a:hover { color: var(--wp--preset--color--periwinkle); }
.sic-footer .sic-foot-logo img { height: 58px; width: auto; }
.sic-footer h4 { font-family: var(--wp--preset--font-family--body); text-transform: uppercase; letter-spacing: .12em; font-size: .78rem; color: var(--wp--preset--color--periwinkle); font-weight:700; }
.sic-foot-chip {
	background: #fff; border-radius: 10px; padding: 0.9rem 1.1rem; display:inline-flex; align-items:center;
}
.sic-foot-chip img { height: 52px; width: auto; display:block; }
.sic-foot-caption { color: var(--wp--preset--color--periwinkle); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700; margin-bottom:.5rem; }
.sic-footer-bottom { border-top: 1px solid rgba(255,255,255,0.12); font-size: 0.86rem; color: var(--wp--preset--color--periwinkle); }
.sic-footer-bottom a { color: #fff; font-weight:600; }

/* ============================================================
   10. RESPONSIVE
   ============================================================ */
@media (max-width: 600px) {
	.sic-topbar .sic-hide-sm { display: none; }
	.sic-footer .sic-foot-logo img { height: 48px; }
}
