/*
Theme Name: Gesler Insurance Agency
Template: devq-starter
Author: Josh Yager
Author URI: https://thedevq.com/
Description: Gesler Insurance Agency child theme. Palette is driven by the parent Styles admin page (primary / secondary / accent); RGBAs derive from those vars via color-mix().
Version: 1.0.0
*/

/* ─────────────────────────────────────────────────────────────────
   1. GLOBAL PALETTE + BODY
   ───────────────────────────────────────────────────────────────── */
:root {
    /* --primary, --secondary, --tertiary are emitted by parent theme
       from the Styles admin page (theme-settings-css.php). Do not redefine here. */
    --tertiary-deep: color-mix(in srgb, var(--tertiary) 78%, #000);
    --cream: #F7F4EC;
    --cream-warm: #EFEADD;
    --ink: #1F2A28;
    --ink-soft: rgba(31, 42, 40, 0.78);
    --rule-soft: rgba(31, 42, 40, 0.12);
}

body {
    background: var(--cream);
    color: var(--ink);
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    font-weight: 400;
    line-height: 1.65;
    font-feature-settings: "ss01", "kern";
}

/* Editorial type scale via Fraunces */
h1, h2, h3, h4 {
    font-family: 'Fraunces', Georgia, serif;
    font-weight: 600;
    color: var(--primary);
    line-height: 1.15;
    letter-spacing: -0.005em;
    margin-top: 0;
}
h1 { font-size: clamp(2.2rem, 4.2vw, 3.6rem); font-weight: 700; }
h2 { font-size: clamp(1.8rem, 3.2vw, 2.6rem); }
h3 { font-size: clamp(1.25rem, 1.8vw, 1.5rem); }
h4 { font-size: 1.0625rem; letter-spacing: 0; }

p { margin-top: 0; }
strong { color: var(--ink); font-weight: 600; }
a { color: var(--primary); text-decoration: none; }
a:hover { color: var(--tertiary); }

/* Eyebrow treatment used across every block */
.cs-topper, .cards-eyebrow, .hero-eyebrow, .cta-eyebrow,
.about-eyebrow, .textimage-eyebrow, .tabs-eyebrow, .features-eyebrow,
.process-eyebrow, .contactsplit-eyebrow, .locationcards-eyebrow,
.stats-eyebrow {
    display: inline-block;
    color: var(--tertiary) !important;
    font-family: 'Inter', sans-serif !important;
    font-weight: 600 !important;
    letter-spacing: 4.5px !important;
    text-transform: uppercase !important;
    font-size: 12px !important;
    margin-bottom: 18px !important;
    position: relative;
}

/* Soft section dividers (alternating bands handled in section overrides) */
section { transition: background 0.2s; }


/* ─────────────────────────────────────────────────────────────────
   2. BUTTONS
   ───────────────────────────────────────────────────────────────── */
.btn,
a.btn,
button.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: 'Inter', sans-serif;
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 14px 28px;
    border-radius: 6px;
    border: 2px solid var(--primary);
    background: var(--primary);
    color: #F7F4EC;
    text-decoration: none;
    transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
    cursor: pointer;
}
.btn:hover {
    background: var(--secondary);
    border-color: var(--secondary);
    color: #F7F4EC;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px color-mix(in srgb, var(--primary) 25%, transparent);
}

.btn.btn-tertiary,
a.btn-tertiary {
    background: var(--tertiary);
    border-color: var(--tertiary);
    color: var(--primary);
}
.btn.btn-tertiary:hover,
a.btn-tertiary:hover {
    background: var(--tertiary-deep);
    border-color: var(--tertiary-deep);
    color: #F7F4EC;
    box-shadow: 0 8px 24px color-mix(in srgb, var(--tertiary) 35%, transparent);
}

.btn.btn-outline,
a.btn-outline {
    background: transparent;
    color: var(--primary);
    border-color: var(--primary);
}
.btn.btn-outline:hover,
a.btn-outline:hover {
    background: var(--primary);
    color: #F7F4EC;
}

.btn.btn-outline-white,
a.btn-outline-white {
    background: transparent;
    color: #fff;
    border-color: rgba(255, 255, 255, 0.65);
}
.btn.btn-outline-white:hover,
a.btn-outline-white:hover {
    background: var(--tertiary);
    color: var(--primary);
    border-color: var(--tertiary);
}


/* ─────────────────────────────────────────────────────────────────
   3. HERO REFINEMENTS
   ───────────────────────────────────────────────────────────────── */
.hero-block {
    background: var(--primary);
}
.hero-block .hero-eyebrow {
    color: var(--tertiary) !important;
    background: color-mix(in srgb, var(--primary) 85%, transparent);
    padding: 8px 16px;
    border-radius: 4px;
    border-left: 3px solid var(--tertiary);
    backdrop-filter: blur(4px);
    font-size: 11px !important;
    letter-spacing: 3px !important;
    width: fit-content;
    max-width: 100%;
}
.hero-block .hero-heading {
    font-family: 'Fraunces', serif;
    color: #F7F4EC;
    font-weight: 700;
    font-size: clamp(2.4rem, 5vw, 4.2rem);
    line-height: 1.05;
    letter-spacing: -0.012em;
    max-width: 16ch;
    margin: 0 0 22px;
    text-shadow: 0 2px 24px rgba(0, 0, 0, 0.25);
}
.hero-block .hero-subheading {
    color: rgba(247, 244, 236, 0.92);
    font-size: clamp(1.05rem, 1.4vw, 1.25rem);
    line-height: 1.55;
    max-width: 56ch;
    margin: 0 0 36px;
    text-shadow: 0 1px 12px rgba(0, 0, 0, 0.3);
}

/* CENTERED HEROES (gradient style on internal pages):
   Parent gives .hero-content text-align:center + margin:0 auto, but my
   max-width on heading/subheading + fit-content on eyebrow leaves those
   constrained boxes anchored to the left. Center them explicitly. */
.hero-block.hero-align-center .hero-eyebrow {
    display: inline-block;
    margin-left: auto !important;
    margin-right: auto !important;
    /* Pad it out so it reads as a deliberate trust marker, not a tight chip */
    padding: 10px 28px;
    letter-spacing: 4px !important;
    font-size: 12px !important;
}
.hero-block.hero-align-center .hero-heading {
    max-width: 24ch;
    margin: 0 auto 22px;
    text-align: center;
}
.hero-block.hero-align-center .hero-subheading {
    margin: 0 auto 36px;
    text-align: center;
}
.hero-block.hero-align-center .hero-buttons {
    justify-content: center;
}
/* Hero buttons: primary gold, secondary outlined-white-with-phone */
.hero-block .hero-buttons {
    gap: 14px;
    flex-wrap: wrap;
}
.hero-block .hero-buttons .btn:first-child {
    background: var(--tertiary);
    border-color: var(--tertiary);
    color: var(--primary);
}
.hero-block .hero-buttons .btn:first-child:hover {
    background: #F7F4EC;
    border-color: #F7F4EC;
    color: var(--primary);
}
.hero-block .hero-buttons .btn:last-child {
    background: transparent;
    border-color: rgba(247, 244, 236, 0.7);
    color: #F7F4EC;
}
.hero-block .hero-buttons .btn:last-child:hover {
    background: rgba(247, 244, 236, 0.12);
    border-color: #F7F4EC;
    color: #F7F4EC;
}
/* Gradient hero polish */
.hero-block.hero-style-gradient {
    padding: 100px 0 80px;
}
.hero-block.hero-style-gradient .hero-eyebrow {
    background: rgba(0, 0, 0, 0.15);
}
/* Scroll indicator */
.hero-scroll-indicator { color: rgba(247, 244, 236, 0.55); }


/* ─────────────────────────────────────────────────────────────────
   4. CARDS — coverage tiles + client resources
   ───────────────────────────────────────────────────────────────── */
.cards-block {
    background: var(--cream);
}
.cards-header {
    text-align: center;
    margin: 0 auto 56px;
    max-width: 720px;
}
.cards-heading {
    font-size: clamp(1.8rem, 2.8vw, 2.4rem);
    margin-bottom: 14px;
}
.cards-subheading {
    color: var(--ink-soft);
    font-size: 1.05rem;
    margin: 0;
}
.cards-grid { gap: 28px; }
.cards-card {
    background: #fff;
    border-left: 4px solid var(--tertiary);
    border-radius: 8px;
    padding: 36px 28px 32px;
    box-shadow: 0 6px 20px color-mix(in srgb, var(--primary) 6%, transparent);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.cards-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 14px 34px color-mix(in srgb, var(--primary) 14%, transparent);
    border-left-color: var(--primary);
}
.cards-card-icon {
    width: 64px;
    height: 64px;
    border-radius: 12px;
    background: color-mix(in srgb, var(--tertiary) 12%, transparent);
    color: var(--tertiary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    transition: background 0.25s ease, color 0.25s ease;
}
.cards-card:hover .cards-card-icon {
    background: var(--primary);
    color: var(--tertiary);
}
.cards-card .cards-card-icon i {
    color: inherit;
    font-size: inherit;
}
.cards-card:hover .cards-card-icon i {
    color: var(--tertiary);
}
.cards-card-title {
    font-family: 'Fraunces', serif;
    font-size: 1.4rem;
    color: var(--primary);
    margin: 0;
}
.cards-card-description {
    color: var(--ink-soft);
    margin: 0;
    line-height: 1.6;
    font-size: 0.96rem;
    flex: 1;
}
.cards-card-link {
    color: var(--tertiary);
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    text-decoration: none;
    margin-top: 6px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s, color 0.2s;
    align-self: flex-start;
}
.cards-card-link:hover {
    color: var(--primary);
    border-bottom-color: var(--tertiary);
}


/* ─────────────────────────────────────────────────────────────────
   5. ABOUT block — stats prominence
   ───────────────────────────────────────────────────────────────── */
.about-block {
    background: var(--cream);
    padding-top: 40px;
    padding-bottom: 40px;
}
.about-grid {
    align-items: center;
    gap: 64px;
}
.about-image-col img {
    border-radius: 8px;
    box-shadow: 0 14px 38px color-mix(in srgb, var(--primary) 18%, transparent);
}
.about-heading {
    font-size: clamp(2rem, 3.2vw, 2.8rem);
    margin-bottom: 22px;
}
.about-content { font-size: 1.05rem; line-height: 1.7; color: var(--ink-soft); }
.about-content p:last-child { margin-bottom: 0; }
.about-stats {
    margin-top: 36px;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    padding-top: 32px;
    border-top: 1px solid var(--rule-soft);
}
.about-stat {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.about-stat-number {
    font-family: 'Fraunces', serif;
    font-weight: 700;
    font-size: clamp(2rem, 3.6vw, 3rem);
    line-height: 1;
    color: var(--primary);
    letter-spacing: -0.02em;
}
.about-stat-number::after {
    content: '';
    display: block;
    width: 28px;
    height: 2px;
    background: var(--tertiary);
    margin-top: 10px;
}
.about-stat-label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--ink-soft);
    font-weight: 600;
}


/* ─────────────────────────────────────────────────────────────────
   6. MARQUEE — carrier names scrolling
   ───────────────────────────────────────────────────────────────── */
.marquee-block {
    background: #fff;
    padding: 32px 0;
    border-top: 1px solid var(--rule-soft);
    border-bottom: 1px solid var(--rule-soft);
}
.marquee-item, .marquee-text {
    font-family: 'Fraunces', serif !important;
    font-weight: 600;
    font-size: 1.3rem !important;
    color: var(--primary) !important;
    letter-spacing: 0.3px;
}
.marquee-separator {
    color: var(--tertiary) !important;
    margin: 0 22px !important;
}


/* ─────────────────────────────────────────────────────────────────
   7. CTA banner
   ───────────────────────────────────────────────────────────────── */
.cta-block {
    background: var(--primary);
    color: #F7F4EC;
}
.cta-block.cta-bg-primary {
    background: linear-gradient(135deg, var(--primary) 0%, color-mix(in srgb, var(--primary) 72%, #000) 100%);
    position: relative;
    overflow: hidden;
}
.cta-block.cta-bg-primary::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -10%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, color-mix(in srgb, var(--tertiary) 10%, transparent) 0%, transparent 70%);
    pointer-events: none;
}
.cta-block .container { position: relative; z-index: 1; }
.cta-eyebrow, .cta-block .cta-eyebrow {
    color: var(--tertiary) !important;
}
.cta-block .cta-heading {
    color: #F7F4EC;
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    max-width: 22ch;
    margin: 0 auto 14px;
}
.cta-block .cta-content {
    color: rgba(247, 244, 236, 0.82);
    font-size: 1.08rem;
    max-width: 52ch;
    margin: 0 auto 28px;
    line-height: 1.65;
}
.cta-block .btn {
    background: var(--tertiary);
    border-color: var(--tertiary);
    color: var(--primary);
}
.cta-block .btn:hover {
    background: #F7F4EC;
    border-color: #F7F4EC;
    color: var(--primary);
}


/* ─────────────────────────────────────────────────────────────────
   8. FEATURES LIST + PROCESS — shared icon-on-left pattern
   ───────────────────────────────────────────────────────────────── */
.featureslist-block,
.process-block {
    background: var(--cream-warm);
}
.features-header,
.process-header {
    text-align: center;
    margin: 0 auto 56px;
    max-width: 760px;
}
.features-heading,
.process-heading { margin-bottom: 14px; }
.features-subheading,
.process-subheading { color: var(--ink-soft); }

.features-grid { gap: 28px 40px; }
.features-item {
    display: flex;
    gap: 20px;
    padding: 22px;
    background: #fff;
    border-radius: 8px;
    border-left: 3px solid var(--tertiary);
    box-shadow: 0 4px 14px color-mix(in srgb, var(--primary) 5%, transparent);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.features-item:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 26px color-mix(in srgb, var(--primary) 10%, transparent);
}
.features-icon, .features-item i {
    color: var(--primary);
    font-size: 28px;
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    background: color-mix(in srgb, var(--primary) 8%, transparent);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.features-title { color: var(--primary); margin-bottom: 6px; font-size: 1.2rem; }
.features-description { color: var(--ink-soft); margin: 0; font-size: 0.96rem; }

.process-grid { gap: 32px; }
.process-step {
    text-align: center;
    background: #fff;
    border-radius: 8px;
    padding: 32px 24px;
    box-shadow: 0 6px 20px color-mix(in srgb, var(--primary) 6%, transparent);
    position: relative;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border-bottom: 3px solid var(--tertiary);
}
.process-step:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 30px color-mix(in srgb, var(--primary) 12%, transparent);
}
.process-step-number,
.process-step-icon {
    color: var(--primary);
    background: color-mix(in srgb, var(--tertiary) 15%, transparent);
    width: 72px;
    height: 72px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    margin: 0 auto 18px;
}
.process-step-number i,
.process-step-icon i {
    color: var(--primary);
    background: transparent;
    font-size: 26px;
}
.process-step-title { margin-bottom: 10px; font-size: 1.25rem; }
.process-step-description { color: var(--ink-soft); margin: 0; }


/* ─────────────────────────────────────────────────────────────────
   9. TABS (What We Insure coverage tabs)
   ───────────────────────────────────────────────────────────────── */
.tabs-block { background: var(--cream); }
.tabs-block .tabs-wrapper {
    display: block;
    max-width: 1200px;
    margin: auto;
}
.tabs-header { text-align: center; margin: 0 auto 48px; max-width: 760px; }
.tabs-block.tabs-style-horizontal .tabs-nav {
    flex-direction: row;
    border-bottom: 0;
    gap: 0;
}
.tabs-nav {
    display: flex;
    justify-content: center;
    gap: 0;
    margin-bottom: 32px;
    flex-wrap: wrap;
    border-bottom: 0;
}
.tabs-nav button,
.tabs-nav .tab-trigger {
    background: transparent;
    border: 2px solid transparent;
    color: var(--ink-soft);
    padding: 12px 28px;
    border-radius: 6px;
    font-family: 'Inter', sans-serif;
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.2s;
}
.tabs-nav button:hover,
.tabs-nav .tab-trigger:hover {
    color: var(--primary);
    border-color: color-mix(in srgb, var(--tertiary) 40%, transparent);
}
.tabs-nav button.active,
.tabs-nav .tab-trigger.active {
    background: var(--primary);
    border-color: var(--primary);
    color: var(--tertiary);
}
.tabs-content {
    background: #fff;
    padding: 48px;
    border-radius: 10px;
    border-left: 4px solid var(--tertiary);
    box-shadow: 0 8px 28px color-mix(in srgb, var(--primary) 8%, transparent);
    font-size: 1.02rem;
    color: var(--ink-soft);
    line-height: 1.75;
}
.tabs-content h3 {
    color: var(--primary);
    margin-bottom: 16px;
    font-size: 1.5rem;
}
.tabs-content ul {
    list-style: none;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px 28px;
}
.tabs-content ul li {
    position: relative;
    padding-left: 24px;
    color: var(--ink-soft);
}
.tabs-content ul li::before {
    content: '';
    position: absolute;
    top: 11px;
    left: 0;
    width: 14px;
    height: 2px;
    background: var(--tertiary);
}
.tabs-content strong { color: var(--primary); }


/* ─────────────────────────────────────────────────────────────────
   10. TEXT IMAGE
   ───────────────────────────────────────────────────────────────── */
.textimage-block { background: var(--cream); }
.textimage-block img {
    border-radius: 10px;
    box-shadow: 0 14px 38px color-mix(in srgb, var(--primary) 18%, transparent);
}
.textimage-heading { font-size: clamp(1.8rem, 3vw, 2.6rem); margin-bottom: 18px; }
.textimage-content { color: var(--ink-soft); font-size: 1.04rem; line-height: 1.7; }


/* ─────────────────────────────────────────────────────────────────
   11. CONTENT block (about service area, our team agents grid)
   ───────────────────────────────────────────────────────────────── */
.content-block { background: var(--cream); padding: 60px 0; }
.content-block h2 { color: var(--primary); }


/* ─────────────────────────────────────────────────────────────────
   12. CONTACT SPLIT
   ───────────────────────────────────────────────────────────────── */
.contactsplit-block {
    background: var(--cream);
}
.contactsplit-grid { gap: 56px; }
.contactsplit-form,
.contactsplit-info {
    background: #fff;
    padding: 40px 36px;
    border-radius: 10px;
    box-shadow: 0 8px 24px color-mix(in srgb, var(--primary) 8%, transparent);
}
.contactsplit-info { border-left: 4px solid var(--tertiary); }
.contactsplit-heading { font-size: 1.8rem; margin-bottom: 14px; }
.contactsplit-info-row {
    display: flex;
    gap: 16px;
    margin-bottom: 18px;
    align-items: flex-start;
}
.contactsplit-info-row i {
    color: var(--tertiary);
    font-size: 18px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--tertiary) 12%, transparent);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

/* Gravity Forms inside Contact Split — 2-column tightened layout */
.contactsplit-block .gform_wrapper .gform_fields {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 14px 18px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}
.contactsplit-block .gform_wrapper .gfield {
    padding: 0 !important;
    margin: 0 !important;
    width: auto !important;
    max-width: none !important;
    grid-column: span 1;
}
/* Long fields span both columns */
.contactsplit-block .gform_wrapper .gfield--type-textarea,
.contactsplit-block .gform_wrapper .gfield--type-address,
.contactsplit-block .gform_wrapper .gfield--width-full {
    grid-column: 1 / -1;
}
/* Make the "type of insurance" select span full width (always 5th field on Get a Quote form) */
.contactsplit-block .gform_wrapper #field_2_5,
.contactsplit-block .gform_wrapper #field_3_5 {
    grid-column: 1 / -1;
}

.contactsplit-block .gform_wrapper .gfield_label {
    font-family: 'Inter', sans-serif !important;
    font-weight: 600 !important;
    color: var(--primary) !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    font-size: 12px !important;
    margin-bottom: 6px !important;
    display: block;
}
.contactsplit-block .gform_wrapper input[type="text"],
.contactsplit-block .gform_wrapper input[type="email"],
.contactsplit-block .gform_wrapper input[type="tel"],
.contactsplit-block .gform_wrapper input[type="url"],
.contactsplit-block .gform_wrapper input[type="number"],
.contactsplit-block .gform_wrapper input.small,
.contactsplit-block .gform_wrapper input.medium,
.contactsplit-block .gform_wrapper input.large,
.contactsplit-block .gform_wrapper select,
.contactsplit-block .gform_wrapper textarea {
    width: 100% !important;
    max-width: 100% !important;
    border: 1px solid color-mix(in srgb, var(--primary) 22%, transparent) !important;
    background: var(--cream) !important;
    padding: 11px 14px !important;
    border-radius: 6px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 15px !important;
    line-height: 1.4 !important;
    color: var(--ink) !important;
    transition: border-color 0.2s, box-shadow 0.2s, background 0.2s !important;
    box-shadow: none !important;
    height: auto !important;
    min-height: 0 !important;
}
.contactsplit-block .gform_wrapper textarea {
    min-height: 130px !important;
    resize: vertical;
}

/* Native-select chevron — accent-colored arrow.
   Data URIs can't reference CSS vars; uses literal stroke matching admin accent. */
.contactsplit-block .gform_wrapper select {
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23ADD580' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    background-size: 12px 8px !important;
    padding-right: 36px !important;
}

.contactsplit-block .gform_wrapper input:focus,
.contactsplit-block .gform_wrapper select:focus,
.contactsplit-block .gform_wrapper textarea:focus {
    outline: none !important;
    border-color: var(--tertiary) !important;
    background-color: #fff !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--tertiary) 18%, transparent) !important;
}

/* Footer container + button alignment */
.contactsplit-block .gform_footer,
.contactsplit-block .gform_wrapper .gform_footer {
    padding-top: 18px !important;
    margin-top: 8px !important;
}

@media (max-width: 767px) {
    .contactsplit-block .gform_wrapper .gform_fields {
        grid-template-columns: 1fr !important;
    }
    .contactsplit-block .gform_wrapper .gfield,
    .contactsplit-block .gform_wrapper .gfield--type-textarea {
        grid-column: 1 / -1;
    }
}


/* ─────────────────────────────────────────────────────────────────
   13. LOCATION CARDS — already styled inline in code.php; tighten
   ───────────────────────────────────────────────────────────────── */
.locationcards-block { background: var(--cream-warm); }
.locationcards-heading { font-size: clamp(1.8rem, 2.8vw, 2.4rem); }


/* ─────────────────────────────────────────────────────────────────
   14. MOBILE / RESPONSIVE TWEAKS
   ───────────────────────────────────────────────────────────────── */
@media (max-width: 1199px) {
    .about-stats { grid-template-columns: repeat(2, 1fr); }
    .tabs-content { padding: 32px; }
    .tabs-content ul { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
    h1 { font-size: 2.1rem; }
    h2 { font-size: 1.7rem; }
    .hero-block .hero-heading { font-size: 2.1rem; max-width: 100%; }
    .hero-block .hero-buttons .btn { width: 100%; justify-content: center; }
    .cards-card { padding: 28px 22px 26px; }
    .about-stats { grid-template-columns: repeat(2, 1fr); gap: 18px; }
    .tabs-content { padding: 24px; }
    .contactsplit-form,
    .contactsplit-info { padding: 28px 22px; }
}


/* ─────────────────────────────────────────────────────────────────
   15. GRAVITY FORMS — high-specificity overrides
   GF Orbital theme adds heavy default button styling. These selectors
   beat GF's defaults without resorting to ID hooks.
   ───────────────────────────────────────────────────────────────── */
body .gform_wrapper.gravity-theme .gform_footer input[type="submit"],
body .gform_wrapper .gform_footer input[type="submit"],
body .gform_wrapper .gform_button,
body .gform_wrapper button[type="submit"],
body .gform_wrapper .gform-theme-button {
    background: var(--tertiary) !important;
    border: 2px solid var(--tertiary) !important;
    color: var(--primary) !important;
    padding: 14px 32px !important;
    border-radius: 6px !important;
    font-family: 'Inter', sans-serif !important;
    font-weight: 600 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    font-size: 14px !important;
    cursor: pointer;
    transition: all 0.2s !important;
    box-shadow: none !important;
}
body .gform_wrapper .gform_footer input[type="submit"]:hover,
body .gform_wrapper .gform_button:hover,
body .gform_wrapper button[type="submit"]:hover,
body .gform_wrapper .gform-theme-button:hover {
    background: var(--tertiary-deep) !important;
    border-color: var(--tertiary-deep) !important;
    color: #F7F4EC !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 22px color-mix(in srgb, var(--tertiary) 32%, transparent) !important;
}
body .gform_wrapper .gfield_required { color: var(--tertiary) !important; font-size: 11px !important; }

/* ─────────────────────────────────────────────────────────────────
   16. LOCATION CARDS — map iframe placeholder
   In headless browsers Google Maps iframes can render blank; give the
   container a subtle pine-teal placeholder so it never looks "broken."
   ───────────────────────────────────────────────────────────────── */
.locationcards-map {
    background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 6%, transparent), color-mix(in srgb, var(--tertiary) 6%, transparent));
    min-height: 200px;
    position: relative;
}
.locationcards-map::before {
    content: '\f3c5'; /* map-marker-alt */
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    color: color-mix(in srgb, var(--primary) 15%, transparent);
    font-size: 56px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 0;
}
.locationcards-map iframe { position: relative; z-index: 1; background: transparent; }


/* ─────────────────────────────────────────────────────────────────
   17. PRIMARY NAV DROPDOWN — desktop submenu for What We Insure
   Parent walker emits .dropdown / .dropdown-menu / .dropdown-toggle
   but the parent theme ships no dropdown CSS. Style it here.
   ───────────────────────────────────────────────────────────────── */
.gesler-header .devq-desktop-nav li.dropdown { position: relative; }
.gesler-header .devq-desktop-nav .dropdown-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(8px);
    min-width: 240px;
    background: #fff;
    list-style: none;
    margin: 0;
    padding: 10px 0;
    border-radius: 6px;
    border-top: 3px solid var(--tertiary);
    box-shadow: 0 12px 32px color-mix(in srgb, var(--primary) 18%, transparent);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s;
    z-index: 200;
}
.gesler-header .devq-desktop-nav li.dropdown:hover > .dropdown-menu,
.gesler-header .devq-desktop-nav li.dropdown:focus-within > .dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}
.gesler-header .devq-desktop-nav .dropdown-menu li { display: block; }
.gesler-header .devq-desktop-nav .dropdown-menu a {
    display: block;
    padding: 10px 22px;
    font-size: 14px;
    color: var(--ink);
    text-decoration: none;
    border-left: 3px solid transparent;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
    white-space: nowrap;
}
.gesler-header .devq-desktop-nav .dropdown-menu a:hover,
.gesler-header .devq-desktop-nav .dropdown-menu a:focus {
    background: color-mix(in srgb, var(--primary) 4%, transparent);
    color: var(--primary);
    border-left-color: var(--tertiary);
}
/* Underline indicator on the parent link stays scaled-up while submenu open */
.gesler-header .devq-desktop-nav > li.dropdown:hover > a::after { transform: scaleX(1); }


/* ─────────────────────────────────────────────────────────────────
   18. COVERAGE BULLETS — /what-we-insure/*/ pages
   Lists rendered by acf/content block on coverage subpages.
   ───────────────────────────────────────────────────────────────── */
.coverage-bullets {
    list-style: none;
    padding: 0;
    margin: 14px 0 0;
}
.coverage-bullets li {
    background: #fff;
    border-left: 4px solid var(--tertiary);
    padding: 16px 20px;
    margin-bottom: 12px;
    border-radius: 4px;
    box-shadow: 0 2px 12px color-mix(in srgb, var(--primary) 6%, transparent);
    font-size: 15px;
    line-height: 1.55;
}
.coverage-bullets li strong { color: var(--primary); }


/* ─────────────────────────────────────────────────────────────────
   19. TABS BLOCK LINK STYLING — /what-we-insure/ tab bullets
   The list items contain <strong><a>Label</a></strong>; make the
   anchor look like an inviting link inside the strong-bold context.
   ───────────────────────────────────────────────────────────────── */
.tabs-content li strong a,
.tabs-panel li strong a {
    color: var(--primary);
    text-decoration: none;
    border-bottom: 1px solid color-mix(in srgb, var(--primary) 25%, transparent);
    transition: color 0.15s, border-color 0.15s;
}
.tabs-content li strong a:hover,
.tabs-panel li strong a:hover {
    color: var(--tertiary-deep);
    border-bottom-color: var(--tertiary);
}


/* ─────────────────────────────────────────────────────────────────
   20. TEAM GRID — /our-team/
   Replaces the broken hardcoded repeat(2,1fr) inline grid that
   overflowed off-screen at mobile widths.
   ───────────────────────────────────────────────────────────────── */
.team-intro {
    text-align: center;
    max-width: 780px;
    margin: 0 auto;
}
.team-intro h2 { color: var(--primary); margin-bottom: 12px; }
.team-intro p { font-size: 18px; color: var(--ink-soft); margin: 0; }

.team-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
    max-width: 880px;
    margin: 42px auto 0;
}
@media (min-width: 600px) {
    .team-grid { grid-template-columns: repeat(2, 1fr); }
}

.team-card {
    background: #fff;
    border-left: 4px solid var(--tertiary);
    padding: 22px 24px;
    border-radius: 6px;
    box-shadow: 0 4px 18px color-mix(in srgb, var(--primary) 8%, transparent);
    min-width: 0;
}
.team-card.is-owner { border-left-color: var(--primary); }
.team-card h3 {
    margin: 0 0 4px;
    color: var(--primary);
    font-size: clamp(1.1rem, 1.4vw, 1.25rem);
    overflow-wrap: break-word;
}
.team-card__role {
    color: var(--tertiary);
    font-weight: 600;
    letter-spacing: 1px;
    font-size: 12px;
    text-transform: uppercase;
}
.team-card__contact {
    margin: 12px 0 0;
    font-size: 15px;
    line-height: 1.5;
}
.team-card__contact a {
    color: var(--primary);
    text-decoration: none;
    border-bottom: 1px dotted var(--tertiary);
    overflow-wrap: break-word;
    word-break: break-word;
}
.team-card__contact a:hover { color: var(--tertiary-deep); }


/* ─────────────────────────────────────────────────────────────────
   21. PRINT
   ───────────────────────────────────────────────────────────────── */
@media print {
    .gesler-utility-strip, .devq-footer, .gesler-header .devq-header-actions { display: none; }
}
