/* =================================================================
   BREAKPOINTS REFERENCE
   =================================================================
   Mobile:   768px   (max-width: 768px for mobile, min-width: 769px for desktop)
   Tablet:   1024px  (for intermediate layouts where needed)
   Desktop:  1280px  (for wide/container layouts where needed)

   These values are hardcoded in @media queries throughout this file
   and in footer.php / custom.js. Update all locations if changed.
   ================================================================= */

/**
 * D20 Starter Theme
 *
* Fonts | Tokens | Base | Components
 */

/* =================================================================
   FONTS
   ================================================================= */

/* Fonts loaded via wp_enqueue_style in inc/assets.php (Google Fonts) */


/* =================================================================
   TOKENS
   ================================================================= */

   :root {
    /* Primary color scale */
    --color-primary-50: #eff6ff;
    --color-primary-100: #dbeafe;
    --color-primary-200: #bfdbfe;
    --color-primary-300: #93c5fd;
    --color-primary-400: #60a5fa;
    --color-primary-500: #3b82f6;
    --color-primary-600: #2563eb;
    --color-primary-700: #1d4ed8;
    --color-primary-800: #1e40af;
    --color-primary-900: #1e3a8a;

    /* Secondary color scale */
    --color-secondary-50: #f0f9ff;
    --color-secondary-100: #e0f2fe;
    --color-secondary-200: #bae6fd;
    --color-secondary-300: #7dd3fc;
    --color-secondary-400: #38bdf8;
    --color-secondary-500: #0ea5e9;
    --color-secondary-600: #0284c7;
    --color-secondary-700: #0369a1;
    --color-secondary-800: #075985;
    --color-secondary-900: #0c4a6e;

    /* Neutral color scale */
    --color-neutral-50: #fafafa;
    --color-neutral-100: #f5f5f5;
    --color-neutral-200: #e5e5e5;
    --color-neutral-300: #d4d4d4;
    --color-neutral-400: #a3a3a3;
    --color-neutral-500: #737373;
    --color-neutral-600: #525252;
    --color-neutral-700: #404040;
    --color-neutral-800: #262626;
    --color-neutral-900: #171717;

    /* Error color scale */
    --color-error-50: #fef2f2;
    --color-error-100: #fee2e2;
    --color-error-200: #fecaca;
    --color-error-300: #fca5a5;
    --color-error-400: #f87171;
    --color-error-500: #ef4444;
    --color-error-600: #dc2626;
    --color-error-700: #b91c1c;
    --color-error-800: #991b1b;
    --color-error-900: #7f1d1d;

    /* Alberto's Commercial Services brand palette */
    --color-brand: #336d93;
    --color-brand-dark: #012241;
    --color-brand-light: #9dd3e0;
    --color-cream: #f4ece0;
    --color-navy: #012241;
    --color-navy-mid: #021a31;
    --color-accent-light: #9dd3e0;

    --color-bg-light: var(--color-cream);
    --color-bg-dark: var(--color-navy);
    --color-bg-footer: #012241;
    --color-text: var(--color-neutral-800);
    --color-text-muted: var(--color-neutral-600);
    --color-text-on-dark: #ffffff;

    /* Typography */
    --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
    --font-heading: 'Barlow Condensed', system-ui, -apple-system, sans-serif;
    --font-signature: 'Homemade Apple', cursive;

    --text-xs: 0.75rem;
    --text-sm: 0.875rem;
    --text-base: 1rem;
    --text-lg: 1.125rem;
    --text-xl: 1.25rem;
    --text-2xl: clamp(1.5rem, 1.25rem + 1vw, 1.875rem);
    --text-3xl: clamp(1.875rem, 1.5rem + 1.5vw, 2.5rem);
    --text-4xl: clamp(2.25rem, 1.75rem + 2vw, 3rem);
    --text-5xl: clamp(2.75rem, 2rem + 3vw, 4rem);

    --leading-tight: 1.2;
    --leading-normal: 1.5;
    --leading-relaxed: 1.625;

    /* Spacing */
    --space-xs: 0.5rem;
    --space-sm: 0.75rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --space-2xl: 3rem;
    --space-3xl: 4rem;

    /* Layout */
    --container-max: 1304px;
    --gutter: clamp(1rem, 0.5rem + 2vw, 2rem);

    /* Misc */
    --radius: 0.5rem;
    --shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1);
    --transition: 200ms ease;
}



@media (max-width: 1024px) {
    :root {
        --text-2xl: 1.5rem;
        --text-3xl: 1.75rem;
        --text-4xl: 2.25rem;
        --text-5xl: 2.75rem;
    }
}

@media (max-width: 767px) {
    :root {
        --text-base: 1rem;
        --text-lg: 1.25rem;
        --text-2xl: 1.25rem;
        --text-3xl: 1.5rem;
        --text-4xl: 1.75rem;
        --text-5xl: 2rem;
    }
}


/* =================================================================
   BASE
   ================================================================= */

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--color-neutral-900);
    background: var(--color-neutral-50);
    -webkit-font-smoothing: antialiased;
}

img, video { max-width: 100%; height: auto; display: block; }

/* Animate on scroll */
.animate-on-scroll {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}
.animate-on-scroll.is-visible {
    opacity: 1;
    transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
    .animate-on-scroll {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

/* Background image utility for components */
[class*="--bg-image"] {
    position: relative;
    background: var(--color-bg-dark) center/cover no-repeat;
    color: #fff;
}
[class*="--bg-image"] .eyebrow { color: var(--color-brand-light); }
[class*="--bg-image"] > .container,
[class*="--bg-image"] > [class*="__inner"] { position: relative; z-index: 1; }
[class*="__overlay"] { position: absolute; inset: 0; }

h1, h2, h3, h4, h5, h6 {
    margin: 0 0 var(--space-md);
    font-family: var(--font-heading);
    font-weight: 700;
    line-height: var(--leading-tight);
}

p { margin: 0 0 var(--space-md); }
p:last-child { margin-bottom: 0; }

a { color: var(--color-brand); }


/* =================================================================
   ACCESSIBILITY
   ================================================================= */

/* Skip link */
.skip-link {
    position: absolute;
    left: -9999px;
    top: var(--space-sm);
    background: var(--color-brand);
    color: #fff;
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius);
    font-weight: 600;
    text-decoration: none;
    z-index: 9999;
}
.skip-link:focus {
    left: var(--space-sm);
    outline: 2px solid var(--color-brand-dark);
    outline-offset: 2px;
}

/* Screen reader only (visually hidden) */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Focus visible states */
:focus-visible {
    outline: 2px solid var(--color-brand);
    outline-offset: 2px;
}
:focus:not(:focus-visible) {
    outline: none;
}

/* Focus on dark backgrounds */
[class*="--bg-dark"] :focus-visible,
[class*="--bg-brand"] :focus-visible,
[class*="--bg-image"] :focus-visible,
.site-footer :focus-visible {
    outline-color: #fff;
}

/* Minimum tap target size ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â applies broadly via lower specificity so
   component-level rules (e.g. .btn { min-height: 60px }) can override. */
button,
input[type="submit"],
input[type="button"] {
    min-height: 44px;
}

/* Text overflow handling */
h1, h2, h3, h4, h5, h6 {
    overflow-wrap: break-word;
}

h1{
    font-size:var(--text-5xl);
}

h2 {
    font-size: clamp(40px, 4.6vw, 64px);    
	font-family: var(--font-heading);
    font-size: clamp(40px, 4.6vw, 64px);
    font-weight: 800;
    line-height: 0.95;
    letter-spacing: -0.64px;
    text-transform: uppercase;
}

h3 {
    font-size:var(--text-3xl);
}

h4 {
    font-size:var(--text-3xl);
}

p { margin: 0 0 var(--space-lg); }
p:last-child { margin-bottom: 0; }

/* Prevent iOS text resize issues */
html {
    text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }

    /* Keep elements visible without animation */
    .animate-on-scroll {
        opacity: 1 !important;
        transform: none !important;
    }
}

/* Container */
.container {
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--gutter);
}
.container--narrow { max-width: 720px; }
.container--wide { max-width: 1400px; }

/* Prose (WYSIWYG content) */
/* .prose h2 { font-size: var(--text-2xl); margin-top: var(--space-xl); }
.prose h3 { font-size: var(--text-xl); margin-top: var(--space-lg); } */
.prose ul, .prose ol { padding-left: var(--space-lg); }
.prose li { margin-bottom: var(--space-xs); }
.prose a { color: var(--color-brand); text-decoration: underline; }

/* Eyebrow / Subhead */
.eyebrow {
    margin-bottom: var(--space-sm);
    font-size: var(--text-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-brand);
}
.subhead {
    font-size: var(--text-lg);
    color: var(--color-neutral-600);
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: 0.75em 1.5em;
    font-size: var(--text-base);
    font-weight: 600;
    text-decoration: none;
    border-radius: var(--radius);
    border: 2px solid transparent;
    cursor: pointer;
    transition: all var(--transition);
}
/* Primary button mirrors .btn--white: cream bg, navy text */
.btn--primary {
    background: var(--color-cream);
    color: var(--color-navy);
    border-color: var(--color-cream);
}
.btn--primary:hover {
    background: #fff;
    border-color: #fff;
    color: var(--color-navy);
}
.btn--secondary {
    background: transparent;
    color: var(--color-brand);
    border-color: var(--color-brand);
}
.btn--secondary:hover {
    background: var(--color-brand);
    color: #fff;
}
.btn--white {
    background: var(--color-cream);
    color: var(--color-navy);
    border-color: var(--color-cream);
}
.btn--white:hover {
    background: #fff;
    border-color: #fff;
    color: var(--color-navy);
}
.btn--outline-light {
    background: transparent;
    color: #fff;
    border-color: rgba(255,255,255,0.5);
}
.btn--outline-light:hover {
    background: rgba(255,255,255,0.1);
    border-color: #fff;
}

.link-arrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    font-weight: 600;
    color: var(--color-brand);
    text-decoration: none;
}
.link-arrow svg { width: 1em; height: 1em; transition: transform var(--transition); }
.link-arrow:hover svg { transform: translateX(4px); }

/* Icons */
svg { width: 24px; height: 24px; flex-shrink: 0; }


/* =================================================================
   HEADER
   ================================================================= */

.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: #fff;
    border-bottom: 1px solid var(--color-neutral-200);
}
.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    /* height: 72px; */
}
.site-header__logo img { height: 40px; width: auto; }
/* Scrolled state */
body.scrolled .site-header {
    box-shadow: 0 2px 16px rgba(0, 0, 0, 0.08);
}
body.scrolled .site-header__inner {
    
}
body.scrolled .site-header__logo img {
    
}
.site-header__toggle {
    display: flex;
    flex-direction: column;
    gap: 5px;
    padding: var(--space-sm);
    background: none;
    border: none;
    cursor: pointer;
}
.site-header__toggle span,
.site-header__toggle::before,
.site-header__toggle::after {
    content: '';
    display: block;
    width: 24px;
    height: 2px;
    background: var(--color-neutral-900);
    transition: var(--transition);
}
.site-header__toggle[aria-expanded="true"] {
    top: 2rem;
    right: 1rem;
    padding-right:0;
    z-index: 9999;
    position:fixed;
}
.site-header__toggle[aria-expanded="true"] span {
    opacity: 0;
    transform: scaleX(0);
}
.site-header__toggle[aria-expanded="true"]::before,
.site-header__toggle[aria-expanded="true"]::after{
    width:32px;
    /* background-color:var(--primary-500); */
}
.site-header__toggle[aria-expanded="true"]::before {
    transform: translateY(7px) rotate(45deg);
}
.site-header__toggle[aria-expanded="true"]::after {
    transform: translateY(-7px) rotate(-45deg);
    /* border: 1px solid red; */
    /* height: 200px!important; */
}
.site-nav__menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: var(--space-lg);
}
.site-nav__menu a {
    font-weight: 500;
    text-decoration: none;
    color: var(--color-neutral-700);
}
.site-nav__menu a:hover { color: var(--color-brand); }

/* Parent menu items with children */
.site-nav__menu > .menu-item-has-children {
    position: relative;
}
.site-nav__menu > .menu-item-has-children > a {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
}
.site-nav__menu > .menu-item-has-children > a::after {
    content: '';
    border: solid currentColor;
    border-width: 0 1.5px 1.5px 0;
    padding: 2.5px;
    transform: rotate(45deg);
    margin-top: -2px;
    transition: transform var(--transition);
}

/* Desktop dropdown */
@media (min-width: 769px) {
    .site-nav__menu .sub-menu {
        position: absolute;
        top: 100%;
        left: 0;
        min-width: 200px;
        list-style: none;
        margin: 0;
        padding: var(--space-sm) 0;
        background: #fff;
        border: 1px solid var(--color-neutral-200);
        border-radius: var(--radius);
        box-shadow: var(--shadow);
        opacity: 0;
        visibility: hidden;
        transform: translateY(8px);
        transition: opacity var(--transition), transform var(--transition), visibility var(--transition);
    }
    .site-nav__menu > .menu-item-has-children:hover > .sub-menu,
    .site-nav__menu > .menu-item-has-children:focus-within > .sub-menu {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }
    .site-nav__menu > .menu-item-has-children:hover > a::after {
        transform: rotate(-135deg);
        margin-top: 2px;
    }
    .site-nav__menu .sub-menu a {
        display: block;
        padding: var(--space-sm) var(--space-md);
        font-weight: 400;
    }
    .site-nav__menu .sub-menu a:hover {
        background: var(--color-neutral-50);
    }
}

@media (max-width: 768px) {
    .site-nav {
        position: fixed;
        top: 72px;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: #fff;
        padding: var(--space-lg) 5%;
        padding-top: 5rem;
        transform: translateX(100%);
        transition: transform var(--transition);
        overflow-y: auto;
    }
    .site-nav.is-open { transform: translateX(0); }
    body.nav-open { overflow: hidden; }
    .site-nav__menu { flex-direction: column; gap: 0; }
    .site-nav__menu > li {
        display:flex;
        border-bottom: 1px solid var(--color-neutral-200);
        /* flex-direction:column; */
        /* align-items:flex-start!important; */
    }
    .site-nav__menu > .menu-item-has-children > a,
    .site-nav__menu > li > a { 
        display: block; 
        padding: 1.5rem 0 1rem 0; 
		font-size:1.25rem;
    }
    /* Row layout so the toggle button sits beside the link */
    .site-nav__menu > .menu-item-has-children {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        justify-content:flex-start;
    }
    .site-nav__menu > .menu-item-has-children > a {
        flex: 1;
        flex-basis: auto;
        min-width: 0;
        /* display: block; */
    }
    /* Sub-menu spans full width on its own row */
    .site-nav__menu > .menu-item-has-children > .sub-menu {
        flex-basis: 100%;
    }
    .site-nav__menu > .menu-item-has-children > a::after {
        display: none;
    }
    /* Toggle button arrow */
    .submenu-toggle {
        background: none;
        border: none;
        padding: 1rem;
        cursor: pointer;
        color: inherit;
        flex-shrink: 0;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .submenu-toggle::before {
        content: '';
        border: solid var(--color-neutral-500);
        border-width: 0 2px 2px 0;
        padding: 8px;
        transform: rotate(45deg);
        margin-top: -6px;
        transition: all var(--transition);
        display: block;
    }
    .site-nav__menu > .menu-item-has-children.is-open > .submenu-toggle::before {
        transform: rotate(-135deg);
        margin-top: 2px;
    }
    .site-nav__menu .sub-menu {
        list-style: none;
        margin: 0;
        padding: 0 0 var(--space-sm) var(--space-md);
        padding: 0;
        max-height: 0;
        overflow: hidden;
        transition: all var(--transition);
        width:100%; 
    }
    .site-nav__menu > .menu-item-has-children.is-open > .sub-menu {
        max-height: 500px;
        overflow-y: scroll;
        padding-bottom:var(--space-sm);
    }
    .site-nav__menu .sub-menu li {

    }
    .site-nav__menu .sub-menu a {
        display: block;
        padding: .875rem 0;
        font-weight: 600;
        /* color: #fff; */
        font-size:1rem;
    }
    .site-nav__menu .sub-menu li.current-menu-item > a,
    .site-nav__menu .sub-menu a:focus, 
    .site-nav__menu .sub-menu a:hover {
        color: var(--color-neutral-900)!important;
        opacity:0.65;
    }
    .site-nav__menu > li.current-menu-item > a,
    .site-nav__menu > li > a:hover,
    .site-nav__menu > li > a:focus{
/*         color: var(--color-neutral-900)!important;
        opacity:0.9; */
    }
	
	.site-nav__menu .sub-menu li.current-menu-item a, 
	.site-nav__menu .sub-menu a:focus, 
	.site-nav__menu .sub-menu a:hover {
		color: var(--color-secondary-800);
		background: var(--color-neutral-50);
		padding-left:.325rem;
	}
}

@media (min-width: 769px) {
    .site-nav {
        display: flex;
        align-items: center;
    }
	.site-header__toggle,
    .site-nav__menu > li.mobile-show,
    button.submenu-toggle{
        display:none!important;
    }
}

body.nav-open {
    overflow: hidden;
}

/* Header actions (phone + CTA) */
.site-nav__actions {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-top: var(--space-lg);
    /* padding-top: var(--space-md); */
    /* border-top: 1px solid var(--color-neutral-100); */
}
.site-nav__phone {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    font-weight: 500;
    color: var(--color-neutral-700);
    text-decoration: none;
}
.site-nav__phone svg { width: 18px; height: 18px; position: relative; top: 2px;}
.site-nav__phone:hover { color: var(--color-accent-light); }

@media (min-width: 769px) {
    .site-nav__actions {
        margin-top: 0;
        margin-left: var(--space-lg);
        padding-top: 0;
        padding-left: var(--space-lg);
        border-top: none;
        border-left: 1px solid var(--color-neutral-200);
    }
}
@media (max-width: 768px) {
    .site-nav__phone span { display: none; }
    .site-nav__phone svg { width: 24px; height: 24px; }
    .site-nav__actions{
        flex-wrap:wrap;
    }

    .site-nav__actions > a{
/*         flex-basis:100%;
        justify-content:center; */
    }
}

/* Small button variant */
.btn--sm {
    padding: var(--space-xs) var(--space-md);
    font-size: var(--text-sm);
}


/* =================================================================
   MEGA MENU
   ================================================================= */

.c-mega-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 100;
    background: #fff;
    border-top: 1px solid var(--color-neutral-200);
    box-shadow: var(--shadow-lg);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: opacity var(--transition), transform var(--transition), visibility var(--transition);
    pointer-events: none;
}

.c-mega-menu.is-active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
}

.c-mega-menu__inner {
    padding: var(--space-xl) var(--gutter);
}

.c-mega-menu__columns {
    display: flex;
    gap: var(--space-lg);
}

.c-mega-menu__col {
    min-width: 0;
}

.c-mega-menu__col-title {
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    font-weight: 700;
    margin-bottom: var(--space-sm);
    color: var(--color-text);
}

.c-mega-menu__menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

.c-mega-menu__menu li {
    margin-bottom: var(--space-xs);
}

.c-mega-menu__menu a {
    color: var(--color-text-muted);
    text-decoration: none;
    transition: color var(--transition);
}

.c-mega-menu__menu a:hover {
    color: var(--color-brand);
}

.c-mega-menu__menu .sub-menu {
    list-style: none;
    padding: 0;
    margin: var(--space-sm) 0 var(--space-sm) var(--space-sm);
}

.c-mega-menu__menu .sub-menu a {
    font-size: var(--text-sm);
}

.c-mega-menu__text {
    color: var(--color-text);
}

.c-mega-menu__image {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius);
}

.c-mega-menu__contact-info p {
    display: flex;
    align-items: flex-start;
    gap: var(--space-xs);
    margin-bottom: var(--space-xs);
}

@media (max-width: 768px) {
    .c-mega-menu {
        display: none !important;
    }
}

/* =================================================================
   FOOTER
   ================================================================= */

.site-footer {
    background: var(--color-bg-footer);
    color: #fff;
    padding: var(--space-3xl) 0 var(--space-lg);
}
.site-footer__inner {
    display: grid;
    gap: var(--space-xl);
}
.site-footer__logo img { height: 32px; width: auto; margin-bottom: var(--space-md); }
.site-footer__social {
    display: flex;
    gap: var(--space-sm);
}
.site-footer__social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--color-neutral-800);
    color: var(--color-neutral-400);
    transition: background var(--transition), color var(--transition);
}
.site-footer__social a span {
    display: flex;
    align-items: center;
    justify-content: center;
}
.site-footer__social a:hover {
    background: var(--color-brand);
    color: #fff;
}
.site-footer__social svg { width: 20px; height: 20px; }
.site-footer__social-icon { width: 20px; height: 20px; object-fit: contain; }

.site-footer__columns {
    display: flex;
    flex-wrap: nowrap;
    gap: var(--space-lg);
    padding: var(--space-xl) 0;
}

.site-footer__col {
    min-width: 0;
}

.site-footer__col-title {
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    font-weight: 700;
    margin-bottom: var(--space-sm);
    color: var(--color-text-on-dark);
}

.site-footer__menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

.site-footer__menu li {
    margin-bottom: var(--space-xs);
}

.site-footer__menu a {
    color: var(--color-neutral-400);
    text-decoration: none;
    transition: color var(--transition);
}

.site-footer__menu a:hover {
    color: var(--color-text-on-dark);
}

.site-footer__menu .sub-menu {
    list-style: none;
    padding: 0;
    margin: 0 0 0 var(--space-sm);
}

.site-footer__menu .sub-menu a {
    font-size: var(--text-sm);
}

.site-footer__contact-info p {
    display: flex;
    align-items: flex-start;
    gap: var(--space-xs);
    margin-bottom: var(--space-xs);
    color: var(--color-neutral-400);
}

.site-footer__contact-info a {
    color: var(--color-neutral-400);
    text-decoration: none;
}

.site-footer__contact-info a:hover {
    color: var(--color-text-on-dark);
}

.site-footer__icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    margin-top: 2px;
}

.site-footer__text {
    color: var(--color-neutral-400);
}

.site-footer__image {
    max-width: 100%;
    height: auto;
}

@media (max-width: 768px) {
    .site-footer__columns {
        flex-direction: column;
    }

    .site-footer__col {
        flex-basis: 100% !important;
        max-width: 100% !important;
    }
}

.site-footer__bottom {
    margin-top: var(--space-2xl);
    padding-top: var(--space-lg);
    border-top: 1px solid var(--color-neutral-800);
    color: var(--color-neutral-500);
    font-size: var(--text-sm);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-sm) var(--space-lg);
}

.site-footer__bottom-left {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-xs) var(--space-lg);
}

.site-footer__copyright { margin: 0; }

.site-footer__bottom-nav { display: flex; align-items: center; }

.site-footer__bottom-menu {
    display: flex;
    gap: var(--space-lg);
    list-style: none;
    margin: 0;
    padding: 0;
}

.site-footer__bottom-menu a {
    color: var(--color-neutral-500);
    text-decoration: none;
    transition: color var(--transition);
}

.site-footer__bottom-menu a:hover,
.site-footer__bottom-menu a:focus { color: var(--color-neutral-100); }

.site-footer__credits { margin: 0; }

.site-footer__credits a {
    color: var(--color-neutral-400);
    text-decoration: none;
    transition: color var(--transition);
}

.site-footer__credits a:hover,
.site-footer__credits a:focus { color: var(--color-brand-light); }


/* =================================================================
   COMPONENTS
   ================================================================= */

/* Adjacent same-background components: collapse top padding */
[class*="--bg-white"] + [class*="--bg-white"],
[class*="--bg-light"] + [class*="--bg-light"],
[class*="--bg-dark"] + [class*="--bg-dark"],
[class*="--bg-brand"] + [class*="--bg-brand"] {
    padding-top: 0;
}

/* ----------------------- UNDER CONSTRUCTION ----------------------- */

.c-under-construction {
    padding: var(--space-3xl) 0;
    min-height: 50vh;
    display: flex;
    align-items: center;
    background: var(--color-bg-light);
}
.c-under-construction h1 {
    font-size: var(--text-3xl);
    margin-bottom: var(--space-md);
    color: var(--color-neutral-700);
}
.c-under-construction p {
    color: var(--color-neutral-500);
    font-size: var(--text-lg);
}

/* ----------------------- HERO ----------------------- */

.c-hero {
    position: relative;
    display: flex;
    align-items: center;
    padding: var(--space-3xl) 0;
    background: var(--color-bg-dark) center/cover no-repeat;
    color: #fff;
    overflow: hidden;
}
.c-hero--h-full { min-height: 100vh; }
.c-hero--h-large { min-height: 80vh; }
.c-hero--h-medium { min-height: 60vh; }
.c-hero--h-small { min-height: 40vh; }

.c-hero__overlay {
    position: absolute;
    inset: 0;
    background: #000;
}
.c-hero__inner {
    position: relative;
    z-index: 1;
}
.c-hero__content { max-width: 700px; }

.c-hero--center { text-align: center; }
.c-hero--center .c-hero__inner { display: flex; flex-direction: column; align-items: center; }
.c-hero--center .c-hero__content { margin: 0 auto; }

.c-hero__eyebrow { opacity: 0.8; color: inherit; }
.c-hero__headline { font-size: var(--text-5xl); margin-bottom: var(--space-md); }
.c-hero__subhead { font-size: var(--text-xl); opacity: 0.9; margin-bottom: var(--space-lg); }
.c-hero__buttons { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.c-hero--center .c-hero__buttons { justify-content: center; }

/* Split layout */
.c-hero--split { background: var(--color-bg-dark); }
.c-hero--split .c-hero__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2xl);
    align-items: center;
    max-width: none;
}
.c-hero--split .c-hero__content { max-width: none; }
.c-hero--split .c-hero__media { order: 1; }
.c-hero--split-left .c-hero__media { order: -1; }
.c-hero--split .c-hero__image {
    width: 100%;
    height: auto;
    border-radius: var(--radius);
}

@media (max-width: 768px) {
    .c-hero--split .c-hero__inner {
        grid-template-columns: 1fr;
        text-align: center;
    }
    .c-hero--split .c-hero__media { order: -1; }
    .c-hero--split .c-hero__buttons { justify-content: center; }
}

/* Minimal layout */
.c-hero--minimal {
    background: #fff;
    color: var(--color-neutral-900);
    min-height: auto;
    padding: var(--space-xl) 0;
    border-bottom: 1px solid var(--color-neutral-200);
}
.c-hero--minimal .c-hero__headline {
    font-size: var(--text-3xl);
    margin-bottom: 0;
}

/* Parallax */
.c-hero__parallax {
    position: absolute;
    inset: -20%;
    background: center/cover no-repeat;
    will-change: transform;
}
.c-hero--parallax {
    background: transparent;
}

@media (max-width: 768px) {
    .c-hero { padding: var(--space-2xl) 0; }
    .c-hero__headline { font-size: var(--text-3xl); }
    .c-hero--minimal .c-hero__headline { font-size: var(--text-2xl); }
}

.c-hero__video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Breadcrumbs */
.breadcrumbs { margin-bottom: var(--space-sm); }
.breadcrumbs__list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-xs);
    list-style: none;
    margin: 0;
    padding: 0;
    font-size: var(--text-sm);
}
.breadcrumbs__item { display: flex; align-items: center; gap: var(--space-xs); }
.breadcrumbs__link { color: var(--color-neutral-500); text-decoration: none; }
.breadcrumbs__link:hover { color: var(--color-brand); }
.breadcrumbs__sep { color: var(--color-neutral-300); }
.breadcrumbs__current { color: var(--color-neutral-700); }


/* ----------------------- CONTENT + MEDIA ----------------------- */

.c-content-media { padding: var(--space-3xl) 0; }
.c-content-media__inner { display: grid; gap: var(--space-2xl); align-items: center; }

@media (min-width: 768px) {
    .c-content-media__inner { grid-template-columns: 1fr 1fr; }
    .c-content-media--left .c-content-media__media { order: -1; }
}


.c-content-media__buttons { display: flex; flex-wrap: wrap; gap: var(--space-sm); margin-top: var(--space-lg); }
.c-content-media__image { border-radius: var(--radius); }
.c-content-media__video { position: relative; padding-bottom: 56.25%; border-radius: var(--radius); overflow: hidden; }
.c-content-media__video iframe { position: absolute; inset: 0; width: 100%; height: 100%; }

.c-content-media--bg-white { background: #fff; }
.c-content-media--bg-light { background: var(--color-bg-light); }
.c-content-media--bg-dark { background: var(--color-bg-dark); color: #fff; }
.c-content-media--bg-dark .eyebrow { color: var(--color-brand-light); }


/* ----------------------- CARDS ----------------------- */

.c-cards { padding: var(--space-3xl) 0; }
.c-cards__header { text-align: center; max-width: 700px; margin: 0 auto var(--space-2xl); }
.c-cards__grid { display: grid; gap: var(--space-lg); }

@media (min-width: 769px) {
    .c-cards--cols-2 .c-cards__grid,
    .c-cards--cols-3 .c-cards__grid,
    .c-cards--cols-4 .c-cards__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
    .c-cards--cols-3 .c-cards__grid { grid-template-columns: repeat(3, 1fr); }
    .c-cards--cols-4 .c-cards__grid { grid-template-columns: repeat(4, 1fr); }
}

.c-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    text-decoration: none;
    color: inherit;
    overflow: hidden;
    transition: transform var(--transition), box-shadow var(--transition);
}
a.c-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }

.c-card__image { margin: 0; }
.c-card__image img { aspect-ratio: 4/3; object-fit: cover; width: 100%; display: block; }
.c-card__content { padding: var(--space-lg); flex: 1; display: flex; flex-direction: column; }
.c-card__title { font-size: var(--text-xl); margin-bottom: var(--space-sm); }
.c-card__desc { color: var(--color-neutral-600); flex: 1; }
.c-card__link { margin-top: var(--space-md); font-weight: 600; color: var(--color-brand); display: inline-flex; align-items: center; gap: var(--space-xs); }
.c-card__link svg { width: 1em; height: 1em; transition: transform var(--transition); }
a.c-card:hover .c-card__link svg { transform: translateX(4px); }

/* Card Style: Horizontal */
.c-cards--style-horizontal .c-card { flex-direction: row; }
.c-cards--style-horizontal .c-card__image { flex: 0 0 40%; max-width: 40%; }
.c-cards--style-horizontal .c-card__image img { aspect-ratio: 1/1; height: 100%; }
.c-cards--style-horizontal .c-card__content { justify-content: center; }
@media (max-width: 768px) {
    .c-cards--style-horizontal .c-card { flex-direction: column; }
    .c-cards--style-horizontal .c-card__image { flex: none; max-width: 100%; }
    .c-cards--style-horizontal .c-card__image img { aspect-ratio: 16/9; height: auto; }
}

/* Card Style: Overlay */
.c-cards--style-overlay .c-card { position: relative; min-height: 280px; }
.c-cards--style-overlay .c-card__image { position: absolute; inset: 0; }
.c-cards--style-overlay .c-card__image img { aspect-ratio: auto; height: 100%; }
.c-cards--style-overlay .c-card__image::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.2) 60%, transparent 100%);
}
.c-cards--style-overlay .c-card__content {
    position: relative;
    z-index: 1;
    justify-content: flex-end;
    color: #fff;
}
.c-cards--style-overlay .c-card__desc { color: var(--color-neutral-200); }
.c-cards--style-overlay .c-card__link { color: #fff; }
a.c-cards--style-overlay .c-card:hover .c-card__image img { transform: scale(1.05); }
.c-cards--style-overlay .c-card__image img { transition: transform var(--transition); }

/* Card Style: Minimal */
.c-cards--style-minimal .c-card {
    flex-direction: row;
    box-shadow: none;
    border: 1px solid var(--color-neutral-200);
}
.c-cards--style-minimal .c-card__image {
    order: 2;
    flex: 0 0 auto;
    width: 80px;
    height: 80px;
    margin: var(--space-lg);
    margin-left: 0;
    border-radius: 50%;
    overflow: hidden;
}
.c-cards--style-minimal .c-card__image img {
    aspect-ratio: 1/1;
    height: 100%;
    width: 100%;
}
.c-cards--style-minimal .c-card__content {
    padding: var(--space-xl);
    flex: 1;
}
a.c-cards--style-minimal .c-card:hover {
    transform: none;
    box-shadow: none;
    border-color: var(--color-brand);
}

.c-cards--bg-white { background: #fff; }
.c-cards--bg-light { background: var(--color-bg-light); }
.c-cards--bg-dark { background: var(--color-bg-dark); color: #fff; }
.c-cards--bg-dark .c-card { background: var(--color-neutral-800); }
.c-cards--bg-dark .c-card__desc { color: var(--color-neutral-300); }
.c-cards--bg-dark.c-cards--style-minimal .c-card { border-color: var(--color-neutral-700); }
.c-cards--bg-dark.c-cards--style-minimal a.c-card:hover { border-color: var(--color-brand-light); }


/* ----------------------- CTA ----------------------- */

.c-cta { padding: var(--space-3xl) 0; }
.c-cta__inner { display: flex; flex-direction: column; gap: var(--space-lg); }
.c-cta--center { text-align: center; }
.c-cta--center .c-cta__inner { align-items: center; max-width: 700px; margin: 0 auto; }

@media (min-width: 768px) {
    .c-cta--split .c-cta__inner,
    .c-cta--has-form .c-cta__inner { flex-direction: row; justify-content: space-between; align-items: center; gap: var(--space-2xl); }
    .c-cta--split .c-cta__content,
        .c-cta--split .c-cta__content, .c-cta--has-form .c-cta__content {
        flex: 1;
        flex-basis: 50%;
        width: 50%;
    }
	.c-cta--split .c-cta__form, .c-cta--has-form .c-cta__form {
		flex: 1;
		max-width: 50%;
		flex-basis: 50%;
	}
	
}

.c-cta__content h2 { margin-bottom: var(--space-sm); }
.c-cta__content p { margin: 0; }
.c-cta__buttons { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.c-cta--center .c-cta__buttons { justify-content: center; }

.c-cta__form {
    background: rgba(255, 255, 255, 0.1);
    padding: var(--space-xl);
    border-radius: var(--radius);
}

.c-cta--bg-light .c-cta__form {
    background: #fff;
    box-shadow: var(--shadow);
}

.c-cta__form .gform_wrapper { margin: 0; }
.c-cta__form .gfield { margin-bottom: var(--space-md); }
.c-cta__form input:not([type="submit"]),
.c-cta__form textarea,
.c-cta__form select {
    width: 100%;
    padding: var(--space-sm) var(--space-md);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: var(--radius);
    background: rgba(255, 255, 255, 0.9);
    font-size: var(--text-base);
}

.c-cta--bg-dark form label, .c-cta--bg-dark form legend, .c-cta--bg-dark .gfield_description {
    color: var(--color-neutral-50)!important;
}

.gform-footer.gform_footer {
    margin-top: 0!important;
}

div#gform_fields_1 {
    row-gap: var(--space-md);
}

div.gform-theme--framework .gform-field-label>.gfield_required:where(:not(.gform-theme__disable):not(.gform-theme__disable *):not(.gform-theme__disable-framework):not(.gform-theme__disable-framework *)) {
    color: var(--color-error-500);
}

.c-cta--bg-light .c-cta__form input:not([type="submit"]),
.c-cta--bg-light .c-cta__form textarea,
.c-cta--bg-light .c-cta__form select {
    border-color: var(--color-neutral-300);
    background: #fff;
}

.c-cta__form .gform_button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 44px;
    padding: 0.75em 1.5em;
    font-size: var(--text-base);
    font-weight: 600;
    text-decoration: none;
    border-radius: var(--radius);
    border: 2px solid transparent;
    cursor: pointer;
    transition: all var(--transition);
    /* Default: white button for dark/brand backgrounds */
    background: #fff;
    color: var(--color-brand);
    border-color: #fff;
}

.c-cta__form .gform_button:hover {
    background: var(--color-neutral-100);
    border-color: var(--color-neutral-100);
}

/* Light background: use primary button style */
.c-cta--bg-light .c-cta__form .gform_button {
    background: var(--color-brand);
    color: #fff;
    border-color: var(--color-brand);
}

.c-cta--bg-light .c-cta__form .gform_button:hover {
    background: var(--color-brand-dark);
    border-color: var(--color-brand-dark);
}

.c-cta--bg-brand { background: var(--color-brand); color: #fff; }
.c-cta--bg-dark { background: var(--color-bg-dark); color: #fff; }
.c-cta--bg-light { background: var(--color-bg-light); }


/* ----------------------- TESTIMONIALS ----------------------- */

.c-testimonials { padding: var(--space-3xl) 0; }
.c-testimonials__header { text-align: center; max-width: 700px; margin: 0 auto var(--space-2xl); }

.c-testimonial { text-align: center; max-width: 800px; margin: 0 auto; }
.c-testimonial__icon { width: 48px; height: 48px; margin: 0 auto var(--space-lg); color: var(--color-brand); opacity: 0.3; }
.c-testimonial__quote { font-size: var(--text-xl); font-style: italic; line-height: var(--leading-relaxed); margin-bottom: var(--space-lg); }
.c-testimonial--featured .c-testimonial__quote { font-size: var(--text-2xl); }
.c-testimonial__author { display: flex; align-items: center; justify-content: center; gap: var(--space-md); text-align: left; }
.c-testimonial__photo { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; }
.c-testimonial__author cite { display: block; font-style: normal; font-weight: 600; }
.c-testimonial__author span { font-size: var(--text-sm); color: var(--color-neutral-500); }

/* Slider nav */
.c-testimonials__nav { display: flex; align-items: center; justify-content: center; gap: var(--space-md); margin-top: var(--space-xl); }
.c-testimonials__prev,
.c-testimonials__next {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background: none;
    border: 1px solid var(--color-neutral-300);
    border-radius: 50%;
    cursor: pointer;
    transition: var(--transition);
}
.c-testimonials__prev:hover,
.c-testimonials__next:hover { border-color: var(--color-neutral-500); }
.c-testimonials__prev svg,
.c-testimonials__next svg { width: 20px; height: 20px; }
.c-testimonials__dots { display: flex; gap: var(--space-xs); }
.c-testimonials__dot {
    width: 10px;
    height: 10px;
    background: var(--color-neutral-300);
    border: none;
    border-radius: 50%;
    cursor: pointer;
    transition: var(--transition);
}
.c-testimonials__dot:hover,
.c-testimonials__dot.is-active { background: var(--color-brand); }

/* Grid layout */
.c-testimonials--grid .c-testimonials__grid { display: grid; gap: var(--space-lg); }
@media (min-width: 768px) {
    .c-testimonials--grid .c-testimonials__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
    .c-testimonials--grid .c-testimonials__grid { grid-template-columns: repeat(3, 1fr); }
}
.c-testimonials--grid .c-testimonial { text-align: left; background: #fff; padding: var(--space-lg); border-radius: var(--radius); box-shadow: var(--shadow); }
.c-testimonials--grid .c-testimonial__author { justify-content: flex-start; }
.c-testimonials--grid .c-testimonial__icon { width: 32px; height: 32px; margin: 0 0 var(--space-md); }
.c-testimonials--grid .c-testimonial__quote { font-size: var(--text-base); }

.c-testimonials--bg-white { background: #fff; }
.c-testimonials--bg-light { background: var(--color-bg-light); }
.c-testimonials--bg-dark { background: var(--color-bg-dark); color: #fff; }
.c-testimonials--bg-dark .c-testimonial__author span { color: var(--color-neutral-400); }


/* ----------------------- ACCORDION ----------------------- */

.c-accordion { padding: var(--space-3xl) 0; }
.c-accordion__header { text-align: center; margin-bottom: var(--space-2xl); }
.c-accordion__items { border-top: 1px solid var(--color-neutral-200); }
.c-accordion__item { border-bottom: 1px solid var(--color-neutral-200); }
.c-accordion__item h3 { margin: 0; font-size: var(--text-base); }
.c-accordion__trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    width: 100%;
    padding: var(--space-lg) 0;
    font: inherit;
    font-weight: 600;
    text-align: left;
    background: none;
    border: none;
    cursor: pointer;
}
.c-accordion__trigger:hover { color: var(--color-brand); }
.c-accordion__icon { width: 20px; height: 20px; transition: transform var(--transition); }
.c-accordion__item.is-open .c-accordion__icon { transform: rotate(180deg); }
.c-accordion__content { padding-bottom: var(--space-lg); color: var(--color-neutral-600); }

.c-accordion--bg-white { background: #fff; }
.c-accordion--bg-light { background: var(--color-bg-light); }


/* ----------------------- STATS ----------------------- */

.c-stats { padding: var(--space-3xl) 0; }
.c-stats__header { text-align: center; max-width: 700px; margin: 0 auto var(--space-2xl); }
.c-stats__grid { display: grid; gap: var(--space-xl); text-align: center; }
@media (min-width: 769px) {
    .c-stats__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
    .c-stats__grid { grid-template-columns: repeat(4, 1fr); }
}
.c-stat__number { font-size: var(--text-4xl); font-weight: 700; color: var(--color-brand); line-height: 1; }
.c-stat__label { margin-top: var(--space-sm); font-size: var(--text-sm); text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-neutral-500); }

.c-stats--bg-white { background: #fff; }
.c-stats--bg-light { background: var(--color-bg-light); }
.c-stats--bg-dark { background: var(--color-bg-dark); color: #fff; }
.c-stats--bg-dark .c-stat__number { color: var(--color-brand-light); }
.c-stats--bg-dark .c-stat__label { color: var(--color-neutral-400); }
.c-stats--bg-brand { background: var(--color-brand); color: #fff; }
.c-stats--bg-brand .c-stat__number { color: #fff; }
.c-stats--bg-brand .c-stat__label { color: rgba(255,255,255,0.8); }


/* ----------------------- LOGO GRID ----------------------- */

.c-logos { padding: var(--space-2xl) 0; }
.c-logos__header { text-align: center; margin-bottom: var(--space-xl); }
.c-logos__header h2 { font-size: var(--text-lg); font-weight: 500; }
.c-logos__grid { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: var(--space-lg) var(--space-xl); }
.c-logos__item { max-width: 140px; height: 48px; display: flex; align-items: center; }
.c-logos__item img { max-width: 100%; max-height: 100%; object-fit: contain; transition: filter var(--transition), opacity var(--transition); }
.c-logos--gray .c-logos__item img { filter: grayscale(100%); opacity: 0.6; }
.c-logos--gray .c-logos__item:hover img { filter: grayscale(0); opacity: 1; }

.c-logos--bg-white { background: #fff; }
.c-logos--bg-light { background: var(--color-bg-light); }


/* ----------------------- FORM SECTION ----------------------- */

.c-form-section { padding: var(--space-3xl) 0; }
.c-form-section--center .c-form-section__inner { max-width: 600px; margin: 0 auto; }
.c-form-section--center .c-form-section__content { text-align: center; margin-bottom: var(--space-xl); }

@media (min-width: 768px) {
    .c-form-section--split .c-form-section__inner { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3xl); align-items: start; }
}

.c-form-section__form { background: #fff; padding: var(--space-xl); border-radius: var(--radius); box-shadow: var(--shadow); }

.c-form-section--bg-white { background: #fff; }
.c-form-section--bg-light { background: var(--color-bg-light); }
.c-form-section--bg-dark { background: var(--color-bg-dark); color: #fff; }
.c-form-section--bg-dark .eyebrow { color: var(--color-brand-light); }

.c-form-section__contact {
    list-style: none;
    margin: var(--space-xl) 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}
.c-form-section__contact-item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    color: var(--color-text);
    font-size: var(--text-base);
}
.c-form-section__contact-item svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    margin-top: 3px;
    color: var(--color-brand);
}
.c-form-section__contact-item a {
    color: var(--color-brand);
}
.c-form-section__contact-item a:hover {
    color: var(--color-brand-dark);
}

.iti__selected-country{
    display:none!important;
}

.gform_body input,
.gform_body textarea {
    font-size:var(--text-xl)!important;
    padding:1.25rem 1rem!important;
    display:block!important;
    min-height:50px!important;
    border-radius:0!important;
    border-color:var(--color-neutral-200);
    box-shadow:none!important;
}

.gform_body fieldset,
.gform-theme--foundation .gform-grid-row{
    margin:0!important;    
}

.gform-theme--foundation .gform_fields,
.gform-theme--foundation .gform-grid-row{
    gap:1.75rem!important;
}

.gform-theme--foundation .gform-grid-col{
    padding:0!important;
}

.gform_body input::placeholder,
.gform_body textarea::placeholder {
    color:var(--color-neutral-600);
}

.gform-theme--foundation .gform_footer{
    margin-block-start:0!important;
    margin-top:1.75rem!important;
}

.gfield_required_text,
.gform_validation_error_link,
.gfield_validation_message,
.gform_submission_error{
    color:var(--color-error-700)!important;
}

.gform-icon--circle-error{
	display:none!important;
}

.gform_validation_errors ol{
	padding:0!important;
}

.gform_validation_errors li{
	list-style-type:none;
	font-size:.875rem!important;
}

@media (max-width:1140px) {
    .gform-theme--foundation .gform-grid-row{
        flex-direction:column!important;
        align-items:flex-start!important;
    }

    .gform-theme--foundation .gform-grid-col.gform-grid-col--size-auto{
        flex-basis:100%!important;
        inline-size:100%!important;
    }

    .gform-theme--foundation .gfield--width-half{
        grid-column:span 12!important;
    }

    .gform-theme--foundation .gform_fields, 
    .gform-theme--foundation .gform-grid-row{
        gap:var(--space-sm)!important;
    }
}

@media (max-width:767px) {
	.c-form-section__form{
		margin-top:var(--space-2xl);
	}
}

/* ----------------------- TEXT BLOCK ----------------------- */

.c-text-block { padding: var(--space-3xl) 0; }
.c-text-block h2 { margin-bottom: var(--space-lg); }

.c-text-block--bg-white { background: #fff; }
.c-text-block--bg-light { background: var(--color-bg-light); }
.c-text-block--bg-dark { background: var(--color-bg-dark); color: #fff; }
.c-hero + .c-text-block--bg-dark {background:#021a31;}
.c-text-block--bg-dark .eyebrow { color: var(--color-brand-light); }
.c-text-block--bg-dark .prose { color: var(--color-neutral-300); }

.c-text-block.text-block-center * {
	text-align:center;
}

/* ----------------------- GALLERY ----------------------- */

.c-gallery { padding: var(--space-3xl) 0; }
.c-gallery__header { text-align: center; max-width: 700px; margin: 0 auto var(--space-2xl); }
.c-gallery__subhead { color: var(--color-neutral-600); margin-top: var(--space-sm); }

.c-gallery__grid {
    display: grid;
    gap: var(--space-md);
}
.c-gallery--cols-2 .c-gallery__grid { grid-template-columns: repeat(2, 1fr); }
.c-gallery--cols-3 .c-gallery__grid { grid-template-columns: repeat(2, 1fr); }
.c-gallery--cols-4 .c-gallery__grid { grid-template-columns: repeat(2, 1fr); }
.c-gallery--cols-5 .c-gallery__grid { grid-template-columns: repeat(2, 1fr); }

@media (min-width: 769px) {
    .c-gallery--cols-3 .c-gallery__grid { grid-template-columns: repeat(3, 1fr); }
    .c-gallery--cols-4 .c-gallery__grid { grid-template-columns: repeat(3, 1fr); }
    .c-gallery--cols-5 .c-gallery__grid { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1024px) {
    .c-gallery--cols-4 .c-gallery__grid { grid-template-columns: repeat(4, 1fr); }
    .c-gallery--cols-5 .c-gallery__grid { grid-template-columns: repeat(5, 1fr); }
}

.c-gallery__item {
    margin: 0;
    overflow: hidden;
    border-radius: var(--radius);
    cursor: pointer;
}
.c-gallery__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition);
}
.c-gallery__item:hover img {
    transform: scale(1.05);
}

/* Aspect ratios */
.c-gallery--square .c-gallery__item { aspect-ratio: 1/1; }
.c-gallery--landscape .c-gallery__item { aspect-ratio: 4/3; }
.c-gallery--portrait .c-gallery__item { aspect-ratio: 3/4; }
.c-gallery--wide .c-gallery__item { aspect-ratio: 16/9; }

/* Masonry layout */
.c-gallery--masonry .c-gallery__grid {
    display: block;
    column-gap: var(--space-md);
}
.c-gallery--masonry.c-gallery--cols-2 .c-gallery__grid { column-count: 2; }
.c-gallery--masonry.c-gallery--cols-3 .c-gallery__grid { column-count: 2; }
.c-gallery--masonry.c-gallery--cols-4 .c-gallery__grid { column-count: 2; }
.c-gallery--masonry.c-gallery--cols-5 .c-gallery__grid { column-count: 2; }

@media (min-width: 768px) {
    .c-gallery--masonry.c-gallery--cols-3 .c-gallery__grid { column-count: 3; }
    .c-gallery--masonry.c-gallery--cols-4 .c-gallery__grid { column-count: 3; }
    .c-gallery--masonry.c-gallery--cols-5 .c-gallery__grid { column-count: 3; }
}
@media (min-width: 1024px) {
    .c-gallery--masonry.c-gallery--cols-4 .c-gallery__grid { column-count: 4; }
    .c-gallery--masonry.c-gallery--cols-5 .c-gallery__grid { column-count: 5; }
}

.c-gallery--masonry .c-gallery__item {
    break-inside: avoid;
    margin-bottom: var(--space-md);
    aspect-ratio: auto;
}
.c-gallery--masonry .c-gallery__item img {
    height: auto;
}

/* Carousel layout */
.c-gallery__carousel {
    position: relative;
}
.c-gallery__track {
    display: flex;
    gap: var(--space-md);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding-bottom: var(--space-sm);
}
.c-gallery__track::-webkit-scrollbar { display: none; }

.c-gallery__slide {
    flex: 0 0 auto;
    width: 300px;
    scroll-snap-align: start;
    margin: 0;
    border-radius: var(--radius);
    overflow: hidden;
    cursor: pointer;
}
@media (min-width: 768px) {
    .c-gallery__slide { width: 400px; }
}
.c-gallery__slide img {
    width: 100%;
    height: 250px;
    object-fit: cover;
    transition: transform var(--transition);
}
@media (min-width: 768px) {
    .c-gallery__slide img { height: 300px; }
}
.c-gallery__slide:hover img {
    transform: scale(1.05);
}

.c-gallery__prev,
.c-gallery__next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    border: none;
    border-radius: 50%;
    box-shadow: var(--shadow);
    cursor: pointer;
    transition: background var(--transition);
    z-index: 2;
}
.c-gallery__prev:hover,
.c-gallery__next:hover { background: var(--color-neutral-100); }
.c-gallery__prev { left: var(--space-sm); }
.c-gallery__next { right: var(--space-sm); }
.c-gallery__prev svg,
.c-gallery__next svg { width: 20px; height: 20px; }

/* Backgrounds */
.c-gallery--bg-white { background: #fff; }
.c-gallery--bg-light { background: var(--color-bg-light); }
.c-gallery--bg-dark { background: var(--color-bg-dark); color: #fff; }
.c-gallery--bg-dark .eyebrow { color: var(--color-brand-light); }
.c-gallery--bg-dark .c-gallery__subhead { color: var(--color-neutral-400); }


/* ----------------------- LIGHTBOX ----------------------- */

.c-lightbox {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}
.c-lightbox.is-open {
    opacity: 1;
    pointer-events: auto;
}
.c-lightbox__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.95);
}
.c-lightbox__content {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-xl);
}
.c-lightbox__close {
    position: absolute;
    top: var(--space-md);
    right: var(--space-md);
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    color: #fff;
    cursor: pointer;
    opacity: 0.7;
    transition: opacity var(--transition);
}
.c-lightbox__close:hover { opacity: 1; }
.c-lightbox__close svg { width: 28px; height: 28px; }

.c-lightbox__prev,
.c-lightbox__next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    transition: background var(--transition);
}
.c-lightbox__prev:hover,
.c-lightbox__next:hover { background: rgba(255, 255, 255, 0.2); }
.c-lightbox__prev { left: var(--space-md); }
.c-lightbox__next { right: var(--space-md); }
.c-lightbox__prev svg,
.c-lightbox__next svg { width: 24px; height: 24px; }

.c-lightbox__figure {
    max-width: 90vw;
    max-height: 80vh;
    margin: 0;
    text-align: center;
}
.c-lightbox__image {
    max-width: 100%;
    max-height: 75vh;
    object-fit: contain;
}
.c-lightbox__caption {
    color: var(--color-neutral-400);
    font-size: var(--text-sm);
    margin-top: var(--space-md);
}
.c-lightbox__counter {
    position: absolute;
    bottom: var(--space-md);
    left: 50%;
    transform: translateX(-50%);
    color: var(--color-neutral-400);
    font-size: var(--text-sm);
}

@media (max-width: 768px) {
    .c-lightbox__prev,
    .c-lightbox__next {
        width: 40px;
        height: 40px;
        bottom: var(--space-3xl);
        top: auto;
        transform: none;
    }
    .c-lightbox__prev { left: var(--space-xl); }
    .c-lightbox__next { right: var(--space-xl); }
}


/* ----------------------- STICKY CTA ----------------------- */
.c-sticky-cta {
    display: none;
    position: fixed;
    bottom: var(--space-lg);
    right: var(--space-lg);
    z-index: 999999;
    align-items: center;
    height: 56px;
    background: var(--color-brand);
    border-radius: 28px;
    color: #fff;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    overflow: hidden;
    transition: background var(--transition);
}

@media (max-width: 900px) {
    .c-sticky-cta {
        display: flex;
    }
}

.c-sticky-cta__toggle {
    display: flex;
    align-items: center;
    height: 56px;
    padding: 0;
    background: transparent;
    border: none;
    color: #fff;
    cursor: pointer;
}

.c-sticky-cta__toggle:active {
    transform: scale(0.98);
}

.c-sticky-cta__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    flex-shrink: 0;
}

.c-sticky-cta__icon svg {
    width: 24px;
    height: 24px;
}

.c-sticky-cta__number {
    display: block;
    max-width: 0;
    overflow: hidden;
    white-space: nowrap;
    font-weight: 600;
    font-size: var(--text-base);
    color: #fff;
    text-decoration: none;
    transition: max-width 0.3s ease, padding 0.3s ease;
    padding: 0;
}

.c-sticky-cta__close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 0;
    overflow: hidden;
    flex-shrink: 0;
    transition: width 0.3s ease, padding 0.3s ease;
    padding: 0;
    background: transparent;
    border: none;
    color: #fff;
    cursor: pointer;
}

.c-sticky-cta__close svg {
    width: 20px;
    height: 20px;
    opacity: 0.8;
}

/* Expanded state */
.c-sticky-cta.is-open {
    background: var(--color-brand-dark);
}

.c-sticky-cta.is-open .c-sticky-cta__number {
    max-width: 200px;
    padding-right: var(--space-xs);
}

.c-sticky-cta.is-open .c-sticky-cta__close {
    width: 44px;
    padding-right: var(--space-sm);
}


/* =================================================================
   ICON CARDS
   ================================================================= */

.c-icon-cards { padding: var(--space-3xl) 0; position: relative; }
.c-icon-cards--bg-light { background: var(--color-bg-light); }
.c-icon-cards--bg-dark { background: var(--color-neutral-800); color: #fff; }
.c-icon-cards--bg-dark h2, .c-icon-cards--bg-dark h3, .c-icon-cards--bg-dark h4 { color: #fff; }
.c-icon-cards--bg-brand { background: var(--color-brand); color: #fff; }
.c-icon-cards--bg-brand h2, .c-icon-cards--bg-brand h3, .c-icon-cards--bg-brand h4 { color: #fff; }

.c-icon-cards__inner { position: relative; z-index: 1; }

.c-icon-cards__header {
    text-align: center;
    max-width: 800px;
    margin: 0 auto var(--space-2xl);
}
.c-icon-cards__header h2, .c-icon-cards__header h3, .c-icon-cards__header h4 {
    font-size: var(--text-3xl);
    margin-bottom: var(--space-md);
}
.c-icon-cards__header .subhead {
    font-size: var(--text-lg);
    color: var(--color-neutral-600);
}
.c-icon-cards--bg-dark .c-icon-cards__header .subhead,
.c-icon-cards--bg-brand .c-icon-cards__header .subhead,
.c-icon-cards--bg-image .c-icon-cards__header .subhead { color: rgba(255,255,255,0.8); }

.c-icon-cards__grid {
    display: grid;
    gap: var(--space-xl);
}
.c-icon-cards--cols-2 .c-icon-cards__grid { grid-template-columns: repeat(2, 1fr); }
.c-icon-cards--cols-3 .c-icon-cards__grid { grid-template-columns: repeat(3, 1fr); }
.c-icon-cards--cols-4 .c-icon-cards__grid { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 1024px) {
    .c-icon-cards--cols-3 .c-icon-cards__grid,
    .c-icon-cards--cols-4 .c-icon-cards__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
    .c-icon-cards__grid { grid-template-columns: 1fr !important; }
}

/* Card base */
.c-icon-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

/* Icon positioning */
.c-icon-cards--top .c-icon-card { text-align: center; align-items: center; }
.c-icon-cards--left .c-icon-card { flex-direction: row; align-items: flex-start; }

/* Card styles */
.c-icon-cards--boxed .c-icon-card {
    background: #fff;
    padding: var(--space-xl);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}
.c-icon-cards--bg-dark.c-icon-cards--boxed .c-icon-card,
.c-icon-cards--bg-brand.c-icon-cards--boxed .c-icon-card,
.c-icon-cards--bg-image.c-icon-cards--boxed .c-icon-card {
    background: rgba(255,255,255,0.1);
    backdrop-filter: blur(10px);
}

.c-icon-cards--bordered .c-icon-card {
    border: 1px solid var(--color-neutral-200);
    padding: var(--space-xl);
    border-radius: var(--radius);
}
.c-icon-cards--bg-dark.c-icon-cards--bordered .c-icon-card,
.c-icon-cards--bg-brand.c-icon-cards--bordered .c-icon-card,
.c-icon-cards--bg-image.c-icon-cards--bordered .c-icon-card {
    border-color: rgba(255,255,255,0.2);
}

/* Icon */
.c-icon-card__icon {
    width: 56px;
    height: 56px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-brand-light);
    border-radius: var(--radius);
    color: var(--color-brand-dark);
}
.c-icon-card__icon svg {
    width: 28px;
    height: 28px;
}
.c-icon-card__img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.c-icon-cards--bg-dark .c-icon-card__icon,
.c-icon-cards--bg-brand .c-icon-card__icon,
.c-icon-cards--bg-image .c-icon-card__icon {
    background: rgba(255,255,255,0.15);
    color: #fff;
}

/* Content */
.c-icon-card__content { flex: 1; } 
.c-icon-card__title {
    font-size: var(--text-lg);
    font-weight: 600;
    margin-bottom: var(--space-xs);
}
.c-icon-card__desc {
    font-size: var(--text-base);
    color: var(--color-neutral-600);
    margin-bottom: var(--space-sm);
}
.c-icon-cards--bg-dark .c-icon-card__desc,
.c-icon-cards--bg-brand .c-icon-card__desc,
.c-icon-cards--bg-image .c-icon-card__desc { color: rgba(255,255,255,0.8); }

.c-icon-card__link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    font-weight: 600;
    color: var(--color-brand);
    text-decoration: none;
    transition: gap 0.2s ease;
}
.c-icon-card__link:hover { gap: var(--space-sm); }
.c-icon-card__link svg { width: 16px; height: 16px; }

.c-icon-cards--bg-dark .c-icon-card__link,
.c-icon-cards--bg-brand .c-icon-card__link,
.c-icon-cards--bg-image .c-icon-card__link { color: #fff; }


/* =================================================================
   MAP EMBED
   ================================================================= */

.c-map { padding: var(--space-3xl) 0; position: relative; }
.c-map--bg-light { background: var(--color-bg-light); }
.c-map--bg-dark { background: var(--color-neutral-800); color: #fff; }
.c-map--bg-dark h2, .c-map--bg-dark h3, .c-map--bg-dark h4 { color: #fff; }
.c-map--bg-brand { background: var(--color-brand); color: #fff; }
.c-map--bg-brand h2, .c-map--bg-brand h3, .c-map--bg-brand h4 { color: #fff; }

.c-map__inner { position: relative; z-index: 1; }

.c-map__header {
    text-align: center;
    max-width: 800px;
    margin: 0 auto var(--space-2xl);
}
.c-map__header h2, .c-map__header h3, .c-map__header h4 {
    font-size: var(--text-3xl);
    margin-bottom: var(--space-md);
}
.c-map__header .subhead {
    font-size: var(--text-lg);
    color: var(--color-neutral-600);
}
.c-map--bg-dark .c-map__header .subhead,
.c-map--bg-brand .c-map__header .subhead,
.c-map--bg-image .c-map__header .subhead { color: rgba(255,255,255,0.8); }

.c-map__embed {
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}
.c-map__embed iframe {
    display: block;
    width: 100%;
    border: 0;
}

/* Height variants */
.c-map--h-small .c-map__embed iframe { height: 300px; }
.c-map--h-medium .c-map__embed iframe { height: 450px; }
.c-map--h-large .c-map__embed iframe { height: 600px; }

@media (max-width: 767px) {
    .c-map--h-small .c-map__embed iframe { height: 250px; }
    .c-map--h-medium .c-map__embed iframe { height: 350px; }
    .c-map--h-large .c-map__embed iframe { height: 450px; }
}


/* =================================================================
   CONTACT INFO BLOCK
   ================================================================= */

.c-contact-info { padding: var(--space-3xl) 0; position: relative; }
.c-contact-info--bg-light { background: var(--color-bg-light); }
.c-contact-info--bg-dark { background: var(--color-neutral-800); color: #fff; }
.c-contact-info--bg-dark h2, .c-contact-info--bg-dark h3, .c-contact-info--bg-dark h4 { color: #fff; }
.c-contact-info--bg-brand { background: var(--color-brand); color: #fff; }
.c-contact-info--bg-brand h2, .c-contact-info--bg-brand h3, .c-contact-info--bg-brand h4 { color: #fff; }

.c-contact-info__inner { position: relative; z-index: 1; }

.c-contact-info__header {
    text-align: center;
    max-width: 800px;
    margin: 0 auto var(--space-2xl);
}
.c-contact-info__header h2, .c-contact-info__header h3, .c-contact-info__header h4 {
    font-size: var(--text-3xl);
    margin-bottom: var(--space-md);
}
.c-contact-info__header .subhead {
    font-size: var(--text-lg);
    color: var(--color-neutral-600);
}
.c-contact-info--bg-dark .c-contact-info__header .subhead,
.c-contact-info--bg-brand .c-contact-info__header .subhead,
.c-contact-info--bg-image .c-contact-info__header .subhead { color: rgba(255,255,255,0.8); }

/* Items layout */
.c-contact-info__items {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xl);
}

/* Stacked layout (default) */
.c-contact-info--stacked .c-contact-info__items {
    flex-direction: column;
    align-items: center;
    max-width: 500px;
    margin: 0 auto;
}
.c-contact-info--stacked .c-contact-info__item {
    text-align: center;
    flex-direction: column;
}
.c-contact-info--stacked .c-contact-info__icon { margin-bottom: var(--space-sm); }

/* Inline layout */
.c-contact-info--inline .c-contact-info__items {
    justify-content: center;
}
@media (max-width: 1024px) {
    .c-contact-info--inline .c-contact-info__items {
        flex-direction: column;
        align-items: center;
    }
}

/* Individual item */
.c-contact-info__item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
}

.c-contact-info__icon {
    width: 48px;
    height: 48px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-brand);
    border-radius: 50%;
    color: #fff;
}
.c-contact-info__icon svg {
    width: 22px;
    height: 22px;
}
.c-contact-info--bg-dark .c-contact-info__icon,
.c-contact-info--bg-brand .c-contact-info__icon,
.c-contact-info--bg-image .c-contact-info__icon {
    background: rgba(255,255,255,0.2);
}

.c-contact-info__content { flex: 1; }

.c-contact-info__label {
    font-size: var(--text-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-neutral-500);
    margin-bottom: var(--space-xs);
}
.c-contact-info--bg-dark .c-contact-info__label,
.c-contact-info--bg-brand .c-contact-info__label,
.c-contact-info--bg-image .c-contact-info__label { color: rgba(255,255,255,0.6); }

.c-contact-info__value {
    font-size: var(--text-lg);
    color: var(--color-neutral-800);
}
.c-contact-info--bg-dark .c-contact-info__value,
.c-contact-info--bg-brand .c-contact-info__value,
.c-contact-info--bg-image .c-contact-info__value { color: #fff; }

.c-contact-info__link {
    color: var(--color-brand);
    text-decoration: none;
    transition: color 0.2s ease;
}
.c-contact-info__link:hover {
    text-decoration: underline;
}
.c-contact-info--bg-dark .c-contact-info__link,
.c-contact-info--bg-brand .c-contact-info__link,
.c-contact-info--bg-image .c-contact-info__link { color: #fff; }

.c-contact-info__empty {
    text-align: center;
    color: var(--color-neutral-500);
    font-style: italic;
}


/* =================================================================
   ARCHIVE
   ================================================================= */

.archive-page { padding: var(--space-3xl) 0; }

.archive-page__header {
    margin-bottom: var(--space-2xl);
}
.archive-page__title {
    font-size: var(--text-4xl);
    margin-bottom: var(--space-sm);
}
.archive-page__description {
    font-size: var(--text-lg);
    color: var(--color-neutral-600);
    max-width: 700px;
}
.archive-page__description p:last-child { margin-bottom: 0; }

/* Archive grid */
.archive-page__grid {
    display: grid;
    gap: var(--space-xl);
}
.archive-page--grid.archive-page--cols-2 .archive-page__grid {
    grid-template-columns: repeat(2, 1fr);
}
.archive-page--grid.archive-page--cols-3 .archive-page__grid {
    grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 1024px) {
    .archive-page--grid.archive-page--cols-3 .archive-page__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 767px) {
    .archive-page__grid { grid-template-columns: 1fr !important; }
}

/* List layout */
.archive-page--list .archive-page__grid {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}
.archive-page--list .archive-card {
    flex-direction: row;
    align-items: flex-start;
}
.archive-page--list .archive-card__image {
    width: 280px;
    flex-shrink: 0;
}
@media (max-width: 767px) {
    .archive-page--list .archive-card {
        flex-direction: column;
    }
    .archive-page--list .archive-card__image {
        width: 100%;
    }
}

/* Archive card */
.archive-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow: hidden;
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.archive-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}

.archive-card__image {
    display: block;
    overflow: hidden;
}
.archive-card__image img {
    aspect-ratio: 16/9;
    object-fit: cover;
    width: 100%;
    transition: transform 0.3s ease;
}
.archive-card:hover .archive-card__image img {
    transform: scale(1.03);
}

.archive-card__content {
    padding: var(--space-lg);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.archive-card__header { margin-bottom: var(--space-sm); }

.archive-card__title {
    font-size: var(--text-xl);
    line-height: var(--leading-tight);
    margin-bottom: var(--space-xs);
}
.archive-card__title a {
    color: inherit;
    text-decoration: none;
}
.archive-card__title a:hover {
    color: var(--color-brand);
}

.archive-card__meta {
    font-size: var(--text-sm);
    color: var(--color-neutral-500);
    display: flex;
    align-items: center;
    gap: var(--space-xs);
}
.archive-card__sep { opacity: 0.5; }

.archive-card__excerpt {
    color: var(--color-neutral-600);
    flex: 1;
}
.archive-card__excerpt p { margin: 0; }

/* Empty state */
.archive-page__empty {
    text-align: center;
    padding: var(--space-3xl) var(--space-xl);
    color: var(--color-neutral-500);
}

/* Pagination */
.pagination {
    margin-top: var(--space-2xl);
    display: flex;
    justify-content: center;
}
.pagination__list {
    display: flex;
    gap: var(--space-xs);
    list-style: none;
    padding: 0;
    margin: 0;
}
.pagination__item a,
.pagination__item span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 var(--space-sm);
    border-radius: var(--radius);
    text-decoration: none;
    font-weight: 500;
    transition: background 0.2s ease, color 0.2s ease;
}
.pagination__item a {
    color: var(--color-neutral-700);
    background: var(--color-neutral-100);
}
.pagination__item a:hover {
    background: var(--color-brand);
    color: #fff;
}
.pagination__item--current span {
    background: var(--color-brand);
    color: #fff;
}


/* =================================================================
   SINGLE POST
   ================================================================= */

.single-page { padding: var(--space-3xl) 0; }

/* Post article */
.single-post { margin-bottom: var(--space-2xl); }

.single-post__header {
    margin-bottom: var(--space-xl);
}
.single-post__title {
    font-size: var(--text-4xl);
    line-height: var(--leading-tight);
    margin-bottom: var(--space-sm);
}
.single-post__meta {
    font-size: var(--text-sm);
    color: var(--color-neutral-500);
}

.single-post__image {
    margin-bottom: var(--space-xl);
    border-radius: var(--radius);
    overflow: hidden;
}
.single-post__image img {
    width: 100%;
    height: auto;
}

.single-post__content {
    margin-bottom: var(--space-xl);
}

.single-post__footer {
    padding-top: var(--space-lg);
    border-top: 1px solid var(--color-neutral-200);
}
.single-post__taxonomies {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
    align-items: center;
    margin-bottom: var(--space-sm);
}
.single-post__taxonomies:last-child { margin-bottom: 0; }
.single-post__tax-label {
    font-weight: 600;
    color: var(--color-neutral-600);
    margin-right: var(--space-xs);
}
.single-post__taxonomies a {
    color: var(--color-brand);
    text-decoration: none;
}
.single-post__taxonomies a:hover {
    text-decoration: underline;
}

/* Author box */
.author-box {
    display: flex;
    gap: var(--space-lg);
    padding: var(--space-xl);
    background: var(--color-neutral-50);
    border-radius: var(--radius);
    margin-bottom: var(--space-2xl);
}
@media (max-width: 600px) {
    .author-box {
        flex-direction: column;
        text-align: center;
    }
}

.author-box__avatar { flex-shrink: 0; }
.author-box__img {
    width: 80px;
    height: 80px;
    border-radius: 50%;
}

.author-box__content { flex: 1; }
.author-box__name {
    font-size: var(--text-lg);
    margin-bottom: var(--space-xs);
}
.author-box__name a {
    color: inherit;
    text-decoration: none;
}
.author-box__name a:hover {
    color: var(--color-brand);
}
.author-box__bio {
    color: var(--color-neutral-600);
    margin-bottom: var(--space-sm);
}
.author-box__bio p:last-child { margin-bottom: 0; }
.author-box__link {
    color: var(--color-brand);
    text-decoration: none;
    font-weight: 500;
}
.author-box__link:hover {
    text-decoration: underline;
}

/* Related posts */
.related-posts {
    margin-bottom: var(--space-2xl);
    padding-top: var(--space-xl);
    border-top: 1px solid var(--color-neutral-200);
}
.related-posts__title {
    font-size: var(--text-2xl);
    margin-bottom: var(--space-lg);
}
.related-posts__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
}
@media (max-width: 767px) {
    .related-posts__grid {
        grid-template-columns: 1fr;
    }
}

.related-posts__item {
    background: #fff;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow: hidden;
}
.related-posts__image {
    display: block;
    overflow: hidden;
}
.related-posts__image img {
    aspect-ratio: 16/9;
    object-fit: cover;
    width: 100%;
    transition: transform 0.3s ease;
}
.related-posts__item:hover .related-posts__image img {
    transform: scale(1.03);
}
.related-posts__item-title {
    font-size: var(--text-base);
    padding: var(--space-md);
    padding-bottom: var(--space-xs);
}
.related-posts__item-title a {
    color: inherit;
    text-decoration: none;
}
.related-posts__item-title a:hover {
    color: var(--color-brand);
}
.related-posts__date {
    display: block;
    padding: 0 var(--space-md) var(--space-md);
    font-size: var(--text-sm);
    color: var(--color-neutral-500);
}

/* Post navigation */
.post-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-lg);
    padding-top: var(--space-xl);
    border-top: 1px solid var(--color-neutral-200);
}
@media (max-width: 600px) {
    .post-nav {
        grid-template-columns: 1fr;
    }
}

.post-nav__link {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    padding: var(--space-lg);
    background: var(--color-neutral-50);
    border-radius: var(--radius);
    text-decoration: none;
    transition: background 0.2s ease;
}
.post-nav__link:hover {
    background: var(--color-neutral-100);
}
.post-nav__link--empty {
    opacity: 0;
    pointer-events: none;
}
.post-nav__link--next {
    text-align: right;
}

.post-nav__label {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-neutral-500);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.post-nav__link--next .post-nav__label {
    justify-content: flex-end;
}
.post-nav__label svg {
    width: 16px;
    height: 16px;
}

.post-nav__title {
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-neutral-800);
    line-height: var(--leading-tight);
}

/* Search form */
.search-form-wrap {
    margin-bottom: var(--space-2xl);
}
.search-form {
    display: flex;
    gap: var(--space-sm);
    max-width: 500px;
}
.search-form label {
    flex: 1;
}
.search-form .search-field {
    width: 100%;
    padding: var(--space-sm) var(--space-md);
    border: 1px solid var(--color-neutral-300);
    border-radius: var(--radius);
    font-size: var(--text-base);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.search-form .search-field:focus {
    outline: none;
    border-color: var(--color-brand);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}
.search-form .search-submit {
    padding: var(--space-sm) var(--space-lg);
    background: var(--color-brand);
    color: #fff;
    border: none;
    border-radius: var(--radius);
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s ease;
}
.search-form .search-submit:hover {
    background: var(--color-brand-dark);
}


/* =================================================================
   404 PAGE
   ================================================================= */
.privacy-policy main > section,
.error-404 {
    padding: 220px 0;
    min-height: 60vh;
    display: flex;
    align-items: center;
    text-align: center;
    background: var(--color-bg-light);
}
.error-404 .container { width: 100%; max-width: 600px; }
.error-404__code {
    font-family: var(--font-heading);
    font-size: clamp(6rem, 20vw, 12rem);
    font-weight: 700;
    line-height: 1;
    /* color: var(--color-neutral-200); */
    margin-bottom: var(--space-md);
}
.error-404 h1 {
    font-size: var(--text-3xl);
    color: var(--color-neutral-800);
    margin-bottom: var(--space-md);
}
.error-404__content {
    color: var(--color-neutral-600);
    margin-bottom: var(--space-xl);
}
.error-404__content p { margin-bottom: var(--space-md); }
.error-404__content p:last-child { margin-bottom: 0; }
.error-404__actions {
    display: flex;
    gap: var(--space-md);
    justify-content: center;
    flex-wrap: wrap;
}

.page-content { padding: var(--space-3xl) 0; }
.page-content h1 { margin-bottom: var(--space-xl); }

@media (max-width:600px) {
	.privacy-policy main > section,
.error-404{
	padding:140px 0;
}
}


/* =================================================================
   ALBERTO'S BRAND SITE-WIDE STYLES
   ================================================================= */

/* ---- Buttons -------------------------------------------------- */
.btn {
    font-family: var(--font-heading);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 2.7px;
    text-transform: uppercase;
    min-height: 60px;
    padding: 0 2rem;
    border-radius: 0;
    gap: var(--space-sm);
}
.btn--sm {
    min-height: 44px;
    padding: 0 1.25rem;
    font-size: 13px;
    letter-spacing: 2px;
}

/* Arrow pseudo-element ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â dark for light-bg buttons (default) */
.btn::after {
    content: '';
    display: inline-block;
    width: 18px;
    height: 10px;
    background: url('/wp-content/uploads/arrow-right-long-dark.svg') center/contain no-repeat;
    flex-shrink: 0;
    transition: transform var(--transition);
}
.btn:hover::after { transform: translateX(4px); }

/* Tan/cream arrow for dark-background buttons */
.btn--primary::after,
.btn--outline-light::after {
    background-image: url('/wp-content/uploads/arrow-right-long-dark.svg');
}

/* Cream-bg primary override (header + hero) needs dark arrow */
.site-header .btn--primary::after,
.c-hero .btn--white::after,
.c-cta--bg-brand .btn--white::after {
    background-image: url('/wp-content/uploads/arrow-right-long-dark.svg');
}

.c-cta--bg-brand .btn--outline-light::after,
.c-hero .btn--outline-light::after{
    background-image: url('/wp-content/uploads/arrow-right-long-tan.svg');
}

/* Primary button on light/white backgrounds: brand-dark bg, cream text + arrow */
[class*="--bg-light"] .btn--primary,
[class*="--bg-white"] .btn--primary {
    background: var(--color-brand-dark);
    color: var(--color-cream);
    border-color: var(--color-brand-dark);
}
[class*="--bg-light"] .btn--primary::after,
[class*="--bg-white"] .btn--primary::after {
    background-image: url('/wp-content/uploads/arrow-right-long-tan.svg');
}
[class*="--bg-light"] .btn--primary:hover,
[class*="--bg-white"] .btn--primary:hover {
    background: #fff;
    border-color: #fff;
    color: var(--color-brand-dark);
}
[class*="--bg-light"] .btn--primary:hover::after,
[class*="--bg-white"] .btn--primary:hover::after {
    background-image: url('/wp-content/uploads/arrow-right-long-dark.svg');
}


/* =================================================================
   ALBERTO'S BRAND ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â HOMEPAGE OVERRIDES
   Site-specific CSS targeting custom IDs and class combinations
   applied to this client's page builder content.
   ================================================================= */

/* Gravity Forms submit â€” matches .btn--primary on light/white backgrounds */
.gform_button {
    display: inline-flex!important;
    align-items: center!important;
    justify-content: center!important;
    gap: var(--space-sm)!important;
    width: 100%!important;
    padding: 0 2rem!important;
    font-family: var(--font-heading)!important;
    font-size: 15px!important;
    font-weight: 700!important;
    letter-spacing: 2.7px!important;
    text-transform: uppercase!important;
    border-radius: 0!important;
    border: 2px solid transparent;
    min-height: 60px!important;
    cursor: pointer!important;
    transition: all var(--transition)!important;
    background: var(--color-brand-dark)!important;
    color: var(--color-cream)!important;
    border-color: var(--color-brand-dark)!important;
}
.gform_button:hover {
    background: #fff!important;
    border-color: #fff!important;
    color: var(--color-brand-dark)!important;
}
button.gform_button::after {
    content: '';
    display: inline-block;
    width: 18px;
    height: 10px;
    background: url('/wp-content/uploads/arrow-right-long-tan.svg') center/contain no-repeat;
    flex-shrink: 0;
    transition: transform var(--transition);
}
button.gform_button:hover::after {
    background-image: url('/wp-content/uploads/arrow-right-long-dark.svg');
    transform: translateX(4px);
}

/* ---- Header: transparent overlay on homepage ------------------- */
.site-header {
    position: fixed;
    inset: 0 0 auto 0;       /* fixed needs explicit left/right to span full width */
    width: 100%;
    background: transparent;
    border-bottom: none;
    transition: all var(--transition);
	height:132px;
	padding:1rem 0;
}
.privacy-policy .site-header,
.error404 .site-header{
	background: var(--color-navy-mid);
}
/* WP admin bar offset: push fixed header below the admin bar when logged in */
body.admin-bar .site-header { top: 32px; }
@media screen and (max-width: 782px) {
    body.admin-bar .site-header { top: 46px; }
}
/* Mobile WP admin bar isn't fixed ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â restore top:0 when it scrolls away */
@media screen and (max-width: 600px) {
    body.admin-bar .site-header { top: 0; }
}
/* =================================================================
   HEADER LAYOUT ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â three responsive tiers
   ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â°ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¥1461  : logo + absolutely-centered menu + phone + CTA
   1100ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã¢â‚¬Å“1460 : logo + (menu inline next to actions) + phone + CTA
   ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â°ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¤1099  : logo + hamburger toggle (menu+actions live inside the drawer)
   ================================================================= */
body .site-header__inner {
    max-width: none;
    width: 100%;
    padding-left: clamp(20px, 4.2vw, 80px);
    padding-right: clamp(20px, 4.2vw, 80px);
    display: flex;
    align-items: center;          /* vertical-center every direct child */
    justify-content: space-between;
    column-gap: 24px;
    position: relative;           /* anchor for absolutely-centered menu */
}
body .site-header__logo {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}
body .site-nav {
    display: flex;
    align-items: center;
    gap: 40px;
}
body .site-nav__menu {
    display: flex;
    align-items: center;          /* vertical-center menu items */
    margin: 0;
    gap: 36px;
}
body .site-nav__actions {
    display: flex;
    align-items: center;
    gap: 40px;
    border-left: 0;
    padding-left: 0;
    margin-left: 0;
}
.site-nav__phone svg { display: none; }
.site-nav__phone {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--font-heading);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 2.1px;
    color: var(--color-cream);
    white-space: nowrap;
}
.site-nav__phone::before {
    content: '';
    display: inline-block;
    width: 12px;
    height: 12px;
    background: url('/wp-content/uploads/phone-icon.svg') center/contain no-repeat;
    flex-shrink: 0;
}

/* ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â°ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¥1461px ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â absolutely center the menu on the viewport */
@media (min-width: 1461px) {
    body .site-nav__menu {
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
    }
}

/* ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â°ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¤1099 ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â collapse to mobile: hide inline menu+actions, show toggle, drawer activates */
@media (max-width: 1099px) {
    /* Show the hamburger (overrides the global min-width:769 hide rule) */
    body .site-header__toggle {
        display: flex !important;
        align-items: center;
        justify-content: center;
    }

    /* When the nav drawer is closed, hide its inline content */
    body .site-nav:not(.is-open) .site-nav__menu,
    body .site-nav:not(.is-open) .site-nav__actions {
        display: none;
    }

    /* Slide-in drawer: dark navy panel, full-screen */
    body .site-nav {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        background: var(--color-navy);
        padding: clamp(96px, 12vh, 132px) clamp(24px, 6vw, 48px) 32px;
        transform: translateX(100%);
        transition: transform 0.3s ease;
        overflow-y: auto;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        z-index: 100;
    }
    body .site-nav.is-open { transform: translateX(0); }
    body.nav-open { overflow: hidden; }

    /* Drawer-open: menu becomes a vertical stack */
    body .site-nav.is-open .site-nav__menu {
        display: flex;
        flex-direction: column;
        gap: 0;
        width: 100%;
        position: static;
        transform: none;
    }
    body .site-nav.is-open .site-nav__menu > li {
        display: block;
        width: 100%;
        border-bottom: 1px solid rgba(244, 236, 224, 0.12);
    }
    body .site-nav.is-open .site-nav__menu > li > a {
        display: block;
        padding: 16px 0;
        font-family: var(--font-heading);
        font-weight: 500;
        font-size: 18px;
        letter-spacing: 2.34px;
        text-transform: uppercase;
        color: var(--color-cream);
    }
    body .site-nav.is-open .site-nav__menu > li > a:hover,
    body .site-nav.is-open .site-nav__menu > li > a:focus {
        color: var(--color-accent-light);
    }

    /* Drawer-open: actions stacked vertically below menu ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â CTA button first, phone centered below */
    body .site-nav.is-open .site-nav__actions {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 20px;
        margin-top: 24px;
        padding-top: 0;
        border-top: 0;                /* no divider above actions */
        width: 100%;
    }
    body .site-nav.is-open .btn--primary {
        order: 1;
        width: 100%;
        justify-content: center;
    }
    body .site-nav.is-open .site-nav__phone {
        order: 2;                     /* phone sits below the CTA button */
        align-self: center;           /* centered horizontally in the column */
        color: var(--color-cream);
        font-size: 16px;
    }
    body .site-nav.is-open .site-nav__phone span { display: inline; }

    /* Hamburger button color: cream over navy header (and over scrolled header) */
    body .site-header__toggle span,
    body .site-header__toggle::before,
    body .site-header__toggle::after { background: var(--color-cream); }
}

/* ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â°ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¤768 ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â tighten padding + logo size */
@media (max-width: 768px) {
    body .site-header__inner { padding-inline: 20px; }
    body .site-header__logo,
    body .site-header__logo img,
    body .site-header__logo picture { width: clamp(96px, 28vw, 134px); }
}

/* Very narrow phones (ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â°ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¤400) */
@media (max-width: 400px) {
    body .site-header__inner { padding-inline: 16px; column-gap: 12px; }
    body .site-header__logo,
    body .site-header__logo img,
    body .site-header__logo picture { width: 96px; }
}
body.scrolled .site-header {
    background: var(--color-navy-mid);
    box-shadow: 0 2px 24px rgba(0,0,0,0.4);
	padding:0.5rem 0;
	height:90px;
}
/* Nav links: white on homepage */
.site-nav__menu li > a,
.site-nav__menu li > span {
    font-family: var(--font-heading);
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 2.34px;
    text-transform: uppercase;
    color: #fff;
}
.site-nav__menu li > a:hover { color: var(--color-accent-light); }
.site-nav__phone { color: var(--color-cream); font-family: var(--font-heading); letter-spacing: 2.1px; font-size: 15px; font-weight: 700; }
.site-header .btn--primary {
    background: var(--color-cream);
    color: var(--color-navy);
    border-color: var(--color-cream);
    font-family: var(--font-heading);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 2.7px;
    text-transform: uppercase;
    min-height: 60px;
}
.site-header .btn--primary:hover { background: #fff; border-color: #fff; }
/* Header height: 88px to match Figma */
.site-header__inner {/* height: 88px; */}
/* Logo size: Figma combined glyph+text block ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â°ÃƒÆ’Ã¢â‚¬Â¹ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â  134px wide; PNG is 300ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â189 (1.59:1)
   so width: 134 yields height ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â°ÃƒÆ’Ã¢â‚¬Â¹ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â  84px which fits within the 88px header */
body .site-header__logo img,
body .site-header__logo picture,
body .site-header__logo {
    width: 160px;
	transition:width var(--transition);
    height: auto;
}

body.scrolled .site-header__logo img, 
body.scrolled .site-header__logo picture, 
body.scrolled .site-header__logo{
	width: 110px;
}

body. .site-header__logo img { display: block; }
/* Hamburger icon white on homepage */
body .site-header__toggle span,
body .site-header__toggle::before,
body .site-header__toggle::after { background: #fff; }

/* ---- Hero: center, compensate for fixed header ----------------- */
.c-hero {
    text-align: center;
    padding-top: 140px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background-color: var(--color-navy);
}

.c-hero.c-hero--h-medium{
	min-height:60vh;
}

.home .c-hero{
    padding-top: 88px;
    min-height: 100vh;	
}
.c-hero .c-hero__overlay { background: #012241; }
.c-hero .c-hero__inner { display: flex; flex-direction: column; align-items: center; max-width: 1400px; }
/* Remove max-width cap so heading uses full container width */
.c-hero .c-hero__content { margin: 0 auto; max-width: none; }
.c-hero .c-hero__buttons { justify-content: center; }

/* Eyebrow with flanking lines */
.c-hero__eyebrow {
    display: flex;
	justify-content: center;
    align-items: center;
    gap: 14px;
    font-family: var(--font-heading);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 3.64px;
    text-transform: uppercase;
    color: #fff;
    opacity: 1;
    margin-bottom: 0px;
}

.c-hero__eyebrow::before,
.c-hero__eyebrow::after {
    content: '';
    display: block;
    flex: 0 0 28px;
    height: 1px;
    background: rgba(255,255,255,0.55);
}

.c-hero .c-hero__badge {
    display: flex;
    justify-content: center;
    margin-bottom: 0; 
	margin-top:-.5rem;
	margin-bottom:-.75rem;
}
.c-hero .c-hero__badge-img {
    width: 280px;                    
    height: 280px;
    object-fit: contain;
}

/* Headline: 90px ExtraBold */
.c-hero .c-hero__headline span { display: block; }
.c-hero .c-hero__headline {
    font-family: var(--font-heading);
    font-size: clamp(42px, 5.5vw, 85px);
    font-weight: 800;
    letter-spacing: -2.04px;
    line-height: 1;
    text-transform: uppercase;
    color: #fff;
    margin-bottom: var(--space-lg);
}

.c-hero .c-hero__subhead {
    font-size: 18px;
    line-height: 1.6;
    color: #fff;
    opacity: 0.9;
    max-width: 620px;
    margin: 0 auto var(--space-xl);
}
.c-hero .c-hero__subhead p { margin: 0; }

/* Buttons: cream primary, translucent outline secondary */
.c-hero .btn--white {
    background: var(--color-cream);
    color: var(--color-navy);
    border-color: var(--color-cream);
    font-family: var(--font-heading);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 2.7px;
    text-transform: uppercase;
    min-height: 60px;
    padding-inline: 2rem;
}
.c-hero .btn--white:hover { background: #fff; border-color: #fff; }
.c-hero .btn--outline-light {
    background: transparent;
    border-color: rgba(244,236,224,0.45);
    color: var(--color-cream);
    font-family: var(--font-heading);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 2.7px;
    text-transform: uppercase;
    min-height: 60px;
    padding-inline: 2rem;
}
.c-hero .btn--outline-light:hover { background: rgba(244,236,224,0.1); }

.c-hero--h-large .c-hero__bottom-bar,
.c-hero--h-full .c-hero__bottom-bar {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 0 clamp(24px, 4.2vw, 48px) 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    z-index: 2;
}
.c-hero--h-large .c-hero__bar-item,
.c-hero--h-full .c-hero__bar-item {
    font-family: var(--font-heading);
    font-weight: 400;
    font-size: 12px;
    letter-spacing: 2.64px;
    text-transform: uppercase;
    color: var(--color-cream);
    line-height: 1;
    flex: 1;
}
.c-hero--h-large .c-hero__bar-side--left  { text-align: left;  }
.c-hero--h-large .c-hero__bar-side--right { text-align: right; }
.c-hero--h-full  .c-hero__bar-side--left  { text-align: left;  }
.c-hero--h-full  .c-hero__bar-side--right { text-align: right; }
/* Centered scroll cue: text + down arrow, link styling reset */
.c-hero--h-large .c-hero__bar-center,
.c-hero--h-full  .c-hero__bar-center {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 20px;                /* Figma: 20px gap between text and arrow */
    flex: 0 0 auto;
    color: var(--color-cream);
    text-decoration: none;
    transition: opacity 0.2s ease;
}
.c-hero--h-large .c-hero__bar-center:hover,
.c-hero--h-full  .c-hero__bar-center:hover { opacity: 0.8; }
.c-hero__bar-arrow {
    color: var(--color-cream);
    flex-shrink: 0;
    animation: hero-scroll-cue 2.4s ease-in-out infinite;
}
@keyframes hero-scroll-cue {
    0%, 60%, 100% { transform: translateY(0); }
    30%           { transform: translateY(4px); }
}
@media (prefers-reduced-motion: reduce) {
    .c-hero__bar-arrow { animation: none; }
}
@media (max-width: 700px) {
    /* On small screens, hide the side items to keep the scroll cue centered & readable */
    .c-hero--h-large .c-hero__bar-side,
    .c-hero--h-full  .c-hero__bar-side { display: none; }
    .c-hero--h-large .c-hero__bottom-bar,
    .c-hero--h-full  .c-hero__bottom-bar { justify-content: center; }
}

@media (max-width: 900px) {
    .c-hero--h-full,
    .c-hero--h-large { padding-bottom: 80px; }
}
@media (max-width: 600px) {
    .c-hero--h-full,
    .c-hero--h-large { padding-bottom: 96px; }
	.c-hero,
	.home .c-hero {
		padding-top:160px;
	}
}

.c-stats--bg-dark .c-stat__number {
    font-family: var(--font-heading);
    font-size: var(--text-5xl);
    font-weight: 700;
    color: var(--color-cream);
}
.c-stats--bg-dark .c-stat__label {
    color: var(--color-accent-light);
    font-size: var(--text-sm);
    font-weight: 600;
}

/* Testimonials cream background */
.c-testimonials--bg-white { background: var(--color-cream); }

/* Cards section cream background for services on this site */
.c-cards--bg-white { background: var(--color-cream); }

.state-cards {
    display: flex;
    gap: var(--space-md);
    margin-top: var(--space-lg);
}
.state-card {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    border: 1px solid rgba(255,255,255,0.25);
    border-radius: var(--radius);
    padding: var(--space-md) var(--space-lg);
    min-width: 110px;
}
.state-card__abbr {
    font-family: var(--font-heading);
    font-size: var(--text-3xl);
    font-weight: 700;
    color: var(--color-accent-light);
    line-height: 1;
}
.state-card__name {
    font-size: var(--text-sm);
    font-weight: 700;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.state-card__desc {
    font-size: var(--text-xs);
    color: rgba(255,255,255,0.6);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.service-area-states-img.c-content-media {
    background: var(--color-navy);
    color: #fff;
}
.service-area-states-img h2,
.service-area-states-img h3 { color: #fff; }
.service-area-states-img .eyebrow { color: var(--color-accent-light); }
.service-area-states-img .prose { color: rgba(255,255,255,0.85); }
.service-area-states-img .prose p { color: rgba(255,255,255,0.85); }


/* ----------------------- PROOF STRIP ----------------------- */

.c-proof-strip {
    background: var(--color-navy);
    padding: var(--space-2xl) 0;
}
.c-proof-strip__inner {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xl);
    justify-content: center;
    align-items: center;
}
.c-proof-strip__item {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    flex: 1 1 200px;
    min-width: 180px;
    max-width: 260px;
}
.c-proof-strip__icon {
    flex-shrink: 0;
    width: 3rem;
    height: 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.c-proof-strip__icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.c-proof-strip__text {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}
.c-proof-strip__number {
    font-family: var(--font-heading);
    font-size: var(--text-3xl);
    font-weight: 700;
    line-height: 1;
    color: var(--color-cream);
    letter-spacing: 0.01em;
}
.c-proof-strip__label {
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-accent-light);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
@media (max-width: 768px) {
    .c-proof-strip__inner {
        gap: var(--space-lg);
    }
    .c-proof-strip__item {
        flex: 1 1 140px;
    }
    .c-proof-strip__number { font-size: var(--text-2xl); }
}


/* ----------------------- SERVICES GRID ----------------------- */

.c-services-grid {
    background: var(--color-cream);
    padding: var(--space-3xl) 0;
}
.c-services-grid__header {
    text-align: center;
    margin-bottom: var(--space-2xl);
}
.c-services-grid__headline {
    font-family: var(--font-heading);
    font-size: var(--text-4xl);
    font-weight: 700;
    color: var(--color-navy);
    margin: 0 0 var(--space-md);
    line-height: var(--leading-tight);
}
.c-services-grid__subhead {
    font-size: var(--text-lg);
    color: var(--color-text-muted);
    max-width: 640px;
    margin: 0 auto;
}
.c-services-grid__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
}
.c-service-card {
    position: relative;
    display: block;
    min-height: 280px;
    background: var(--color-navy) center/cover no-repeat;
    border-radius: var(--radius);
    overflow: hidden;
    text-decoration: none;
    color: #fff;
    transition: transform var(--transition), box-shadow var(--transition);
}
a.c-service-card:hover,
a.c-service-card:focus {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}
.c-service-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(1,34,65,0.85) 0%, rgba(1,34,65,0.3) 60%, transparent 100%);
    transition: background var(--transition);
}
a.c-service-card:hover .c-service-card__overlay {
    background: linear-gradient(to top, rgba(1,34,65,0.92) 0%, rgba(1,34,65,0.5) 60%, rgba(1,34,65,0.1) 100%);
}
.c-service-card__content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--space-xl) var(--space-lg);
}
.c-service-card__title {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    font-weight: 700;
    line-height: var(--leading-tight);
    margin: 0 0 var(--space-xs);
    color: #fff;
}
.c-service-card__desc {
    font-size: var(--text-sm);
    line-height: var(--leading-normal);
    color: rgba(255,255,255,0.85);
    margin-bottom: var(--space-sm);
}
.c-service-card__desc p { margin: 0; }
.c-service-card__cta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-accent-light);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    opacity: 0;
    transform: translateY(4px);
    transition: opacity var(--transition), transform var(--transition);
}
a.c-service-card:hover .c-service-card__cta,
a.c-service-card:focus .c-service-card__cta {
    opacity: 1;
    transform: translateY(0);
}
@media (max-width: 1024px) {
    .c-services-grid__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .c-services-grid__grid {
        grid-template-columns: 1fr;
        gap: var(--space-md);
    }
    .c-service-card { min-height: 220px; }
    .c-service-card__cta { opacity: 1; transform: none; }
}


/* ----------------------- COVERAGE ----------------------- */

.c-coverage {
    background: var(--color-navy);
    padding: var(--space-3xl) 0;
    color: #fff;
}
.c-coverage__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3xl);
    align-items: center;
}
.c-coverage .eyebrow {
    color: var(--color-accent-light);
}
.c-coverage__headline {
    font-family: var(--font-heading);
    font-size: var(--text-4xl);
    font-weight: 700;
    line-height: var(--leading-tight);
    color: #fff;
    margin: 0 0 var(--space-lg);
}
.c-coverage__subhead {
    font-size: var(--text-lg);
    color: rgba(255,255,255,0.8);
    margin-bottom: var(--space-xl);
    line-height: var(--leading-relaxed);
}
.c-coverage__subhead p { margin: 0; }
.c-coverage__states {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    margin-bottom: var(--space-xl);
}
.c-coverage__state {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
    border-bottom: 1px solid rgba(255,255,255,0.15);
    padding-bottom: var(--space-md);
}
.c-coverage__state:last-child {
    border-bottom: none;
    padding-bottom: 0;
}
.c-coverage__state-abbr {
    font-family: var(--font-heading);
    font-size: var(--text-3xl);
    font-weight: 700;
    color: var(--color-accent-light);
    min-width: 3.5rem;
    line-height: 1;
}
.c-coverage__state-name {
    font-size: var(--text-lg);
    font-weight: 500;
    color: #fff;
}
.c-coverage__map {
    display: flex;
    align-items: center;
    justify-content: center;
}
.c-coverage__map-img {
    max-width: 100%;
    height: auto;
    filter: drop-shadow(0 8px 24px rgba(0,0,0,0.4));
}
@media (max-width: 1024px) {
    .c-coverage__inner {
        grid-template-columns: 1fr;
        gap: var(--space-2xl);
    }
    .c-coverage__map { order: -1; }
    .c-coverage__map-img { max-width: 480px; }
}
@media (max-width: 768px) {
    .c-coverage__map-img { max-width: 100%; }
}


/* ----------------------- GUARANTEE ----------------------- */

.c-guarantee {
    background: var(--color-cream);
    padding: var(--space-3xl) 0;
    text-align: center;
}
.c-guarantee .eyebrow {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    color: var(--color-brand);
}
.c-guarantee .eyebrow::before,
.c-guarantee .eyebrow::after {
    content: '';
    flex: 0 0 60px;
    height: 1px;
    background: var(--color-brand);
}
.c-guarantee__headline {
    font-family: var(--font-heading);
    font-size: var(--text-4xl);
    font-weight: 700;
    color: var(--color-navy);
    margin: 0 0 var(--space-2xl);
    line-height: var(--leading-tight);
}
.c-guarantee__box {
    max-width: 780px;
    margin: 0 auto var(--space-2xl);
    border: 2px solid var(--color-navy);
    border-radius: var(--radius);
    padding: var(--space-2xl);
    background: #fff;
    text-align: left;
}
.c-guarantee__body {
    font-family: var(--font-heading);
    font-size: 44px;
    font-weight: 500;
    line-height: 55px;
    color: var(--color-navy);
    margin-bottom: var(--space-xl);
}
.c-guarantee__body p { margin: 0 0 var(--space-md); }
.c-guarantee__body p:last-child { margin-bottom: 0; }
.c-guarantee__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-xl);
    padding-top: 0;
    border-top: 0;
}
.c-guarantee__sig-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
}
.c-guarantee__sig {
    font-family: var(--font-signature);
    font-size: 38px;
    color: var(--color-navy);
    line-height: 1.2;
}
.c-guarantee__signer-title {
    font-family: var(--font-heading);
    font-size: 11px;
    font-weight: 400;
    letter-spacing: 2.42px;
    color: rgba(1,34,65,0.65);
    text-transform: uppercase;
}
.c-guarantee__seal {
    flex-shrink: 0;
}
.c-guarantee__seal-img {
    width: 100px;
    height: 100px;
    object-fit: contain;
}
.c-guarantee__cta {
    margin-top: var(--space-xl);
}
@media (max-width: 768px) {
    .c-guarantee__box { padding: var(--space-lg); }
    .c-guarantee__footer {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-lg);
    }
    .c-guarantee__seal-img { width: 80px; height: 80px; }
}


/* =================================================================
   HOMEPAGE OVERRIDES ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â ALBERTO'S (Figma match)
   ================================================================= */

/* All major section headings uppercase on homepage */
main h1,
main h2 { text-transform: uppercase; }

/* --- Services grid: overlay card style -------------------------------- */
.c-cards--style-default .c-card {
    position: relative;
    min-height: 300px;
    background: var(--color-navy);
}
.c-cards--style-default .c-card__image {
    position: absolute;
    inset: 0;
}
.c-cards--style-default .c-card__image img {
    aspect-ratio: auto;
    height: 100%;
    transition: transform var(--transition);
}
.c-cards--style-default .c-card__image::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(1,34,65,0.9);
}
.c-cards--style-default .c-card__content {
    position: relative;
    z-index: 1;
    justify-content: flex-end;
    color: #fff;
    background: none;
}
.c-cards--style-default .c-card__title {
    font-family: var(--font-heading);
    font-size: 24px;
    font-weight: 700;
    letter-spacing: -0.12px;
    color: #fff;
    margin-bottom: var(--space-xs);
    text-transform: uppercase;
}
.c-cards--style-default .c-card__desc {
    color: rgba(255,255,255,0.7);
    font-size: 15px;
}
.c-cards--style-default a.c-card:hover .c-card__image img {
    transform: scale(1.05);
}

/* --- CTA: dark navy on homepage -------------------------------------- */
.c-cta--bg-brand {
    background: var(--color-bg-dark);
    border-top: 1px solid rgba(51,109,147,0.3);
}

/* --- Coverage heading: accent colour on <span> ----------------------- */
.service-area-states-img h2 span { color: var(--color-accent-light); }

/* --- Services section heading: 76px ExtraBold ----------------------- */
.c-cards__header h2 {
    font-family: var(--font-heading);
    font-size: clamp(42px, 6vw, 76px);
    font-weight: 800;
    letter-spacing: -0.76px;
    line-height: 1.05;
}

/* --- CTA heading: 128px ExtraBold, cream + accent split ------------- */
.c-cta--bg-brand h2 {
    font-family: var(--font-heading);
    font-size: clamp(56px, 9vw, 128px);
    font-weight: 800;
    letter-spacing: -1.92px;
    line-height: 1;
    color: var(--color-cream);
    margin-bottom: var(--space-xl);
    text-transform: uppercase;
}
.c-cta--bg-brand h2 span {
    color: var(--color-accent-light);
    display: block;
}

/* --- CTA primary button: cream bg + navy text ----------------------- */
.c-cta--bg-brand .btn--white {
    background: var(--color-cream);
    color: var(--color-navy);
    border-color: var(--color-cream);
    font-family: var(--font-heading);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 2.7px;
    text-transform: uppercase;
    min-height: 60px;
    padding-inline: 2rem;
}
.c-cta--bg-brand .btn--white:hover {
    background: #fff;
    border-color: #fff;
}

/* --- CTA secondary button: translucent cream outline ---------------- */
.c-cta--bg-brand .btn--outline-light {
    background: transparent;
    border-color: rgba(244,236,224,0.45);
    color: var(--color-cream);
    min-height: 60px;
    padding-inline: 2rem;
}
.c-cta--bg-brand .btn--outline-light:hover {
    background: rgba(244,236,224,0.1);
}


/* =================================================================
   ALBERTO'S ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â FIGMA PIXEL-PERFECT PASS (24 Apr 2026)
   Values from Figma node 6:2 via desktop MCP.
   Tokens: navy=#012241, navy-deep=#021a31, footer-deep=#021527,
           cream=#f4ece0, accent-light=#9dd3e0, brand=#336d93
   ================================================================= */

/* ---------- Proof strip / Stats (dark) ---------- */
.c-stats--bg-dark {
    background: #021a31;
    border-block: 1px solid rgba(51,109,147,0.25);
    padding: 56px 0;
}
.c-stats--bg-dark .c-stats__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    text-align: left;
}
@media (max-width: 768px) {
    .c-stats--bg-dark .c-stats__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 400px) {
    /* Stack each stat full-width below 400px */
    .c-stats--bg-dark .c-stats__grid { grid-template-columns: 1fr; gap: 32px; }
}
.c-stats--bg-dark .c-stat {
    padding: 8px 32px 8px 40px;
    border-left: 1px solid rgba(51,109,147,0.3);
}
.c-stats--bg-dark .c-stat:first-child { border-left: 0; padding-left: 8px; }
@media (max-width: 768px) {
    .c-stats--bg-dark .c-stat:nth-child(odd) { border-left: 0; padding-left: 8px; }
}
@media (max-width: 400px) {
    /* No vertical dividers when stacked single-column */
    .c-stats--bg-dark .c-stat { border-left: 0; padding-left: 8px; }
}
.c-stats--bg-dark .c-stat__number {
    font-family: var(--font-heading);
    font-size: clamp(48px, 6vw, 72px);
    font-weight: 800;
    line-height: 1;
    color: #fff;
    letter-spacing: -1.44px;
    margin-bottom: 14px;
}
.c-stats--bg-dark .c-stat__label {
    font-family: var(--font-heading);
    font-weight: 500;
    font-size: 13px;
    line-height: 1.4;
    letter-spacing: 2.34px;
    color: rgba(244,236,224,0.75);
    text-transform: uppercase;
}

/* ---------- Eyebrow with leading line (28px bar) ---------- */
.c-cards__header .eyebrow,
.c-content-media__content .eyebrow,
.c-cta__inner .eyebrow,
.c-text-block .eyebrow,
.c-testimonials__header .eyebrow,
.c-guarantee .eyebrow {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 3.64px;
    text-transform: uppercase;
    color: var(--color-brand);
    margin-bottom: 24px;
}
.c-cards__header .eyebrow::before,
.c-content-media__content .eyebrow::before,
.c-text-block .eyebrow::before,
.c-testimonials__header .eyebrow::before {
    content: '';
    display: inline-block;
    width: 28px;
    height: 1px;
    background: currentColor;
    flex-shrink: 0;
}
/* Dark sections: lighter eyebrow color */
.c-content-media--bg-dark .eyebrow,
.service-area-states-img .eyebrow,
.c-cta--bg-brand .eyebrow {
    color: rgba(255,255,255,0.55);
}
.c-cta--bg-brand .eyebrow {
    color: #8d9ca9;
    justify-content: center;
    margin-bottom: 36px;          /* Figma: eyebrow top:140, heading top:192 ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ 36px gap below 16px-tall eyebrow */
}
.c-cta--bg-brand .eyebrow::before,
.c-cta--bg-brand .eyebrow::after,
.c-guarantee .eyebrow::before,
.c-guarantee .eyebrow::after {
    content: '';
    display: inline-block;
    width: 28px;
    height: 1px;
    background: currentColor;
    flex-shrink: 0;
}
.c-guarantee {
    text-align: center;
}
.c-guarantee .eyebrow {
    color: var(--color-brand);
    justify-content: center;
    margin-bottom: 36px;
}

/* ---------- Services / Cards section ---------- */
.c-cards--bg-white,
.c-cards--bg-light {
    background: var(--color-cream);
    padding: 120px 0 80px;
}
.c-cards__header {
    display: grid;
    grid-template-columns: minmax(380px, 408px) 1fr;
    grid-template-rows: auto auto;
    column-gap: 80px;
    row-gap: 24px;
    align-items: start;
    text-align: left;
    max-width: none;
    margin-bottom: 80px;
}
@media (max-width: 900px) {
    .c-cards__header { grid-template-columns: 1fr; grid-template-rows: auto; column-gap: 0; }
}
.c-cards__header > .eyebrow {
    grid-column: 1;
    grid-row: 1;
    margin-bottom: 0;
}
.c-cards__header h2 {
    grid-column: 1;
    grid-row: 2;
    font-family: var(--font-heading);
    font-size: clamp(48px, 6vw, 76px);
    font-weight: 800;
    line-height: 0.95;
    letter-spacing: -0.76px;
    color: var(--color-navy);
    text-transform: uppercase;
    margin: 0;
}
.c-cards__header > .subhead,
.c-cards__header > .c-cards__intro,
.c-cards__header > p:not(.eyebrow) {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: end;
    font-family: var(--font-sans);
    font-size: 18px;
    line-height: 1.65;
    color: rgba(1,34,65,0.72);
    margin: 0;
    padding-bottom: 4px;
    max-width: 520px;
}
.c-cards__header > .subhead p,
.c-cards__header > .subhead > * { margin: 0; color: inherit; font-size: inherit; line-height: inherit; }
@media (max-width: 900px) {
    .c-cards__header > .eyebrow,
    .c-cards__header h2,
    .c-cards__header > .subhead,
    .c-cards__header > .c-cards__intro,
    .c-cards__header > p:not(.eyebrow) {
        grid-column: 1;
        grid-row: auto;
    }
}

/* ---------- Service cards (overlay style) ---------- */
.c-cards--style-overlay .c-cards__grid,
.c-cards--style-default .c-cards__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    border-left: 1px solid rgba(1,34,65,0.18);
    border-top: 1px solid rgba(1,34,65,0.18);
}
@media (max-width: 900px) {
    .c-cards--style-overlay .c-cards__grid,
    .c-cards--style-default .c-cards__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 600px) {
    .c-cards--style-overlay .c-cards__grid,
    .c-cards--style-default .c-cards__grid {
        grid-template-columns: 1fr;
    }
}
.c-cards--style-overlay .c-card,
.c-cards--style-default .c-card {
    min-height: 224px;
    border-right: 1px solid rgba(1,34,65,0.18);
    border-bottom: 1px solid rgba(1,34,65,0.18);
    border-radius: 0;
    overflow: hidden;
    box-shadow: none;
    background: var(--color-cream);
}
.c-cards--style-overlay .c-card__image::after,
.c-cards--style-default .c-card__image::after {
    background: rgba(1,34,65,0.9);
}
.c-cards--style-overlay .c-card,
.c-cards--style-default .c-card {
    position: relative;
}
.c-cards--style-overlay .c-card__content,
.c-cards--style-default .c-card__content {
    justify-content: flex-end;
    padding: 28px;
    color: #fff;
}
.c-cards--style-overlay .c-card__title,
.c-cards--style-default .c-card__title {
    font-family: var(--font-heading);
    font-size: 24px;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.12px;
    color: #fff;
    margin-bottom: 6px;
    text-transform: uppercase;
    flex: 0 0 auto;            /* don't stretch ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â keep natural size */
}
.c-cards--style-overlay .c-card__desc,
.c-cards--style-default .c-card__desc {
    font-family: var(--font-sans);
    font-size: 15px;
    line-height: 1.55;
    color: rgba(255,255,255,0.7);
    margin: 0;
    flex: 0 0 auto;            /* override base flex:1 so title+desc cluster at the bottom */
}
/* Top-right arrow icon (Figma) */
.c-cards--style-overlay .c-card::after,
.c-cards--style-default .c-card::after {
    content: '';
    position: absolute;
    top: 22px;
    right: 22px;
    width: 24px;
    height: 12px;
    background: url('/wp-content/uploads/arrow-right-long.svg') center/contain no-repeat;
    pointer-events: none;
    z-index: 2;
    transition: transform 0.25s ease;
}
.c-cards--style-overlay a.c-card:hover::after,
.c-cards--style-default a.c-card:hover::after {
    transform: translateX(4px);
}

/* ---------- Coverage (states + map) section ---------- */
.service-area-states-img.c-content-media {
    background-color: var(--color-navy);
    padding: 120px 0;
    position: relative;
}
.service-area-states-img.c-content-media .c-content-media__inner {
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

.service-area-states-img h2 {
    font-family: var(--font-heading);
    font-size: clamp(48px, 6vw, 76px);
    font-weight: 800;
    line-height: 0.95;
    letter-spacing: -0.76px;
    color: var(--color-cream);
    text-transform: uppercase;
    margin: 0 0 24px;
}
.service-area-states-img h2 span,
.service-area-states-img h2 strong {
    color: var(--color-accent-light);
    font-weight: inherit;
    display: block;
}
.service-area-states-img .prose,
.service-area-states-img .prose p {
    font-family: var(--font-sans);
    font-size: 17px;
    line-height: 1.65;
    color: rgba(244,236,224,0.72);
    max-width: 480px;
}

/* ---------- State cards (TX OK LA) ---------- */
.state-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-top: 36px;
    max-width: 560px;
}
@media (max-width: 768px) {
    /* On tablet, let the cards take the full row width and shrink padding */
    .state-cards { max-width: 100%; }
}
@media (max-width: 480px) {
    /* Stack to a single column on phones */
    .state-cards { grid-template-columns: 1fr; gap: 8px; }
}
.state-card {
    border: 1px solid rgba(51,109,147,0.4);
    border-radius: 0;
    padding: 22px;
    background: transparent;
    min-width: 0;
}
@media (max-width: 480px) {
    .state-card { padding: 16px 22px; }
    /* Inline the abbr + name on stacked cards so they read as one row */
    .state-card { display: flex; align-items: baseline; gap: 16px; }
    .state-card__abbr { margin-bottom: 0; }
    .state-card__name,
    .state-card__desc { margin-bottom: 0; }
}
.state-card__abbr {
    font-family: var(--font-heading);
    font-size: 44px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0.88px;
    color: var(--color-cream);
    text-transform: uppercase;
    margin-bottom: 12px;
}
.state-card__name {
    font-family: var(--font-heading);
    font-weight: 400;
    font-size: 12px;
    letter-spacing: 2.4px;
    color: var(--color-accent-light);
    text-transform: uppercase;
    margin-bottom: 4px;
}
.state-card__desc {
    font-family: var(--font-sans);
    font-weight: 400;
    font-size: 13px;
    color: #b0b3b3;
    text-transform: none;
    letter-spacing: normal;
}

/* ---------- Guarantee section ---------- */
.c-guarantee {
    background: var(--color-cream);
    padding: 120px 0;
}
.c-guarantee__box {
    max-width: 1004px;             /* Figma 6:292 */
    width: 100%;
    margin: 0 auto;
    border: 2px solid var(--color-navy);
    background: transparent;
    padding: 48px 56px;            /* tightened from 64 */
    border-radius: 0;
    box-shadow: none;
    text-align: left;
    position: relative;
}
.c-guarantee__body {
    font-family: var(--font-heading);
    font-weight: 500;
    font-size: clamp(22px, 4.4vw, 44px);   /* scales: 22px on phones ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ 44px on desktop */
    line-height: 1.3;
    letter-spacing: -0.22px;
    color: var(--color-navy);
}
@media (max-width: 600px) {
    /* Tighten box padding so the smaller text isn't lost in whitespace on phones */
    .c-guarantee__box { padding: 32px 24px; }
}
.c-guarantee__body strong,
.c-guarantee__body em,
.c-guarantee__body .highlight {
    color: var(--color-brand);
    font-weight: 700;
    font-style: normal;
}
.c-guarantee__footer {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 32px;
    margin-top: 32px;              /* tightened from 64 */
    padding-top: 0;
    border-top: 0;
}
.c-guarantee__sig {
    font-family: var(--font-signature);
    font-size: 38px;
    line-height: 1;
    color: var(--color-navy);
    margin-bottom: 4px;
}
.c-guarantee__signer-title {
    border-top: 0;                /* divider above signer title removed */
    padding-top: 0;
    font-family: var(--font-heading);
    font-weight: 400;
    font-size: 11px;
    letter-spacing: 2.42px;
    color: rgba(1,34,65,0.65);
    text-transform: uppercase;
}
.c-guarantee__seal-img {
    width: 144px;
    height: 144px;
    transform: rotate(7.96deg);
}

@media (max-width:768px) {
	.c-guarantee__footer{
		align-items:center;
	}

	.c-guarantee__footer *{
		text-align:center!important;
	}
}

/* ---------- Evidence (content-media left, dark) ---------- */
.c-content-media h2{
    font-family: var(--font-heading);
    font-size: clamp(40px, 4.6vw, 64px);
    font-weight: 800;
    line-height: 0.95;
    letter-spacing: -0.64px;
    text-transform: uppercase;
}
.c-content-media--bg-dark.c-content-media--left {
    background: var(--color-navy);
    color: #fff;
    padding: 120px 0;
}
.c-content-media--bg-dark.c-content-media--left .c-content-media__inner {
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: stretch;
}
.c-content-media--bg-dark.c-content-media--left .c-content-media__media {
    border: 1px solid rgba(51,109,147,0.22);
    background: #021a31;
    height: 100%;
    min-height: 540px;
}
.c-content-media--bg-dark.c-content-media--left .c-content-media__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.c-content-media--bg-dark h2 {
    color: var(--color-cream);
}
.c-content-media--bg-dark h2 span,
.c-content-media--bg-dark h2 strong {
    color: var(--color-accent-light);
    font-weight: inherit;
    display: block;
}
.c-content-media--bg-dark .prose,
.c-content-media--bg-dark .prose p {
    font-family: var(--font-sans);
    font-size: 17px;
    line-height: 1.65;
    color: rgba(244,236,224,0.72);
}
.c-content-media--bg-dark .prose ul {
    list-style: none;
    padding: 0;
    margin: 24px 0 36px;
}
.c-content-media--bg-dark .prose ul li {
    position: relative;
    padding: 16px 0 16px 34px;
    border-bottom: 1px solid rgba(51,109,147,0.2);
    font-size: 15px;
    color: rgba(244,236,224,0.85);
    line-height: 1.4;
}
.c-content-media--bg-dark .prose ul li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 19px;
    width: 18px;
    height: 18px;
    background: url('/wp-content/uploads/list-check.svg') no-repeat center / contain;
}

/* ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â°ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¤768: stack ALL content-media variants vertically with media first.
   Placed after section-specific overrides so it wins the cascade. */
@media (max-width: 768px) {
    .c-content-media__inner,
    .service-area-states-img.c-content-media .c-content-media__inner,
    .c-content-media--bg-dark.c-content-media--left .c-content-media__inner {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    .c-content-media__media   { order: -1; }
    .c-content-media__content { order:  0; }
    /* Evidence dark variant: drop the rigid min-height so it doesn't waste space */
    .c-content-media--bg-dark.c-content-media--left .c-content-media__media {
        min-height: 0;
        height: auto;
    }
    .c-content-media--bg-dark.c-content-media--left .c-content-media__media img {
        height: auto;
        max-height: 360px;
    }
    /* Reduce section padding on mobile */
    .service-area-states-img.c-content-media,
    .c-content-media--bg-dark.c-content-media--left { padding: 64px 0; }
}

/* ---------- Testimonials grid (cream background, white cards) ---------- */
.c-testimonials--bg-light,
.c-testimonials--bg-white {
    background: var(--color-cream);
    padding: 120px 0;
}
.c-testimonials__header {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 40px;
    align-items: end;
    text-align: left;
    max-width: none;
    margin-bottom: 72px;
}
@media (max-width: 700px) {
    .c-testimonials__header { grid-template-columns: 1fr; }
}
.c-testimonials__header-text {
    display: flex;
    flex-direction: column;
    gap: 24px;
    max-width: 720px;
}
.c-testimonials__header h2 {
    font-family: var(--font-heading);
    font-size: clamp(40px, 4.6vw, 64px);
    font-weight: 800;
    line-height: 0.95;
    letter-spacing: -0.64px;
    color: var(--color-navy);
    text-transform: uppercase;
    margin: 0;
}
.c-testimonials__header .eyebrow { margin: 0; }

/* See More Testimonials button ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â matches site-wide button height (60px) */
.c-testimonials__see-more {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    /* min-height inherits 60px from base .btn ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â keep consistent with hero buttons */
    padding: 0 32px;
    white-space: nowrap;
    background: #fff;
    border: 1px solid #bdc0be;
    border-radius: 0;
    color: var(--color-navy);
    text-decoration: none;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
    align-self: end;
}
.c-testimonials__see-more::after {
    /* override default .btn::after arrow color via filter for hover state */
    background-image: url('/wp-content/uploads/arrow-right-long-dark.svg');
}
.c-testimonials__see-more:hover {
    background: var(--color-navy);
    border-color: var(--color-navy);
    color: var(--color-cream);
}
.c-testimonials__see-more:hover::after {
    background-image: url('/wp-content/uploads/arrow-right-long-tan.svg');
}

.c-testimonials--grid .c-testimonials__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
@media (max-width: 900px) {
    .c-testimonials--grid .c-testimonials__grid { grid-template-columns: 1fr; }
    /* When stacked, ensure each card fills the row */
    .c-testimonials--grid .c-testimonial {
        width: 100%;
        max-width: none;
    }
}
.c-testimonials--grid .c-testimonial {
    background: #fff;
    border: 1px solid rgba(1,34,65,0.2);
    border-radius: 0;
    padding: 32px;
    box-shadow: none;
    position: relative;
    /* Flex column so the author footer can stick to the bottom of every card */
    display: flex;
    flex-direction: column;
}
.c-testimonials--grid .c-testimonial::before {
    content: '';
    display: block;
    width: 38px;
    height: 29px;
    background: url('/wp-content/uploads/icon-quote.svg') no-repeat center / contain;
    margin-bottom: 36px;
}
.c-testimonials--grid .c-testimonial__icon { display: none; }
.c-testimonials--grid .c-testimonial__quote {
    font-family: var(--font-sans);
    font-style: italic;
    font-size: 15px;
    line-height: 1.6;
    color: rgba(1,34,65,0.7);
    margin: 0 0 32px;
}
.c-testimonials--grid .c-testimonial__author {
    border-top: 1px solid rgba(1,34,65,0.2);
    padding-top: 17px;
    margin-top: auto;
    display: block;
    text-align: left;
}
/* Author <div> wrapper: keep its content on one line */
.c-testimonials--grid .c-testimonial__author > div {
    display: inline;
}
/* cite (name) + span (title) share identical typography on a single line */
.c-testimonials--grid .c-testimonial__author cite,
.c-testimonials--grid .c-testimonial__author span,
.c-testimonials--grid .c-testimonial__name,
.c-testimonials--grid .c-testimonial__role {
    display: inline;
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: 12px;
    line-height: 1;
    letter-spacing: 2.64px;
    color: var(--color-brand);
    text-transform: uppercase;
    font-style: normal;
}
/* Inject Figma's middle-dot separator between name and title */
.c-testimonials--grid .c-testimonial__author cite + span::before,
.c-testimonials--grid .c-testimonial__name + .c-testimonial__role::before {
    content: '\00B7';
	margin-right:.325rem;
}

/* ---------- Final CTA ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â generous vertical padding ---------- */
.c-cta--bg-brand,
.c-cta--center.c-cta--bg-brand {
    padding: 140px 0;
}
.c-cta--bg-brand .c-cta__inner {
    text-align: center;
    align-items: center;
    max-width: 1304px;
}
.c-cta--bg-brand .c-cta__content {
    max-width: none;
    width: 100%;
}
.c-cta--bg-brand h2 {
    font-size: clamp(56px, 9vw, 116px);
    line-height: 0.92;
    margin: 0 auto 32px;
    max-width: 1304px;
}
.c-cta--bg-brand .c-cta__content > div,
.c-cta--bg-brand .c-cta__content p:not(.eyebrow) {
    max-width: 560px;
    margin: 0 auto;
}
.c-cta--bg-brand .c-cta__content p:not(.eyebrow) {
    font-family: var(--font-sans);
    font-size: 18px;
    line-height: 1.6;
    color: rgba(244,236,224,0.72);
}
.c-cta--bg-brand .c-cta__buttons {
    margin-top: 16px;
    gap: 16px;
    justify-content: center;
}

/* ---------- Footer (Figma node 6:434) ---------- */
.site-footer {
    background: #021527;
    border-top: 1px solid rgba(51,109,147,0.2);
    padding: 56px 0 0;
    color: rgba(244,236,224,0.55);
}

/* 4-column row: brand+tagline | services | company | contact
   Brand column is widest; logo + tagline stack vertically; other cols fill rows. */
.site-footer__inner {
    display: grid;
    grid-template-columns: minmax(280px, 1.3fr) repeat(3, 1fr);
    grid-template-rows: auto 1fr;
    column-gap: 48px;
    row-gap: 0;
    padding-bottom: 32px;
}
.site-footer__columns {
    display: contents;     /* flatten so cols flow into the inner grid */
}
.site-footer__col {
    padding: 0;
    margin: 0;
    min-width: 0;
    /* override inline flex-basis/max-width from d20_render_columns helper */
    max-width: none !important;
    width: auto !important;
    flex: 1 1 auto !important;
    grid-row: 1 / span 2;          /* default: span both rows so tops align */
}
.site-footer__brand { grid-column: 1; grid-row: 1; padding: 0; }
/* First col content (tagline / text) sits beneath the brand logo */
.site-footer__columns > .site-footer__col:first-child {
    grid-column: 1;
    grid-row: 2;
}
.site-footer__columns > .site-footer__col:nth-child(2) { grid-column: 2; }
.site-footer__columns > .site-footer__col:nth-child(3) { grid-column: 3; }
.site-footer__columns > .site-footer__col:nth-child(4) { grid-column: 4; }

/* When a single ACF menu column carries both 'Services' and 'Company' nav items,
   widen the menu col to span 2 grid cells and split its top-level items into
   two side-by-side sub-columns. The contact-info col then takes the 4th cell. */
.site-footer__columns > .site-footer__col:has(> .site-footer__menu) {
    grid-column: 2 / span 2;
}
.site-footer__columns > .site-footer__col:has(> .site-footer__contact-info) {
    grid-column: 4;
}

/* Footer menu: 2-column layout, level-1 link styled as column heading */
.site-footer__menu {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 48px;
    row-gap: 0;
}
.site-footer__menu > li.menu-item {
    padding: 0;
    margin: 0;
    list-style: none;
}
.site-footer__menu > li.menu-item > a {
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: 12px;
    line-height: 1;
    letter-spacing: 2.88px;
    color: var(--color-brand);
    text-transform: uppercase;
    text-decoration: none;
    margin: 0 0 18px;
    display: block;
    pointer-events: none;          /* heading isn't a navigable link */
}
.site-footer__menu > li.menu-item > a:hover { color: var(--color-brand); }
.site-footer__menu .sub-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}
.site-footer__menu .sub-menu li {
    padding: 6px 0;
    margin: 0;
    line-height: 1.25;
}
.site-footer__menu .sub-menu a {
    font-family: var(--font-sans);
    font-size: 13px;
    color: rgba(244,236,224,0.55);
    text-decoration: none;
    transition: color 0.2s;
}
.site-footer__menu .sub-menu a:hover { color: var(--color-cream); }

@media (max-width: 700px) {
    .site-footer__menu { grid-template-columns: 1fr; gap: 24px; }
}
.site-footer__brand .site-footer__logo img {
    height: auto;
    width: 134px;        /* match header logo */
    margin-bottom: 24px;
}
.site-footer__brand .site-footer__text,
.site-footer__brand p {
    font-family: var(--font-sans);
    font-size: 13px;
    line-height: 1.6;
    color: rgba(244,236,224,0.55);
    max-width: 280px;
    margin: 0;
}

/* Column heading: 12px Barlow Condensed SemiBold #336d93 2.88px tracking */
.site-footer h2,
.site-footer h3,
.site-footer h4,
.site-footer .site-footer__col-title,
.site-footer .footer__heading,
.site-footer .menu-title {
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 2.88px;
    color: var(--color-brand);
    text-transform: uppercase;
    margin: 0 0 18px;
}

/* List items: Inter Regular 13px rgba(244,236,224,0.55), 28px-tall row with py:6 */
.site-footer ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.site-footer ul li {
    padding: 6px 0;
    margin: 0;
    line-height: 1.25;
}
.site-footer p,
.site-footer ul li a,
.site-footer a {
    font-family: var(--font-sans);
    font-size: 13px;
    line-height: 1.6;
    color: rgba(244,236,224,0.55);
    text-decoration: none;
    transition: color 0.2s;
}
.site-footer ul li a:hover,
.site-footer a:hover { color: var(--color-cream); }

/* Contact column: heading + paragraphs with optional icons */
.site-footer__contact-info::before {
    content: 'Contact';
    display: block;
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: 12px;
    line-height: 1;
    letter-spacing: 2.88px;
    color: var(--color-brand);
    text-transform: uppercase;
    margin: 0 0 18px;
}
.site-footer__contact-info p {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
    margin: 0;
    color: rgba(244,236,224,0.55);
}
.site-footer__contact-info svg,
.site-footer__contact-info img,
.site-footer__icon {
    width: 14px;
    height: 14px;
    color: rgba(244,236,224,0.55);
    flex-shrink: 0;
}

/* Bottom bar: full-width row with hairline separator above */
.site-footer__bottom,
.site-footer .site-footer__bottom {
    border-top: 1px solid rgba(51,109,147,0.2);
    margin-top: 24px;
    padding: 21px 0 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
    background: transparent;
    color: rgba(244,236,224,0.4);
}
.site-footer .site-footer__copyright,
.site-footer .site-footer__credits,
.site-footer .site-footer__bottom *,
.site-footer .site-footer__bottom-menu a,
.site-footer .site-footer__bottom p,
.site-footer .site-footer__bottom a {
    font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 11px;
    line-height: 1.4;
    letter-spacing: 1.65px;
    color: rgba(244,236,224,0.4);
    text-transform: uppercase;
}
.site-footer__copyright { margin: 0; }
.site-footer__bottom-left {
    display: flex;
    align-items: center;
    gap: 32px;
}
.site-footer__bottom-menu {
    display: flex;
    gap: 32px;
    list-style: none;
    margin: 0;
    padding: 0;
}
.site-footer__bottom-menu a:hover,
.site-footer__credits a:hover { color: var(--color-cream); }
.site-footer__credits a { color: inherit; }

@media (max-width: 900px) {
    .site-footer__inner { grid-template-columns: 1fr; column-gap: 24px; }
    .site-footer__brand { grid-column: 1; }
}

/* ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â°ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¤768: hide the menu column entirely (Services + Company), stack remaining columns */
@media (max-width: 768px) {
    .site-footer__inner {
        display: flex;
        flex-direction: column;
        gap: 32px;
    }
    /* The Services/Company menu column is the one whose direct child is the nav menu */
    .site-footer__columns > .site-footer__col:has(> .site-footer__menu) {
        display: none;
    }
    /* Reset the column-position grid placement we added earlier so the cols render
       as natural flex children of the inner */
    .site-footer__brand,
    .site-footer__columns > .site-footer__col {
        grid-column: auto;
        grid-row: auto;
        width: 100%;
        max-width: none;
    }
    .site-footer__columns {
        display: flex;
        flex-direction: column;
        gap: 32px;
        width: 100%;
    }
}

@media (max-width: 600px) {
    .site-footer__bottom { 
		flex-direction: column; 
		align-items: flex-start!important; 
		padding-left:var(--gutter)!important; 
		padding-right:var(--gutter)!important; 
	}

	.site-footer__bottom,
	.site-footer__bottom-left{
		gap: 8px!important; 
	}
}


/* =================================================================
   PRINT STYLES
   ================================================================= */

@media print {
    /* Page setup */
    @page {
        margin: 0.75in;
        size: letter;
    }

    /* Reset colors for print */
    * {
        background: transparent !important;
        color: #000 !important;
        box-shadow: none !important;
        text-shadow: none !important;
    }

    /* Typography adjustments */
    body {
        font-size: 12pt;
        line-height: 1.5;
    }

    h1 { font-size: 24pt; }
    h2 { font-size: 20pt; }
    h3 { font-size: 16pt; }
    h4, h5, h6 { font-size: 14pt; }

    /* Hide non-printable elements */
    .site-header,
    .site-footer,
    .site-nav,
    .mobile-nav-toggle,
    .skip-link,
    .c-sticky-cta,
    .btn,
    .btn--primary,
    .btn--secondary,
    .c-hero__buttons,
    .c-cta__buttons,
    .c-content-media__buttons,
    .c-cards .c-card__link,
    .search-form,
    .post-nav,
    .pagination,
    .gform_wrapper,
    .c-form-section,
    .global-cta,
    video,
    iframe,
    .c-gallery[data-layout="carousel"],
    .c-testimonials__nav,
    .c-testimonials__dots,
    noscript {
        display: none !important;
    }

    /* Show main content area */
    .site-main,
    main {
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    /* Container adjustments */
    .container {
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* Component spacing for print */
    .component {
        padding: 0.5in 0 !important;
        margin: 0 !important;
        page-break-inside: avoid;
    }

    /* Hero - simplified */
    .c-hero {
        min-height: auto !important;
        height: auto !important;
        padding: 0.25in 0 !important;
        background: none !important;
    }
    .c-hero::before { display: none !important; }
    .c-hero__content {
        position: static !important;
        transform: none !important;
    }
    .c-hero__eyebrow { color: #666 !important; }
    .c-hero__headline { font-size: 28pt !important; }

    /* Content + Media - stack vertically */
    .c-content-media__inner {
        display: block !important;
    }
    .c-content-media__media {
        max-width: 100% !important;
        margin-bottom: 0.25in !important;
    }
    .c-content-media__media img {
        max-width: 4in !important;
        height: auto !important;
    }

    /* Cards - grid for print */
    .c-cards__grid {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 0.25in !important;
    }
    .c-card {
        border: 1px solid #ccc !important;
        padding: 0.15in !important;
        page-break-inside: avoid;
    }
    .c-card__image {
        max-height: 1.5in !important;
        overflow: hidden;
    }

    /* Testimonials - show all */
    .c-testimonials__slider {
        display: block !important;
        overflow: visible !important;
    }
    .c-testimonials__slider .c-testimonial {
        display: block !important;
        width: 100% !important;
        margin-bottom: 0.25in !important;
        border: 1px solid #ccc !important;
        padding: 0.15in !important;
        page-break-inside: avoid;
    }
    .c-testimonials__slider .c-testimonial[hidden] {
        display: block !important;
    }

    /* Accordion - expand all for print */
    .c-accordion__content {
        display: block !important;
        max-height: none !important;
        overflow: visible !important;
        padding: 0.1in 0 !important;
    }
    .c-accordion__item {
        border: 1px solid #ccc !important;
        margin-bottom: 0.1in !important;
        padding: 0.1in !important;
        page-break-inside: avoid;
    }
    .c-accordion__icon { display: none !important; }

    /* Stats */
    .c-stats__grid {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 0.25in !important;
    }
    .c-stat {
        flex: 1 1 30% !important;
        text-align: center;
    }

    /* Logo grid */
    .c-logos__grid {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 0.15in !important;
    }
    .c-logos__item {
        width: 1in !important;
        filter: none !important;
    }
    .c-logos__item img {
        max-width: 100% !important;
        max-height: 0.75in !important;
    }

    /* Gallery - grid only */
    .c-gallery__grid {
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 0.1in !important;
    }
    .c-gallery__item img {
        max-height: 1.5in !important;
    }

    /* Icon cards */
    .c-icon-cards__grid {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 0.2in !important;
    }
    .c-icon-card {
        border: 1px solid #ccc !important;
        padding: 0.1in !important;
        page-break-inside: avoid;
    }

    /* Contact info */
    .c-contact-info__items {
        display: block !important;
    }
    .c-contact-info__item {
        margin-bottom: 0.1in !important;
    }

    /* Map - show placeholder text */
    .c-map__embed {
        border: 1px solid #ccc !important;
        padding: 0.25in !important;
        text-align: center;
    }
    .c-map__embed::after {
        content: "[Map - See website for interactive version]";
        display: block;
        font-style: italic;
        color: #666 !important;
    }

    /* Images */
    img {
        max-width: 100% !important;
        height: auto !important;
        page-break-inside: avoid;
    }

    /* Links - show URLs */
    a[href^="http"]:after,
    a[href^="https"]:after {
        content: " (" attr(href) ")";
        font-size: 10pt;
        color: #666 !important;
        word-break: break-all;
    }

    /* Don't show URL for buttons or images */
    a.btn:after,
    a.c-card:after,
    a > img:after,
    .c-logos__item a:after {
        content: none !important;
    }

    /* Page break hints */
    h1, h2, h3, h4, h5, h6 {
        page-break-after: avoid;
        page-break-inside: avoid;
    }

    p, blockquote, ul, ol, dl, table, figure {
        page-break-inside: avoid;
    }

    /* Orphan/widow control */
    p {
        orphans: 3;
        widows: 3;
    }

    /* Archive/blog posts */
    .archive-page__grid {
        display: block !important;
    }
    .archive-card {
        display: flex !important;
        gap: 0.2in !important;
        border-bottom: 1px solid #ccc !important;
        padding: 0.15in 0 !important;
        page-break-inside: avoid;
    }
    .archive-card__image {
        width: 1.5in !important;
        flex-shrink: 0;
    }

    /* Single post */
    .single-post__featured {
        max-height: 3in !important;
        overflow: hidden;
    }
    .author-box {
        border: 1px solid #ccc !important;
        padding: 0.15in !important;
        margin: 0.25in 0 !important;
    }

    /* Prose content */
    .prose {
        max-width: 100% !important;
    }
    .prose a:after {
        content: none !important; /* Too noisy in body text */
    }

    /* CTA section - text only */
    .c-cta {
        border: 2px solid #000 !important;
        padding: 0.25in !important;
        text-align: center;
    }

    /* Background sections - add border for visual separation */
    .bg--dark,
    .bg--brand,
    .bg--light {
        border: 1px solid #ccc !important;
        padding: 0.2in !important;
        margin: 0.1in 0 !important;
    }
}

.gform_wrapper .grecaptcha-badge {
    position: relative!important;
    left: 0;
    right: auto!important;
    margin-top: 10px;
}