/* ==========================================================================
   Miami Metal Roof — miami-roof v1.0.0
   Deep navy + royal blue + GOLD accent + coral (emergency only) · Montserrat
   (display 700/800) + Open Sans (body 400/600). Layout: a NAVY top
   utility bar over a WHITE logo row (sticky, scrolled-shadow) · a full-bleed hero
   photo with a navy scrim and a FLOATING WHITE quick-quote card · alternating
   full-width NAVY / white / mist bands with rounded soft-shadow cards, circular
   badge icons, and a navy footer with gold hairline rules. Site #9 — built to a
   client-directed navy/gold contractor layout; original code/copy/imagery,
   no fabricated or reproduced trust signals.
   ========================================================================== */

:root {
	/* Palette (locked) */
	--mia-navy:        #14274D;  /* deep navy — bands, footer, utility bar */
	--mia-blue:        #1E498C;  /* primary royal blue — headings/links */
	--mia-blue-bright: #2E66C4;  /* interactive royal blue */
	--mia-gold:        #E8A62C;  /* accent — CTAs, rules, badges */
	--mia-gold-deep:   #C2851C;  /* accent-deep (hover, eyebrow on light) */
	--mia-gold-soft:   rgba(232, 166, 44, 0.16);
	--mia-coral:       #E5402E;  /* emergency / urgency accent ONLY */
	--mia-white:       #FFFFFF;
	--mia-mist:        #EEF3FA;  /* light blue-gray surface */
	--mia-mist-2:      #E2EAF5;  /* deeper mist for borders/fills */
	--mia-ink:         #10213F;  /* near-navy ink — headings on light (AA) */
	--mia-body:        #33415C;  /* body copy (AA on white/mist) */
	--mia-line:        rgba(16, 33, 63, 0.14);
	--mia-navy-soft:   rgba(30, 73, 140, 0.08);

	/* Type */
	--mia-font-display: 'Montserrat', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
	--mia-font-body:    'Open Sans', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;

	--mia-radius:      8px;
	--mia-radius-md:   14px;
	--mia-radius-lg:   22px;

	--mia-shadow-sm:   0 2px 12px rgba(16, 33, 63, 0.08);
	--mia-shadow:      0 16px 38px rgba(16, 33, 63, 0.16);
	--mia-shadow-lg:   0 28px 64px rgba(16, 33, 63, 0.28);
	--mia-container:   1180px;
	--mia-bar-h:       74px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: clip; }   /* zero horizontal overflow */
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { font-family: var(--mia-font-body); color: var(--mia-body); background: var(--mia-white); line-height: 1.62; font-size: 17px; -webkit-font-smoothing: antialiased; }
body.mia-no-scroll { overflow: hidden; }
img, picture, video, svg { max-width: 100%; height: auto; display: block; }
a { color: var(--mia-blue); text-decoration: underline; text-underline-offset: 3px; transition: color .14s ease; }
a:hover { color: var(--mia-navy); }
button { font: inherit; cursor: pointer; }
button, input, textarea, select { font-family: inherit; }
:focus-visible { outline: 3px solid var(--mia-gold); outline-offset: 2px; }

.mia-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; }
.mia-skip { position: absolute; left: -9999px; top: 0; background: var(--mia-navy); color: #fff; padding: 12px 18px; z-index: 300; border-radius: 0 0 var(--mia-radius) 0; text-decoration: none; }
.mia-skip:focus { left: 0; top: 0; }
.mia-container { width: 100%; max-width: var(--mia-container); margin-inline: auto; padding-inline: clamp(1rem, 3vw, 1.75rem); }

/* ============ TYPOGRAPHY — Montserrat display, bold ============ */
.mia-h1, h1 { font-family: var(--mia-font-display); font-weight: 800; font-size: clamp(2.3rem, 5vw, 3.4rem); line-height: 1.08; letter-spacing: -0.018em; margin: 0 0 0.5em; color: var(--mia-ink); }
.mia-h2, h2 { font-family: var(--mia-font-display); font-weight: 800; font-size: clamp(1.8rem, 3.6vw, 2.5rem); line-height: 1.14; letter-spacing: -0.012em; margin: 0 0 0.5em; color: var(--mia-blue); }
.mia-h3, h3 { font-family: var(--mia-font-display); font-weight: 700; font-size: clamp(1.2rem, 2vw, 1.5rem); line-height: 1.24; margin: 0 0 0.4em; color: var(--mia-ink); }
p { margin: 0 0 1em; }
.mia-eyebrow { font-family: var(--mia-font-display); font-size: 0.78rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mia-gold-deep); margin: 0 0 0.85rem; }
.mia-eyebrow--on-navy { color: var(--mia-gold); }

/* ============ BUTTONS ============ */
.mia-btn { display: inline-flex; align-items: center; justify-content: center; gap: .55rem; padding: 0.92rem 1.7rem; border-radius: 999px; font-family: var(--mia-font-display); font-weight: 700; text-decoration: none; transition: transform .12s ease, box-shadow .14s ease, background .14s ease, color .14s ease, border-color .14s ease; white-space: nowrap; font-size: 0.98rem; letter-spacing: 0.01em; border: 2px solid transparent; line-height: 1.1; }
.mia-btn svg { width: 18px; height: 18px; }
.mia-btn:hover { transform: translateY(-2px); }
/* gold = gold fill w/ NAVY text (AA: #E8A62C bg + #14274D text ≈ 7.6:1) */
.mia-btn--gold { background: var(--mia-gold); color: var(--mia-navy); border-color: var(--mia-gold); box-shadow: 0 8px 20px rgba(194, 133, 28, 0.32); }
.mia-btn--gold:hover { background: var(--mia-gold-deep); color: #fff; border-color: var(--mia-gold-deep); box-shadow: var(--mia-shadow); }
/* blue = royal-blue fill w/ white text */
.mia-btn--blue { background: var(--mia-blue); color: #fff; border-color: var(--mia-blue); }
.mia-btn--blue:hover { background: var(--mia-navy); color: #fff; border-color: var(--mia-navy); box-shadow: var(--mia-shadow); }
/* ghost-light = outlined for use on photos/navy */
.mia-btn--ghost-light { background: rgba(20, 39, 77, 0.30); color: #fff; border-color: rgba(255,255,255,0.85); -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px); }
.mia-btn--ghost-light:hover { background: #fff; color: var(--mia-navy); border-color: #fff; }
/* ghost-dark = outlined for use on white/mist */
.mia-btn--ghost-dark { background: transparent; color: var(--mia-navy); border-color: var(--mia-navy); }
.mia-btn--ghost-dark:hover { background: var(--mia-navy); color: #fff; }

.mia-phone { display: inline-flex; align-items: center; gap: .5rem; text-decoration: none; color: var(--mia-navy); font-weight: 700; font-family: var(--mia-font-display); white-space: nowrap; }
.mia-phone:hover { color: var(--mia-blue); }
.mia-phone__icon { color: var(--mia-gold-deep); display: inline-flex; }
.mia-phone__icon svg { width: 17px; height: 17px; }
.mia-link { display: inline-flex; align-items: center; gap: .4rem; color: var(--mia-blue); font-weight: 700; font-family: var(--mia-font-display); text-decoration: none; letter-spacing: 0.01em; font-size: 0.95rem; }
.mia-link:hover { color: var(--mia-navy); }
.mia-link--on-navy { color: var(--mia-gold); }
.mia-link--on-navy:hover { color: #fff; }
.mia-link span[aria-hidden] { transition: transform .16s ease; }
.mia-link:hover span[aria-hidden] { transform: translateX(3px); }

/* ============================================================
   HEADER — NAVY top utility bar over a WHITE logo row. Sticky; deeper shadow on scroll.
   ============================================================ */
.mia-header { position: sticky; top: 0; left: 0; right: 0; z-index: 100; background: var(--mia-white); transition: box-shadow .25s ease; }
.mia-header.is-scrolled { box-shadow: 0 6px 24px rgba(16, 33, 63, 0.20); }

/* Row 1 — navy utility bar */
.mia-utility { background: var(--mia-navy); color: rgba(255,255,255,0.92); font-size: 0.85rem; }
.mia-utility__row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 40px; padding-block: 0.35rem; }
.mia-utility a { color: inherit; text-decoration: none; }
.mia-utility__emergency { display: inline-flex; align-items: center; gap: 0.5rem; font-weight: 600; }
.mia-utility__emergency svg { width: 16px; height: 16px; color: var(--mia-gold); flex-shrink: 0; }
.mia-utility__emergency strong { color: #fff; font-weight: 700; }
.mia-utility__emergency:hover { color: var(--mia-gold); }
.mia-utility__right { display: inline-flex; align-items: center; gap: 1.25rem; }
.mia-utility__noa { color: rgba(255,255,255,0.78); border-left: 1px solid rgba(255,255,255,0.22); padding-left: 1.25rem; }
.mia-utility__email { display: inline-flex; align-items: center; gap: 0.45rem; }
.mia-utility__email svg { width: 16px; height: 16px; color: var(--mia-gold); }
.mia-utility__email:hover { color: var(--mia-gold); }
@media (max-width: 860px) {
	.mia-utility__noa { display: none; }
	.mia-utility__email { display: none; }
	.mia-utility__row { justify-content: center; }
}

/* Row 2 — white logo row */
.mia-bar__row { display: flex; align-items: center; gap: 1.5rem; min-height: var(--mia-bar-h); }
.mia-logo { display: inline-flex; align-items: center; gap: 0.7rem; text-decoration: none; flex-shrink: 0; }
.mia-logo img { height: 52px; width: auto; display: block; }
.mia-logo__mark { display: inline-flex; color: var(--mia-blue); flex-shrink: 0; }
.mia-logo__mark svg { width: 42px; height: 42px; }
.mia-logo__wordmark { display: flex; flex-direction: column; line-height: 1.04; }
.mia-logo__name { font-family: var(--mia-font-display); font-weight: 800; font-size: 1.34rem; color: var(--mia-navy); letter-spacing: -0.01em; }
.mia-logo__tag { font-family: var(--mia-font-body); font-size: 0.64rem; font-weight: 600; letter-spacing: 0.11em; text-transform: uppercase; color: var(--mia-gold-deep); margin-top: 2px; }

.mia-nav { display: flex; justify-content: center; flex: 1; }
.mia-nav__list { display: flex; gap: clamp(0.85rem, 1.9vw, 1.75rem); margin: 0; padding: 0; list-style: none; align-items: center; }
.mia-nav__list a { color: var(--mia-ink); text-decoration: none; font-family: var(--mia-font-display); font-size: 0.98rem; font-weight: 700; letter-spacing: 0.005em; padding: 0.5rem 0; position: relative; white-space: nowrap; }
.mia-nav__list a::after { content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 3px; background: var(--mia-gold); transform: scaleX(0); transform-origin: center; transition: transform .2s ease; border-radius: 2px; }
.mia-nav__list a:hover { color: var(--mia-blue); }
.mia-nav__list a:hover::after, .mia-nav__list .current-menu-item > a::after { transform: scaleX(1); }
.mia-bar__cta { flex-shrink: 0; }
.mia-bar__cta .mia-btn { padding: 0.62rem 1.35rem; font-size: 0.92rem; }

/* Hamburger (hidden on desktop) */
.mia-burger { display: none; align-items: center; gap: .5rem; background: var(--mia-navy-soft); border: 1px solid var(--mia-line); padding: 0.55rem 0.7rem; border-radius: var(--mia-radius); color: var(--mia-navy); }
.mia-burger__lines { display: inline-flex; flex-direction: column; gap: 4px; }
.mia-burger__lines span { width: 22px; height: 2px; background: var(--mia-navy); display: block; border-radius: 2px; }

@media (max-width: 1040px) {
	.mia-nav, .mia-bar__cta { display: none; }
	.mia-burger { display: inline-flex; }
	.mia-bar__row { justify-content: space-between; }
	.mia-logo__name { font-size: 1.18rem; }
}
@media (max-width: 560px) {
	.mia-logo__mark svg { width: 36px; height: 36px; }
	.mia-logo__name { font-size: 1.06rem; }
	.mia-logo__tag { font-size: 0.56rem; letter-spacing: 0.08em; }
}

/* Off-canvas mobile drawer — slides in from the right via translateX(100vw) */
.mia-mobile-nav { position: fixed; inset: 0; background: var(--mia-navy); color: #fff; padding: 4.5rem 1.5rem 2rem; transform: translateX(100vw); transition: transform .28s ease; z-index: 150; overflow-y: auto; overflow-x: clip; }
.mia-mobile-nav.is-open { transform: translateX(0); }
.mia-mobile-nav__inner { max-width: 460px; margin: 0 auto; }
.mia-mobile-nav__list { list-style: none; padding: 0; margin: 0 0 2rem; }
.mia-mobile-nav__list a { display: block; padding: 1rem 0; color: #fff; text-decoration: none; font-family: var(--mia-font-display); font-weight: 700; font-size: 1.35rem; border-bottom: 1px solid rgba(232,166,44,0.4); }
.mia-mobile-nav__list a:hover { color: var(--mia-gold); }
.mia-mobile-nav__cta { display: flex; flex-direction: column; gap: 0.85rem; margin-top: 1.5rem; }
.mia-mobile-nav__cta .mia-phone { color: #fff; justify-content: center; padding: 1rem; border: 2px solid var(--mia-gold); border-radius: 999px; }
.mia-mobile-nav__cta .mia-phone__icon { color: var(--mia-gold); }

/* ============================================================
   HERO — full-bleed photo + navy scrim + copy left + FLOATING WHITE quote card right
   ============================================================ */
.mia-hero { position: relative; background: var(--mia-navy) var(--mia-bg-md) center/cover no-repeat; overflow: hidden; }
@media (min-width: 1281px) { .mia-hero { background-image: var(--mia-bg-lg); } }
@media (max-width: 768px)  { .mia-hero { background-image: var(--mia-bg-sm); } }
.mia-hero__slides { position: absolute; inset: 0; z-index: 0; }
.mia-hero__slide { position: absolute; inset: 0; background: var(--mia-bg-md) center/cover no-repeat; opacity: 0; transition: opacity 1.2s ease; will-change: opacity, transform; }
@media (min-width: 1281px) { .mia-hero__slide { background-image: var(--mia-bg-lg); } }
@media (max-width: 768px)  { .mia-hero__slide { background-image: var(--mia-bg-sm); } }
.mia-hero__slide.is-active { opacity: 1; animation: mia-kenburns 8s ease-out forwards; }
@keyframes mia-kenburns { from { transform: scale(1.03); } to { transform: scale(1.1); } }
@media (prefers-reduced-motion: reduce) { .mia-hero__slide { transition: none; animation: none !important; } }
.mia-hero__scrim { position: absolute; inset: 0; z-index: 1; background:
	linear-gradient(100deg, rgba(16,33,63,0.92) 0%, rgba(16,33,63,0.74) 42%, rgba(20,39,77,0.42) 72%, rgba(20,39,77,0.30) 100%); }
.mia-hero__inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1.15fr 0.85fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; padding: clamp(3rem, 7vw, 5.5rem) 0 clamp(3.5rem, 8vw, 6rem); }
.mia-hero__eyebrow { font-family: var(--mia-font-display); font-size: 0.8rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--mia-gold); margin: 0 0 0.9rem; }
.mia-hero__h { font-family: var(--mia-font-display); font-weight: 800; font-size: clamp(2.2rem, 4.8vw, 3.5rem); line-height: 1.07; letter-spacing: -0.02em; color: #fff; margin: 0 0 1rem; text-shadow: 0 2px 24px rgba(8,16,33,0.4); }
.mia-hero__sub { font-size: 1.08rem; color: rgba(255,255,255,0.92); margin: 0 0 1.6rem; max-width: 38rem; }
.mia-hero__actions { display: flex; flex-wrap: wrap; gap: 0.85rem; align-items: center; }

/* Floating white quote card */
.mia-hero__card { background: var(--mia-white); border-radius: var(--mia-radius-lg); padding: clamp(1.5rem, 2.5vw, 2.1rem); box-shadow: var(--mia-shadow-lg); border-top: 5px solid var(--mia-gold); }
.mia-hero__card-h { font-family: var(--mia-font-display); font-weight: 800; color: var(--mia-navy); font-size: 1.5rem; line-height: 1.12; margin: 0 0 0.35rem; }
.mia-hero__card-sub { font-size: 0.92rem; color: var(--mia-body); margin: 0 0 1.2rem; }
.mia-hqq { display: grid; gap: 0.8rem; }
.mia-hqq__field { display: flex; flex-direction: column; }
.mia-hqq__field label { font-size: 0.7rem; font-weight: 700; color: var(--mia-navy); margin-bottom: 0.3rem; text-transform: uppercase; letter-spacing: 0.05em; font-family: var(--mia-font-display); }
.mia-hqq__field input, .mia-hqq__field select { width: 100%; padding: 0.72rem 0.85rem; font-size: 0.98rem; border: 1px solid var(--mia-line); border-radius: var(--mia-radius); background: #fff; color: var(--mia-ink); }
.mia-hqq__field input:focus, .mia-hqq__field select:focus { outline: 0; border-color: var(--mia-blue); box-shadow: 0 0 0 3px var(--mia-navy-soft); }
.mia-hqq__submit { width: 100%; margin-top: 0.3rem; }
.mia-hqq__fine { font-size: 0.82rem; color: var(--mia-body); margin: 0.5rem 0 0; text-align: center; }
.mia-hqq__fine a { color: var(--mia-blue); font-weight: 700; text-decoration: none; border-bottom: 2px solid var(--mia-gold); }
.mia-hqq__fine a:hover { color: var(--mia-navy); }
@media (max-width: 960px) {
	.mia-hero__inner { grid-template-columns: 1fr; }
	.mia-hero__card { max-width: 480px; }
}

/* ============================================================
   INTRO — photo + copy, blue headings (white band)
   ============================================================ */
.mia-intro { padding: clamp(3.5rem, 7vw, 5.5rem) 0; background: var(--mia-white); }
.mia-intro__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.mia-intro__media picture, .mia-intro__media img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: var(--mia-radius-lg); box-shadow: var(--mia-shadow); }
.mia-intro__copy p { font-size: 1.06rem; color: var(--mia-body); }
.mia-intro__copy p:first-of-type { color: var(--mia-ink); font-size: 1.12rem; }
.mia-intro__actions { display: flex; flex-wrap: wrap; gap: 0.85rem 1.25rem; align-items: center; margin-top: 1.4rem; }
@media (max-width: 900px) { .mia-intro__grid { grid-template-columns: 1fr; } .mia-intro__media { order: -1; } }

/* ============================================================
   SYSTEMS & MATERIALS strip — circular badge + name (mist band)
   ============================================================ */
.mia-materials { padding: clamp(3rem, 6vw, 4.5rem) 0; background: var(--mia-mist); }
.mia-materials__head { text-align: center; max-width: 760px; margin: 0 auto clamp(2rem, 4vw, 2.75rem); }
.mia-materials__sub { color: var(--mia-body); margin: 0; }
.mia-materials__row { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(5, 1fr); gap: clamp(1rem, 2.5vw, 1.75rem); }
.mia-material { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 0.5rem; background: var(--mia-white); border: 1px solid var(--mia-mist-2); border-radius: var(--mia-radius-md); padding: 1.5rem 1rem 1.35rem; box-shadow: var(--mia-shadow-sm); }
.mia-material__badge { display: grid; place-items: center; width: 56px; height: 56px; border-radius: 50%; background: var(--mia-navy-soft); color: var(--mia-blue); margin-bottom: 0.25rem; }
.mia-material__badge svg { width: 28px; height: 28px; }
.mia-material__name { font-family: var(--mia-font-display); font-weight: 800; font-size: 1.04rem; color: var(--mia-navy); line-height: 1.15; }
.mia-material__sub { font-size: 0.82rem; color: var(--mia-body); }
.mia-materials__note { text-align: center; font-size: 0.86rem; color: var(--mia-body); margin: 1.75rem 0 0; }
@media (max-width: 900px) { .mia-materials__row { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .mia-materials__row { grid-template-columns: repeat(2, 1fr); } }

/* ============================================================
   PROJECTS — NAVY band "the proof is on the roof" + gallery tiles
   ============================================================ */
.mia-projects { padding: clamp(3.5rem, 7vw, 5.5rem) 0; background: var(--mia-navy); color: #fff; }
.mia-projects__head { display: flex; justify-content: space-between; align-items: end; gap: 1.5rem; margin-bottom: clamp(1.75rem, 3vw, 2.75rem); flex-wrap: wrap; }
.mia-projects__title { font-family: var(--mia-font-display); font-weight: 800; font-size: clamp(1.8rem, 3.6vw, 2.5rem); line-height: 1.14; letter-spacing: -0.012em; color: #fff; margin: 0; }
.mia-projects__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.25rem, 3vw, 1.85rem); }
.mia-projects__item { margin: 0; display: flex; flex-direction: column; }
.mia-projects__frame { display: block; overflow: hidden; border-radius: var(--mia-radius-md); box-shadow: var(--mia-shadow); transition: transform .18s ease, box-shadow .18s ease; }
.mia-projects__item:hover .mia-projects__frame { transform: translateY(-4px); }
.mia-projects__frame picture, .mia-projects__frame img { width: 100%; aspect-ratio: 4/5; object-fit: cover; transition: transform .4s ease; }
.mia-projects__item:hover .mia-projects__frame img { transform: scale(1.05); }
.mia-projects__caption { padding: 0.95rem 0.2rem 0; display: flex; flex-direction: column; gap: 0.2rem; }
.mia-projects__caption strong { font-family: var(--mia-font-display); font-weight: 700; font-size: 1.06rem; color: #fff; }
.mia-projects__caption span { font-size: 0.88rem; color: rgba(255,255,255,0.78); }
.mia-projects__cta { margin-top: clamp(2rem, 4vw, 2.75rem); text-align: center; }
@media (max-width: 860px) { .mia-projects__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px) { .mia-projects__grid { grid-template-columns: 1fr; } .mia-projects__frame picture, .mia-projects__frame img { aspect-ratio: 4/3; } }

/* ============================================================
   SERVICE-AREA band — neighborhood chips (white band)
   ============================================================ */
.mia-areas-band { padding: clamp(3.5rem, 7vw, 5rem) 0; background: var(--mia-white); }
.mia-areas-band__head { text-align: center; max-width: 760px; margin: 0 auto clamp(1.75rem, 3vw, 2.5rem); }
.mia-areas-band__sub { color: var(--mia-body); margin: 0; }
.mia-chips { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 0.7rem; justify-content: center; }
.mia-chip a { display: inline-flex; align-items: center; padding: 0.6rem 1.15rem; background: var(--mia-mist); border: 1px solid var(--mia-mist-2); border-radius: 999px; color: var(--mia-navy); text-decoration: none; font-family: var(--mia-font-display); font-weight: 700; font-size: 0.9rem; transition: background .14s ease, color .14s ease, border-color .14s ease, transform .12s ease; }
.mia-chip a:hover { background: var(--mia-blue); color: #fff; border-color: var(--mia-blue); transform: translateY(-2px); }

/* ============================================================
   WHY-CHOOSE band — 4 process-clarity cards (mist band). No reviews or testimonials.
   ============================================================ */
.mia-why { padding: clamp(3.5rem, 7vw, 5.5rem) 0; background: var(--mia-mist); }
.mia-why__head { text-align: center; max-width: 760px; margin: 0 auto clamp(2rem, 4vw, 3rem); }
.mia-why__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.mia-why__card { background: var(--mia-white); border-radius: var(--mia-radius-md); padding: 1.85rem 1.6rem; box-shadow: var(--mia-shadow-sm); border-top: 4px solid var(--mia-gold); }
.mia-why__icon { display: grid; place-items: center; width: 56px; height: 56px; border-radius: 50%; background: var(--mia-navy); color: var(--mia-gold); margin-bottom: 1.1rem; }
.mia-why__icon svg { width: 28px; height: 28px; }
.mia-why__card-h { font-family: var(--mia-font-display); font-weight: 800; color: var(--mia-navy); margin: 0 0 0.55rem; font-size: 1.16rem; line-height: 1.2; }
.mia-why__card p { font-size: 0.94rem; color: var(--mia-body); margin: 0; }
@media (max-width: 980px) { .mia-why__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .mia-why__grid { grid-template-columns: 1fr; } }

/* ============================================================
   MID CTA — NAVY band (front page)
   ============================================================ */
.mia-midcta { position: relative; background:
	radial-gradient(circle at 88% 120%, rgba(232,166,44,0.16), transparent 46%),
	var(--mia-navy); color: #fff; padding: clamp(3.5rem, 6vw, 5rem) 0; }
.mia-midcta__rule { position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--mia-gold-deep), var(--mia-gold), var(--mia-gold-deep)); }
.mia-midcta__inner { display: flex; align-items: center; justify-content: space-between; gap: 2.5rem; flex-wrap: wrap; position: relative; z-index: 1; }
.mia-midcta__copy { max-width: 640px; }
.mia-midcta__h { font-family: var(--mia-font-display); font-weight: 800; color: #fff; font-size: clamp(1.75rem, 3.6vw, 2.4rem); line-height: 1.14; letter-spacing: -0.01em; margin: 0.3rem 0; }
.mia-midcta__sub { color: rgba(255,255,255,0.86); font-size: 1.04rem; margin: 0; }
.mia-midcta__actions { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; }

/* ============================================================
   FEATURE BLOCKS — "why metal in Miami" alternating photo/copy (white band)
   ============================================================ */
.mia-features { padding: clamp(3.5rem, 7vw, 5.5rem) 0; background: var(--mia-white); }
.mia-features__head { text-align: center; max-width: 760px; margin: 0 auto clamp(2.5rem, 4vw, 3.5rem); }
.mia-feature { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.75rem, 4vw, 3.5rem); align-items: center; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.mia-feature:last-child { margin-bottom: 0; }
.mia-feature__media picture, .mia-feature__media img { width: 100%; aspect-ratio: 3/2; object-fit: cover; border-radius: var(--mia-radius-lg); box-shadow: var(--mia-shadow); }
.mia-feature__h { font-family: var(--mia-font-display); font-weight: 800; color: var(--mia-blue); margin: 0 0 0.7rem; font-size: clamp(1.4rem, 2.6vw, 1.85rem); line-height: 1.16; }
.mia-feature__copy p { font-size: 1.04rem; color: var(--mia-body); margin: 0; }
.mia-feature--flip .mia-feature__media { order: 2; }
@media (max-width: 860px) {
	.mia-feature, .mia-feature--flip { grid-template-columns: 1fr; }
	.mia-feature__media, .mia-feature--flip .mia-feature__media { order: -1; }
}

/* ============================================================
   INSIGHTS / RESOURCES teaser — 3 cards (mist band)
   ============================================================ */
.mia-insights { padding: clamp(3.5rem, 7vw, 5.5rem) 0; background: var(--mia-mist); }
.mia-insights__head { display: flex; justify-content: space-between; align-items: end; gap: 1.5rem; margin-bottom: clamp(1.75rem, 3vw, 2.5rem); flex-wrap: wrap; }
.mia-insights__head .mia-h2 { margin: 0; }
.mia-insights__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.mia-insight { background: var(--mia-white); padding: 1.85rem; border-radius: var(--mia-radius-md); border: 1px solid var(--mia-mist-2); border-bottom: 4px solid var(--mia-gold); transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease; }
.mia-insight:hover { transform: translateY(-3px); box-shadow: var(--mia-shadow-sm); border-bottom-color: var(--mia-blue); }
.mia-insight__h { font-family: var(--mia-font-display); font-weight: 800; font-size: 1.2rem; line-height: 1.22; margin: 0 0 0.6rem; }
.mia-insight__h a { color: var(--mia-navy); text-decoration: none; }
.mia-insight__h a:hover { color: var(--mia-blue); }
.mia-insight p { color: var(--mia-body); margin: 0 0 1rem; font-size: 0.96rem; }
@media (max-width: 900px) { .mia-insights__grid { grid-template-columns: 1fr; } }

/* ============================================================
   PAGE HERO (interior) — full-bleed NAVY band w/ photo + scrim, breadcrumbs + bold title
   ============================================================ */
.mia-page-hero { position: relative; background: var(--mia-navy) var(--mia-bg-md) center/cover no-repeat; overflow: hidden; }
@media (min-width: 1281px) { .mia-page-hero { background-image: var(--mia-bg-lg); } }
@media (max-width: 768px)  { .mia-page-hero { background-image: var(--mia-bg-sm); } }
.mia-page-hero__photo { position: absolute; inset: 0; background: inherit; z-index: 0; }
.mia-page-hero__overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(100deg, rgba(16,33,63,0.93) 0%, rgba(16,33,63,0.78) 55%, rgba(20,39,77,0.52) 100%); }
.mia-page-hero__inner { position: relative; z-index: 2; max-width: 820px; padding: clamp(2.75rem, 5vw, 4.25rem) 0; }
.mia-page-hero__h { font-family: var(--mia-font-display); font-weight: 800; font-size: clamp(2.1rem, 4.6vw, 3.1rem); line-height: 1.08; letter-spacing: -0.018em; color: #fff; margin: 0 0 1rem; }
.mia-page-hero__sub { color: rgba(255,255,255,0.92); font-size: 1.06rem; margin: 0 0 1.6rem; max-width: 660px; }
.mia-page-hero__actions { display: flex; flex-wrap: wrap; gap: 0.85rem; align-items: center; }

.mia-breadcrumbs { margin-bottom: 0.9rem; }
.mia-breadcrumbs ol { list-style: none; padding: 0; margin: 0; display: flex; gap: 0.5rem; flex-wrap: wrap; font-size: 0.85rem; color: rgba(255,255,255,0.8); }
.mia-breadcrumbs li + li::before { content: '/'; color: var(--mia-gold); margin-right: 0.5rem; }
.mia-breadcrumbs a { color: rgba(255,255,255,0.88); text-decoration: none; }
.mia-breadcrumbs a:hover { color: #fff; }
.mia-breadcrumbs [aria-current="page"] { color: #fff; font-weight: 700; }

/* ============ INTERIOR STRUCTURES ============ */
.mia-section { padding: clamp(3rem, 6vw, 5rem) 0; }
.mia-prose { font-size: 1.06rem; line-height: 1.72; color: var(--mia-body); }
.mia-prose h2 { margin-top: 2rem; color: var(--mia-blue); } .mia-prose h3 { margin-top: 1.5rem; font-size: 1.25rem; color: var(--mia-ink); }
.mia-prose ul, .mia-prose ol { padding-left: 1.5rem; margin: 0 0 1.25rem; }
.mia-prose li { margin-bottom: 0.4rem; }
.mia-prose strong { color: var(--mia-navy); }
.mia-prose a { font-weight: 600; }

.mia-svc-layout, .mia-article-layout, .mia-about__grid { display: grid; grid-template-columns: 1.7fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.mia-aside-card { background: var(--mia-mist); border-radius: var(--mia-radius-md); padding: 1.85rem; border-top: 5px solid var(--mia-gold); position: sticky; top: calc(var(--mia-bar-h) + 24px); box-shadow: var(--mia-shadow-sm); }
.mia-aside-card__h { font-family: var(--mia-font-display); font-weight: 800; color: var(--mia-navy); margin: 0 0 0.6rem; font-size: 1.3rem; }
.mia-aside-card__sub { font-size: 0.95rem; color: var(--mia-body); margin: 0 0 1.2rem; }
.mia-aside-card .mia-btn { width: 100%; margin-bottom: 0.7rem; }
.mia-aside-card .mia-phone { width: 100%; justify-content: center; padding: 0.8rem; border: 1px solid var(--mia-line); border-radius: 999px; background: #fff; }
.mia-aside-card__meta { margin: 1.4rem 0 0; padding-top: 1.2rem; border-top: 1px solid var(--mia-line); font-size: 0.88rem; }
.mia-aside-card__meta dt { font-weight: 700; color: var(--mia-navy); margin-top: 0.6rem; text-transform: uppercase; letter-spacing: 0.05em; font-size: 0.72rem; font-family: var(--mia-font-display); }
.mia-aside-card__meta dd { margin: 0.2rem 0 0; color: var(--mia-body); }
.mia-aside-card__meta dd a { color: var(--mia-blue); }
.mia-aside-card__steps { list-style: none; padding: 0; margin: 0 0 1.2rem; counter-reset: stp; }
.mia-aside-card__steps li { padding-left: 2.1rem; position: relative; margin-bottom: 0.8rem; font-size: 0.93rem; color: var(--mia-body); }
.mia-aside-card__steps li::before { content: counter(stp); counter-increment: stp; position: absolute; left: 0; top: 0; width: 24px; height: 24px; background: var(--mia-gold); color: var(--mia-navy); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 0.78rem; font-weight: 800; font-family: var(--mia-font-display); }
.mia-aside-card__steps strong { color: var(--mia-navy); }
@media (max-width: 900px) { .mia-svc-layout, .mia-article-layout, .mia-about__grid { grid-template-columns: 1fr; } .mia-aside-card { position: static; } }

/* Services hub grid (shared with front-page service cards) */
.mia-services { padding: clamp(3.5rem, 7vw, 5.5rem) 0; background: var(--mia-white); }
.mia-services--page { padding-top: clamp(2.5rem, 5vw, 4rem); }
.mia-services__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.75rem; }
.mia-svccard { display: flex; flex-direction: column; background: var(--mia-white); border-radius: var(--mia-radius-md); overflow: hidden; text-decoration: none; color: var(--mia-body); box-shadow: var(--mia-shadow-sm); transition: transform .16s ease, box-shadow .16s ease; border: 1px solid var(--mia-mist-2); }
.mia-svccard:hover { transform: translateY(-5px); box-shadow: var(--mia-shadow); }
.mia-svccard__photo { display: block; position: relative; }
.mia-svccard__photo picture, .mia-svccard__photo img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.mia-svccard__body { padding: 1.4rem 1.5rem 1.6rem; display: flex; flex-direction: column; flex: 1; }
.mia-svccard__h { font-family: var(--mia-font-display); font-weight: 800; color: var(--mia-navy); margin: 0 0 0.65rem; font-size: 1.28rem; line-height: 1.16; }
.mia-svccard__rule { display: block; width: 46px; height: 3px; background: var(--mia-gold); border-radius: 3px; margin: 0 0 0.85rem; }
.mia-svccard__p { font-size: 0.95rem; color: var(--mia-body); margin: 0 0 1.1rem; flex: 1; }
.mia-svccard__more { align-self: flex-start; font-family: var(--mia-font-display); font-weight: 700; color: var(--mia-blue); font-size: 0.92rem; display: inline-flex; align-items: center; gap: 0.4rem; }
.mia-svccard__more span[aria-hidden] { transition: transform .16s ease; }
.mia-svccard:hover .mia-svccard__more { color: var(--mia-navy); }
.mia-svccard:hover .mia-svccard__more span[aria-hidden] { transform: translateX(3px); }
@media (max-width: 980px) { .mia-services__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 620px) { .mia-services__grid { grid-template-columns: 1fr; } }

/* FAQ page */
.mia-faq { display: flex; flex-direction: column; gap: 0.65rem; max-width: 860px; margin: 0 auto; }
.mia-faq__item { background: var(--mia-mist); padding: 1.4rem 1.6rem; border-radius: var(--mia-radius); border-left: 4px solid var(--mia-gold); }
.mia-faq__item[open] { border-left-color: var(--mia-blue); }
.mia-faq__item summary { font-family: var(--mia-font-display); font-weight: 700; color: var(--mia-navy); font-size: 1.08rem; cursor: pointer; list-style: none; padding-right: 1.75rem; position: relative; }
.mia-faq__item summary::-webkit-details-marker { display: none; }
.mia-faq__item summary::after { content: '+'; position: absolute; right: 0; top: 50%; transform: translateY(-50%); color: var(--mia-gold-deep); font-size: 1.5rem; font-weight: 400; line-height: 1; }
.mia-faq__item[open] summary::after { content: '\2013'; }
.mia-faq__item p { margin: 0.9rem 0 0; color: var(--mia-body); }
.mia-faq__item a { color: var(--mia-blue); font-weight: 700; }

/* Service areas */
.mia-areas { max-width: 880px; margin: 0 auto; }
.mia-areas__intro { margin-bottom: 2.5rem; font-size: 1.08rem; color: var(--mia-ink); }
.mia-area-section { padding: 1.6rem 0 1.9rem; border-bottom: 1px solid var(--mia-line); }
.mia-area-section:last-child { border-bottom: 0; }
.mia-area-section__h { font-family: var(--mia-font-display); font-weight: 800; color: var(--mia-navy); margin: 0 0 0.9rem; font-size: clamp(1.4rem, 2.4vw, 1.7rem); }
.mia-area-section__h span { color: var(--mia-gold-deep); font-weight: 700; font-size: 0.62em; }
.mia-area-section p { margin: 0 0 0.7rem; color: var(--mia-body); }
.mia-area-section p strong { color: var(--mia-navy); }
.mia-area-section--outro { background: var(--mia-mist); padding: 1.75rem; border-radius: var(--mia-radius-md); border-left: 4px solid var(--mia-gold); margin-top: 1.5rem; }

/* Contact */
.mia-contact__grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.mia-contact__details h2 { margin-top: 1.6rem; } .mia-contact__details h2:first-child { margin-top: 0; }
.mia-contact__details address { font-style: normal; color: var(--mia-ink); line-height: 1.5; }
.mia-contact__note { font-size: 0.9rem; color: var(--mia-body); margin-top: 0.3rem; }
.mia-contact__hours dt { font-weight: 700; color: var(--mia-navy); margin-top: 0.5rem; text-transform: uppercase; font-size: 0.72rem; letter-spacing: 0.05em; font-family: var(--mia-font-display); }
.mia-contact__hours dd { margin: 0; color: var(--mia-body); }
.mia-contact__map iframe { width: 100%; height: 480px; border: 0; border-radius: var(--mia-radius-md); box-shadow: var(--mia-shadow); }
@media (max-width: 900px) { .mia-contact__grid { grid-template-columns: 1fr; } .mia-contact__map iframe { height: 340px; } }

/* Resources */
.mia-resources__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.mia-resource { background: var(--mia-mist); padding: 1.85rem; border-radius: var(--mia-radius-md); border: 1px solid var(--mia-mist-2); border-bottom: 4px solid var(--mia-gold); transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease; }
.mia-resource:hover { transform: translateY(-3px); box-shadow: var(--mia-shadow-sm); border-bottom-color: var(--mia-blue); }
.mia-resource__h { font-family: var(--mia-font-display); font-weight: 800; font-size: 1.26rem; line-height: 1.22; margin: 0 0 0.6rem; }
.mia-resource__h a { color: var(--mia-navy); text-decoration: none; }
.mia-resource__h a:hover { color: var(--mia-blue); }
.mia-resource p { color: var(--mia-body); margin: 0 0 1rem; }
@media (max-width: 760px) { .mia-resources__grid { grid-template-columns: 1fr; } }
.mia-article { max-width: 720px; }

/* ============================================================
   BOOK APPOINTMENT (5-step quote)
   ============================================================ */
.mia-book__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.mia-book__form-wrap { background: var(--mia-white); padding: clamp(1.5rem, 3vw, 2.5rem); border-radius: var(--mia-radius-md); border: 1px solid var(--mia-mist-2); box-shadow: var(--mia-shadow); }
.mia-quote__progress { height: 6px; background: var(--mia-mist-2); border-radius: 999px; overflow: hidden; margin-bottom: 1.6rem; }
.mia-quote__progress-bar { display: block; height: 100%; background: var(--mia-gold); border-radius: 999px; transition: width .3s ease; }
.mia-quote__steps { list-style: none; padding: 0; margin: 0; }
.mia-quote__step { display: none; } .mia-quote__step.is-active { display: block; }
.mia-quote__head { margin-bottom: 1.2rem; }
.mia-quote__head span { font-size: 0.76rem; color: var(--mia-gold-deep); letter-spacing: 0.12em; text-transform: uppercase; font-weight: 700; font-family: var(--mia-font-display); }
.mia-quote__head .mia-h3 { margin: 0.3rem 0 0; }
.mia-quote__hint { font-size: 0.9rem; color: var(--mia-body); margin: 0 0 1rem; }
.mia-quote__hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.mia-field { margin-bottom: 1rem; }
.mia-field label { display: block; font-size: 0.74rem; font-weight: 700; color: var(--mia-navy); margin-bottom: 0.4rem; text-transform: uppercase; letter-spacing: 0.05em; font-family: var(--mia-font-display); }
.mia-field input, .mia-field select, .mia-field textarea { width: 100%; padding: 0.8rem 0.95rem; font-size: 1rem; border: 1px solid var(--mia-line); border-radius: var(--mia-radius); background: #fff; color: var(--mia-ink); transition: border-color .14s ease, box-shadow .14s ease; }
.mia-field input:focus, .mia-field select:focus, .mia-field textarea:focus { outline: 0; border-color: var(--mia-blue); box-shadow: 0 0 0 3px var(--mia-navy-soft); }
.mia-field input.is-invalid, .mia-field select.is-invalid { border-color: var(--mia-coral); box-shadow: 0 0 0 3px rgba(229,64,46,0.12); }
.mia-field--split { display: grid; grid-template-columns: 2fr 1fr; gap: 1rem; }
.mia-radios { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.75rem; padding: 0; border: 0; margin: 0 0 1rem; }
.mia-radio { display: flex; align-items: flex-start; gap: 0.6rem; padding: 1rem; border: 1px solid var(--mia-line); border-radius: var(--mia-radius); cursor: pointer; transition: border-color .14s ease, background .14s ease; background: #fff; }
.mia-radio:hover { border-color: var(--mia-blue); background: var(--mia-mist); }
.mia-radio input { margin-top: 0.25rem; accent-color: var(--mia-blue); }
.mia-radio:has(input:checked) { border-color: var(--mia-blue); background: var(--mia-navy-soft); }
.mia-radio__body { display: flex; flex-direction: column; gap: 0.15rem; }
.mia-radio__body strong { font-size: 0.95rem; font-weight: 700; color: var(--mia-navy); }
.mia-radio__body em { font-style: normal; font-size: 0.82rem; color: var(--mia-body); }
.mia-radio--alert { border-color: var(--mia-coral); }
.mia-radio--alert .mia-radio__body strong { color: var(--mia-coral); }
.mia-radio--alert:has(input:checked) { border-color: var(--mia-coral); background: rgba(229,64,46,0.08); }
.mia-quote__nav { display: flex; gap: 0.85rem; justify-content: space-between; margin-top: 1.5rem; }
.mia-quote__nav .mia-btn { flex: 1; }
.mia-quote__success { text-align: center; padding: 2rem 0; }
.mia-quote__success svg { width: 80px; height: 80px; margin: 0 auto 1.5rem; }
.mia-quote__error { background: rgba(229,64,46,0.08); border: 1px solid var(--mia-coral); border-radius: var(--mia-radius); padding: 1rem 1.25rem; color: var(--mia-coral); font-size: 0.92rem; margin-top: 1.5rem; }
@media (max-width: 600px) { .mia-radios { grid-template-columns: 1fr; } .mia-field--split { grid-template-columns: 1fr; } }
@media (max-width: 900px) { .mia-book__grid { grid-template-columns: 1fr; } }

/* ============================================================
   NAVY CTA BAND (footer) w/ a gold hairline rule
   ============================================================ */
.mia-cta-band { position: relative; background:
	radial-gradient(circle at 90% 120%, rgba(232,166,44,0.16), transparent 46%),
	var(--mia-navy); color: #fff; padding: clamp(4rem, 7vw, 5.5rem) 0 clamp(3.5rem, 6vw, 5rem); }
.mia-cta-band__rule { position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--mia-gold-deep), var(--mia-gold), var(--mia-gold-deep)); }
.mia-cta-band__inner { display: flex; align-items: center; justify-content: space-between; gap: 2.5rem; flex-wrap: wrap; position: relative; z-index: 1; }
.mia-cta-band__copy { max-width: 640px; }
.mia-cta-band__h { font-family: var(--mia-font-display); font-weight: 800; color: #fff; font-size: clamp(1.8rem, 3.8vw, 2.5rem); line-height: 1.12; letter-spacing: -0.012em; margin: 0.3rem 0; }
.mia-cta-band__sub { color: rgba(255,255,255,0.86); font-size: 1.04rem; margin: 0; }
.mia-cta-band__actions { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; }

/* ============ FOOTER ============ */
.mia-footer { position: relative; background: var(--mia-navy); color: rgba(255,255,255,0.82); padding: clamp(3.5rem, 5vw, 5rem) 0 0; }
.mia-footer__rule { position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--mia-gold-deep), var(--mia-gold), var(--mia-gold-deep)); }
.mia-footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: clamp(1.5rem, 3vw, 3rem); padding-bottom: 3rem; }
.mia-footer .mia-logo { gap: 0.7rem; margin-bottom: 1.1rem; }
.mia-footer .mia-logo__mark { color: var(--mia-gold); }
.mia-footer .mia-logo__name { color: #fff; }
.mia-footer .mia-logo__tag { color: var(--mia-gold); }
.mia-footer__lede { font-size: 0.95rem; line-height: 1.65; margin: 0 0 1.2rem; max-width: 400px; color: rgba(255,255,255,0.78); }
.mia-footer__locality { font-style: normal; color: var(--mia-gold); line-height: 1.5; font-size: 0.92rem; margin: 0 0 1rem; font-weight: 600; }
.mia-footer__contact { margin: 1rem 0 0; font-size: 0.95rem; }
.mia-footer__contact a { color: #fff; text-decoration: none; border-bottom: 1px solid var(--mia-gold); }
.mia-footer__contact a:hover { color: var(--mia-gold); }
.mia-footer__h { font-family: var(--mia-font-display); font-weight: 700; color: #fff; font-size: 1.06rem; margin: 0 0 1rem; }
.mia-footer__list { list-style: none; padding: 0; margin: 0; }
.mia-footer__list li { margin-bottom: 0.55rem; font-size: 0.93rem; }
.mia-footer__list a { color: rgba(255,255,255,0.78); text-decoration: none; }
.mia-footer__list a:hover { color: var(--mia-gold); }
.mia-footer__base { background: rgba(0,0,0,0.20); border-top: 1px solid rgba(232,166,44,0.3); padding: 1.2rem 0; margin-top: 0.5rem; }
.mia-footer__base-row { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; }
.mia-footer__copy, .mia-footer__credit { font-size: 0.85rem; color: rgba(255,255,255,0.65); margin: 0; }
.mia-footer__credit a { color: var(--mia-gold); text-decoration: none; font-weight: 700; }
.mia-footer__credit a:hover { color: #fff; }
@media (max-width: 980px) { .mia-footer__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .mia-footer__grid { grid-template-columns: 1fr; } }

/* ============ STICKY MOBILE BAR (gold call) ============ */
.mia-sticky-bar { display: none; position: fixed; bottom: 0; left: 0; right: 0; width: 100vw; max-width: 100%; background: var(--mia-navy); border-top: 3px solid var(--mia-gold); padding: 0.55rem 0.8rem calc(0.55rem + env(safe-area-inset-bottom)); z-index: 130; gap: 0.6rem; }
.mia-sticky-bar__btn { flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 0.4rem; padding: 0.85rem; border-radius: 999px; text-decoration: none; font-family: var(--mia-font-display); font-weight: 700; font-size: 0.95rem; }
.mia-sticky-bar__btn--call { background: var(--mia-gold); color: var(--mia-navy); }
.mia-sticky-bar__btn--quote { background: #fff; color: var(--mia-navy); }
.mia-sticky-bar__btn svg { width: 17px; height: 17px; }
@media (max-width: 720px) { .mia-sticky-bar { display: flex; } body { padding-bottom: 76px; } }

/* ============ REDUCED MOTION ============ */
@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after { animation: none !important; transition: none !important; }
	.mia-projects__item:hover .mia-projects__frame img { transform: none; }
	.mia-btn:hover, .mia-svccard:hover, .mia-resource:hover, .mia-insight:hover, .mia-chip a:hover, .mia-projects__item:hover .mia-projects__frame { transform: none; }
}
