/*
Theme Name: TAMIC
Theme URI: https://tamic.org
Author: Ledger Marketing
Author URI: https://ledgermarketing.com
Description: Custom full-site-editing block theme for the Texas Association of Mutual Insurance Companies (TAMIC) — the statewide trade association of Texas farm mutual insurers, serving members since 1936. Warm, heritage, Lone Star brand with the annual convention front and center.
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: tamic
*/

/* ============================================================
   TAMIC — component & override CSS
   theme.json is the design source of truth; this file adds
   layout structure, the header/nav, hero overlays, cards,
   logo walls, and the hard-won FSE fixes.
   ============================================================ */

:root {
	--tamic-ink: #16233a;
	--tamic-ink-deep: #101a2c;
	--tamic-ink-soft: #24334d;
	--tamic-navy: #22477f;
	--tamic-navy-deep: #17335f;
	--tamic-red: #b42a2d;
	--tamic-red-deep: #8f2124;
	--tamic-cream: #f7f3ea;
	--tamic-line: #e4ddcc;
	--tamic-shadow: 0 14px 40px rgba(16, 26, 44, 0.14);
	--tamic-shadow-sm: 0 6px 18px rgba(16, 26, 44, 0.10);
}

/* ---- GOTCHA: kill block-gap strips between top-level blocks
   and between full-width sections so the body bg never shows
   as a stripe under the header / between colored bands. ---- */
.wp-site-blocks > * { margin-block: 0; }
.wp-site-blocks main .alignfull { margin-block: 0; }
.wp-site-blocks main > .alignfull + .alignfull { margin-block: 0; }

body { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }

/* ---- Skip link ---- */
.skip-link:focus { background: #fff; color: var(--tamic-ink); padding: .6rem 1rem; z-index: 9999; }

/* ============================================================
   TOP UTILITY BAR (ink) — location, phone
   ============================================================ */
.wm-topbar { background: var(--tamic-ink-deep); color: #cdd6e4; font-size: .86rem; }
.wm-topbar a { color: #e7ecf5; text-decoration: none; }
.wm-topbar a:hover { color: #fff; text-decoration: underline; }
.wm-topbar .wm-topbar-inner { display: flex; flex-wrap: wrap; gap: .4rem 1.4rem; align-items: center; justify-content: space-between; padding: .5rem 0; }
.wm-topbar strong { color: #fff; font-weight: 700; }
.wm-topbar-items { display: flex; flex-wrap: wrap; gap: .3rem 1.4rem; align-items: center; }

/* ============================================================
   HEADER / BRAND / NAV
   ============================================================ */
.wm-header { background: #fffdf8; border-bottom: 1px solid #ece5d5; position: sticky; top: 0; z-index: 100; box-shadow: 0 1px 0 rgba(16,26,44,.04); }
.wm-header-inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; padding: .5rem 0; }
.wm-brand img { display: block; height: 66px; width: auto; }
@media (max-width: 600px) { .wm-brand img { height: 48px; } }

.wm-header .wp-block-navigation { font-weight: 600; }
.wm-header .wp-block-navigation a { color: var(--tamic-ink); text-decoration: none; letter-spacing: .005em; }
.wm-header .wp-block-navigation a:hover { color: var(--tamic-red); }
.wm-nav-wrap { display: flex; align-items: center; gap: 1.4rem; }

/* Header CTA button — always visible, brand-forward (Convention) */
.wm-header-pay a,
.wm-pay-btn a {
	display: inline-flex; align-items: center; gap: .5rem;
	background: var(--tamic-red); color: #fff !important;
	font-family: 'Source Sans 3', sans-serif; font-weight: 700; font-size: .98rem;
	text-decoration: none; padding: .66rem 1.2rem; border-radius: 8px;
	box-shadow: 0 6px 16px rgba(180, 42, 45, 0.26); transition: background .15s ease, transform .15s ease;
	white-space: nowrap;
}
.wm-header-pay a:hover,
.wm-pay-btn a:hover { background: var(--tamic-red-deep); transform: translateY(-1px); }
.wm-header-pay a::before { content: ""; width: 16px; height: 16px; background-repeat: no-repeat; background-size: contain;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E"); }

/* ============================================================
   HERO / COVER OVERLAYS
   ============================================================ */
.wm-hero { position: relative; background: var(--tamic-ink); }
/* GOTCHA: theme.json colors headings to ink; force white on dark covers, ALL levels */
.wm-hero :where(h1, h2, h3, h4, p, li, .wp-block-heading) { color: #fff; }
.wm-hero .wm-eyebrow { color: #f0b7b8; }
/* Texas silhouette watermark on hero */
.wm-hero-tx { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.wm-hero-tx::after {
	content: ""; position: absolute; right: -4%; top: 50%; transform: translateY(-50%);
	width: min(52vw, 640px); aspect-ratio: 478/471;
	background: url("assets/brand/texas-white.png") no-repeat center/contain; opacity: .07;
}
.wm-eyebrow {
	font-family: 'Source Sans 3', sans-serif; font-weight: 700; text-transform: uppercase;
	letter-spacing: .16em; font-size: .8rem; color: var(--tamic-red); margin: 0 0 .35rem;
}
.wm-hero .wp-block-buttons { margin-top: 1.4rem; }

/* Hero CTA button large */
.wm-cta-lg a { font-size: 1.05rem !important; padding: .95rem 1.9rem !important; border-radius: 9px !important; }

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
.wm-section { padding-block: clamp(3.25rem, 2.4rem + 4vw, 5.5rem); }
.wm-eyebrow-dark { font-family: 'Source Sans 3', sans-serif; font-weight: 700; text-transform: uppercase; letter-spacing: .16em; font-size: .8rem; color: var(--tamic-red); margin: 0 0 .4rem; }
.wm-lead { font-size: clamp(1.08rem, 1rem + .4vw, 1.28rem); color: #3c4756; line-height: 1.65; }
.wm-rule { width: 64px; height: 3px; background: var(--tamic-red); border: 0; border-radius: 3px; margin: 1rem 0 0; }

/* ============================================================
   FEATURE CARDS
   GOTCHA: align-items:start + height:auto so cards size to content
   ============================================================ */
.wm-cards .wp-block-column { align-self: start; }
.wm-card {
	background: #fff; border: 1px solid #ece5d5; border-radius: 14px;
	padding: 1.6rem 1.5rem; box-shadow: var(--tamic-shadow-sm);
	transition: transform .16s ease, box-shadow .16s ease; height: 100%;
}
.wm-card:hover { transform: translateY(-3px); box-shadow: var(--tamic-shadow); }
.wm-card h3, .wm-card h4 { margin-top: .3rem; }
.wm-card p { color: #4b5563; margin-bottom: 0; }
.wm-card-icon {
	width: 52px; height: 52px; border-radius: 12px; display: flex; align-items: center; justify-content: center;
	background: #e9eef6; margin-bottom: 1rem;
}
.wm-card-icon svg { width: 26px; height: 26px; stroke: var(--tamic-navy); }

/* Card grid (auto) */
.wm-cardgrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); gap: 1.3rem; align-items: start; margin-top: 2.2rem; }
.wm-cardgrid.cols-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 900px) { .wm-cardgrid.cols-3 { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); } }
.wm-cardgrid .wm-card { display: flex; flex-direction: column; }
.wm-card .wm-card-eyebrow { font-size: .74rem; text-transform: uppercase; letter-spacing: .1em; color: var(--tamic-red); font-weight: 700; margin: 0 0 .3rem; }
.wm-card h3 { font-size: 1.22rem; margin: 0 0 .5rem; color: var(--tamic-ink); }
.wm-center { text-align: center; }
.wm-center .wm-rule { margin-inline: auto; }
.wm-maxw { max-width: 720px; margin-inline: auto; }

/* ============================================================
   CONVENTION / FOCAL BAND (red)
   GOTCHA: white button w/ brand text on the colored band
   ============================================================ */
.wm-payband { background: var(--tamic-red); position: relative; overflow: hidden; }
.wm-payband::after { content: ""; position: absolute; inset: 0; background: radial-gradient(1200px 400px at 85% -10%, rgba(255,255,255,.12), transparent 60%); pointer-events: none; }
.wm-payband :where(h1, h2, h3, p) { color: #fff; position: relative; }
.wm-payband .wm-eyebrow { color: #ffd9d5; }
.wm-payband .wm-pay-lg a {
	background: #fff !important; color: var(--tamic-red-deep) !important;
	font-weight: 700; font-size: 1.05rem; padding: .95rem 1.9rem !important; border-radius: 9px !important;
	box-shadow: 0 10px 24px rgba(60, 12, 13, .3);
}
.wm-payband .wm-pay-lg a:hover { background: #fff5f4 !important; color: var(--tamic-ink) !important; }

/* Ink band variant */
.wm-inkband { background: var(--tamic-ink); }
.wm-inkband :where(h1,h2,h3,h4,p,li){ color: #fff; }

/* ============================================================
   PAGE HEADER BAND (ink) for interior pages
   ============================================================ */
.wm-pagehead { background: var(--tamic-ink); position: relative; overflow: hidden; }
.wm-pagehead::after {
	content: ""; position: absolute; right: -3%; top: 50%; transform: translateY(-50%);
	width: 360px; aspect-ratio: 478/471;
	background: url("assets/brand/texas-white.png") no-repeat center/contain; opacity: .06; pointer-events: none;
}
.wm-pagehead :where(h1, p, .wm-eyebrow) { color: #fff; position: relative; }
.wm-pagehead .wm-eyebrow { color: #f0b7b8; }
.wm-pagehead p { color: #cdd6e4; }

/* ============================================================
   MEMBER LOGO WALL
   ============================================================ */
.wm-logowall { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.1rem; margin-top: 2.2rem; }
@media (max-width: 900px) { .wm-logowall { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .wm-logowall { grid-template-columns: repeat(2, 1fr); } }
.wm-logo-tile {
	background: #fff; border: 1px solid #ece5d5; border-radius: 12px; aspect-ratio: 3 / 2;
	display: flex; align-items: center; justify-content: center; padding: 1rem 1.1rem;
	box-shadow: var(--tamic-shadow-sm); transition: transform .15s ease, box-shadow .15s ease;
}
.wm-logo-tile:hover { transform: translateY(-2px); box-shadow: var(--tamic-shadow); }
.wm-logo-tile img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; }

/* ============================================================
   MEMBER DIRECTORY CARDS (content varies → size to content)
   ============================================================ */
.wm-dir-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1.1rem; align-items: start; margin-top: 1.6rem; }
.wm-dir {
	background: #fff; border: 1px solid #e8e1d0; border-left: 4px solid var(--tamic-navy);
	border-radius: 12px; padding: 1.15rem 1.25rem; height: auto; box-shadow: var(--tamic-shadow-sm);
}
.wm-dir h3 { font-size: 1.1rem; margin: 0 0 .35rem; color: var(--tamic-ink); line-height: 1.25; }
.wm-dir .wm-dir-officer { color: var(--tamic-red-deep); font-weight: 700; font-size: .9rem; margin: 0 0 .55rem; }
.wm-dir p { margin: .15rem 0; font-size: .92rem; color: #4b5563; }
.wm-dir a { color: var(--tamic-navy); font-weight: 600; }
.wm-dir-meta { display: flex; flex-direction: column; gap: .12rem; }

/* Directory filter box */
.wm-dir-filter { display: flex; gap: .6rem; align-items: center; flex-wrap: wrap; margin-bottom: .4rem; }
.wm-dir-filter input {
	flex: 1 1 320px; padding: .8rem 1rem; border: 1px solid #d9d2c1; border-radius: 9px;
	font-family: 'Source Sans 3', sans-serif; font-size: 1rem; background: #fff; color: var(--tamic-ink);
}
.wm-dir-filter input:focus { outline: 2px solid var(--tamic-navy); border-color: var(--tamic-navy); }
.wm-dir-count { color: #6b7280; font-size: .9rem; }
.wm-dir.is-hidden { display: none; }
.wm-dir-empty { display: none; color: #6b7280; padding: 1rem 0; }

/* ============================================================
   LEADERSHIP ROSTER
   ============================================================ */
.wm-roster { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1rem; align-items: start; margin-top: 1.4rem; }
.wm-person { background: #fff; border: 1px solid #e8e1d0; border-radius: 12px; padding: 1.1rem 1.2rem; box-shadow: var(--tamic-shadow-sm); height: auto; }
.wm-person .wm-role { font-size: .74rem; text-transform: uppercase; letter-spacing: .09em; color: var(--tamic-red); font-weight: 700; margin: 0 0 .25rem; }
.wm-person h3 { font-size: 1.08rem; margin: 0 0 .15rem; color: var(--tamic-ink); }
.wm-person p { margin: 0; font-size: .9rem; color: #55606f; }
.wm-roster-simple { list-style: none; margin: 1rem 0 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: .55rem; }
.wm-roster-simple li { background: #fff; border: 1px solid #e8e1d0; border-radius: 10px; padding: .7rem .9rem; font-size: .93rem; }
.wm-roster-simple li b { color: var(--tamic-ink); display: block; }
.wm-roster-simple li span { color: #6b7280; font-size: .85rem; }

/* ============================================================
   CONTACT
   ============================================================ */
.wm-contact-card { background: #fff; border: 1px solid #e8e1d0; border-radius: 14px; padding: 1.8rem; box-shadow: var(--tamic-shadow-sm); height: 100%; }
.wm-contact-card h3 { margin-top: 0; }
.wm-contact-row { display: flex; gap: .8rem; align-items: flex-start; padding: .55rem 0; border-bottom: 1px dashed #eee4d2; }
.wm-contact-row:last-child { border-bottom: 0; }
.wm-contact-row .wm-ci { width: 38px; height: 38px; border-radius: 9px; background: #e9eef6; flex: none; display: flex; align-items: center; justify-content: center; }
.wm-contact-row .wm-ci svg { width: 19px; height: 19px; stroke: var(--tamic-navy); }
.wm-contact-row b { display: block; color: var(--tamic-ink); font-size: .82rem; text-transform: uppercase; letter-spacing: .05em; }
.wm-contact-row a, .wm-contact-row span { color: #3c4756; text-decoration: none; }
.wm-map { border: 0; width: 100%; height: 100%; min-height: 360px; border-radius: 14px; }

/* ============================================================
   FOOTER
   ============================================================ */
.wm-footer { background: var(--tamic-ink-deep); color: #b9c2d2; }
.wm-footer a { color: #d6ddea; text-decoration: none; }
.wm-footer a:hover { color: #fff; text-decoration: underline; }
.wm-footer h4 { color: #fff; font-family: 'Source Sans 3', sans-serif; font-size: .82rem; text-transform: uppercase; letter-spacing: .12em; margin: 0 0 1rem; font-weight: 700; }
.wm-footer-brand { display: flex; align-items: center; gap: .8rem; margin-bottom: 1rem; }
.wm-footer-brand img { height: 60px; width: auto; }
.wm-footer-brand .wm-fb-word { font-family: Bitter, serif; font-weight: 700; color: #fff; font-size: 1.5rem; line-height: 1; }
.wm-footer-brand .wm-fb-sub { color: #9aa6b8; font-size: .72rem; letter-spacing: .04em; }
.wm-footer p { color: #9aa6b8; font-size: .93rem; line-height: 1.7; }
.wm-footer ul { list-style: none; margin: 0; padding: 0; }
.wm-footer ul li { margin: .4rem 0; font-size: .95rem; }
.wm-affil { display: flex; gap: .7rem; flex-wrap: wrap; align-items: center; }
.wm-affil-chip { background: #fff; border-radius: 8px; padding: .6rem .8rem; display: inline-flex; align-items: center; }
.wm-affil-chip img { height: 34px; width: auto; display: block; }
.wm-affil-cap { color: #8592a6; font-size: .78rem; text-transform: uppercase; letter-spacing: .1em; margin: 0 0 .6rem; }
.wm-footer-bottom { border-top: 1px solid rgba(255,255,255,.1); }
.wm-footer-bottom .wm-fb-inner { display: flex; flex-wrap: wrap; gap: .6rem 1.4rem; align-items: center; justify-content: space-between; padding: 1.2rem 0; }
.wm-footer-bottom p { color: #808da1; font-size: .86rem; margin: 0; }
.wm-credit a { color: #c3ccdb; }
.wm-footer .wm-footer-pay a {
	display: inline-block; background: var(--tamic-red); color: #fff !important; font-weight: 700;
	padding: .7rem 1.3rem; border-radius: 8px; text-decoration: none;
}
.wm-footer .wm-footer-pay a:hover { background: var(--tamic-red-deep); text-decoration: none; }

/* ============================================================
   GENERIC PAGE CONTENT (prose)
   ============================================================ */
.wm-prose h2 { margin-top: 2.2rem; }
.wm-prose h3 { margin-top: 1.6rem; }
.wm-prose p, .wm-prose li { color: #333e4c; }
.wm-timeline { list-style: none; margin: 1.4rem 0 0; padding: 0; }
.wm-timeline li { position: relative; padding: 0 0 1.3rem 2.2rem; border-left: 2px solid #e3dccb; }
.wm-timeline li:last-child { border-left-color: transparent; }
.wm-timeline li::before { content: ""; position: absolute; left: -8px; top: .2rem; width: 14px; height: 14px; border-radius: 50%; background: var(--tamic-red); border: 3px solid var(--tamic-cream); }
.wm-timeline .wm-year { font-family: Bitter, serif; font-weight: 700; color: var(--tamic-navy); font-size: 1.15rem; display: block; }

/* Stat grid — size cards to content; don't stretch to the neighbouring column */
.wm-statgrid { align-content: start; align-items: start; }
.wm-statgrid .wm-card { height: auto; }
.wm-stat { display: flex; flex-direction: column; gap: .3rem; padding: 1.35rem 1.45rem; }
.wm-stat .wm-stat-num { font-family: Bitter, serif; font-weight: 700; color: var(--tamic-navy); font-size: clamp(2.2rem, 1.6rem + 2vw, 3rem); line-height: 1; }
.wm-stat .wm-stat-lbl { color: #55606f; font-size: .95rem; }

/* Event card */
.wm-event { background: #fff; border: 1px solid #e8e1d0; border-radius: 14px; padding: 1.6rem 1.7rem; box-shadow: var(--tamic-shadow-sm); height: 100%; }
.wm-event .wm-event-date { font-family: Bitter, serif; font-weight: 700; color: var(--tamic-red); font-size: 1.02rem; margin: 0 0 .4rem; }
.wm-event h3 { margin: 0 0 .5rem; }
.wm-event p { color: #4b5563; }
.wm-event ul { margin: .8rem 0 0; padding-left: 1.1rem; color: #4b5563; }
.wm-event ul li { margin: .3rem 0; }

/* ============================================================
   MOBILE NAV OVERLAY
   GOTCHA: prefix with body to beat core specificity; center items
   ============================================================ */
body .wp-block-navigation__responsive-container.is-menu-open {
	background: var(--tamic-ink) !important; padding: 5rem 1.5rem 2.5rem !important;
}
body .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
	width: 100%;
}
body .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container,
body .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container {
	gap: .35rem; align-items: center !important; justify-content: flex-start !important; width: 100%; text-align: center;
}
body .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item {
	align-items: center !important; width: 100%; border-bottom: 1px solid rgba(255,255,255,.08);
}
body .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a {
	color: #fff !important; font-size: 1.18rem; padding: .55rem 0; text-decoration: none; font-family: Bitter, serif;
}
body .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a:hover { color: #f0b7b8 !important; }
body .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close { color: #fff; top: 1.6rem; right: 1.4rem; }
/* Mobile menu CTA inside overlay */
.wm-mobile-pay { display: none; }
@media (max-width: 781px) {
	.wm-mobile-pay { display: block; margin-top: 1.4rem; }
	.wm-mobile-pay a { display: block; text-align: center; background: var(--tamic-red); color: #fff !important; font-weight: 700; padding: .9rem; border-radius: 9px; text-decoration: none; font-family: 'Source Sans 3', sans-serif; }
}
/* Hamburger color on light header */
.wm-header .wp-block-navigation__responsive-container-open svg { fill: var(--tamic-ink); }

/* Keep header CTA visible on mobile (do NOT hide in hamburger) */
@media (max-width: 781px) {
	.wm-header-inner { gap: .6rem; }
	.wm-header-pay { order: 2; }
	.wm-header-pay a { padding: .58rem .95rem; font-size: .9rem; }
	.wm-header-pay a span.wm-pay-full { display: none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 781px) {
	.wm-topbar { display: none; }
	.wm-split { flex-direction: column; }
	.wm-map { min-height: 280px; }
}
@media (max-width: 600px) {
	.wm-dir-grid { grid-template-columns: 1fr; }
	.wm-roster { grid-template-columns: 1fr; }
}
