:root {
    --cc-blue: #1769e0;
    --cc-blue-dark: #0f4faa;
    --cc-blue-soft: #eaf2ff;
    --cc-mint: #38bfa7;
    --cc-mint-soft: #e6f7f3;
    --cc-navy: #0e1a30;
    --cc-navy-soft: #1d2d4a;
    --cc-ice: #f6f9fc;
    --cc-ice-2: #eef3f9;
    --cc-white: #ffffff;
    --cc-slate: #364152;
    --cc-muted: #667085;
    --cc-muted-2: #98a2b3;
    --cc-success: #17a673;
    --cc-warning: #f5a524;
    --cc-error: #d92d20;
    --cc-border: #e3e8ef;
    --cc-border-strong: #cdd5df;
    --cc-radius: 14px;
    --cc-radius-sm: 10px;
    --cc-radius-lg: 22px;
    --cc-shadow-sm: 0 1px 2px rgba(16, 24, 40, 0.06), 0 1px 3px rgba(16, 24, 40, 0.04);
    --cc-shadow: 0 4px 12px rgba(14, 26, 48, 0.05), 0 12px 32px rgba(14, 26, 48, 0.06);
    --cc-shadow-lg: 0 20px 48px rgba(14, 26, 48, 0.10), 0 6px 16px rgba(14, 26, 48, 0.06);
    --cc-shadow-glow: 0 16px 40px rgba(23, 105, 224, 0.18);
    --maxw: 1240px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    background: var(--cc-white);
    color: var(--cc-slate);
    font-family: Inter, "Plus Jakarta Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 16px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

h1, h2, h3, h4, p, ul, ol, blockquote, figure {
    margin: 0;
    padding: 0;
}
ul, ol { list-style: none; }

h1, h2, h3, h4 {
    color: var(--cc-navy);
    font-weight: 700;
    letter-spacing: -0.018em;
    line-height: 1.12;
}

h1 {
    font-family: Fraunces, "Times New Roman", Georgia, serif;
    font-size: clamp(2.4rem, 4.2vw + 1rem, 4.4rem);
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.04;
}

h1 em {
    color: var(--cc-blue);
    font-style: italic;
    font-weight: 500;
}

h2 {
    font-family: Fraunces, "Times New Roman", Georgia, serif;
    font-size: clamp(1.8rem, 1.6vw + 1rem, 2.6rem);
    font-weight: 600;
    letter-spacing: -0.018em;
}

h3 { font-size: 1.15rem; font-weight: 700; }
h4 { font-size: 0.98rem; font-weight: 700; }

p { color: var(--cc-slate); }

.eyebrow {
    color: var(--cc-blue);
    display: inline-block;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.eyebrow-line {
    align-items: center;
    color: var(--cc-navy);
    display: inline-flex;
    gap: 10px;
}

.eyebrow-line span {
    background: var(--cc-blue);
    border-radius: 999px;
    display: inline-block;
    height: 2px;
    width: 28px;
}

.eyebrow-light { color: rgba(255, 255, 255, 0.85); }

.lede {
    color: var(--cc-muted);
    font-size: 1.06rem;
    margin-top: 14px;
    max-width: 720px;
}

/* ====================== top strip ====================== */
.top-strip {
    background: var(--cc-navy);
    color: rgba(255, 255, 255, 0.82);
    font-size: 0.82rem;
}
.top-strip-inner {
    align-items: center;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    margin: 0 auto;
    max-width: var(--maxw);
    padding: 10px 6vw;
}
.top-strip-tag { color: rgba(255, 255, 255, 0.7); }
.top-strip-links {
    align-items: center;
    display: flex;
    gap: 18px;
}
.top-strip-phone, .top-strip-mail {
    align-items: center;
    color: var(--cc-white);
    display: inline-flex;
    font-weight: 600;
    gap: 6px;
    transition: color .15s ease;
}
.top-strip-phone:hover, .top-strip-mail:hover { color: var(--cc-mint); }
.top-strip-account {
    max-width: 8.5rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ====================== header ====================== */
.site-header {
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: saturate(140%) blur(12px);
    border-bottom: 1px solid var(--cc-border);
    position: sticky;
    top: 0;
    z-index: 30;
}
.site-header-inner {
    align-items: center;
    display: flex;
    gap: 20px;
    justify-content: space-between;
    margin: 0 auto;
    max-width: var(--maxw);
    min-height: 76px;
    padding: 0 6vw;
}

.brand {
    align-items: center;
    color: var(--cc-navy);
    display: inline-flex;
    flex: 0 0 auto;
    font-weight: 800;
    gap: 12px;
}

.brand-mark {
    align-items: center;
    background: linear-gradient(140deg, var(--cc-blue), var(--cc-mint));
    border-radius: var(--cc-radius-sm);
    box-shadow: var(--cc-shadow-sm);
    color: var(--cc-white);
    display: inline-flex;
    height: 38px;
    justify-content: center;
    width: 38px;
}
.brand-text { display: flex; flex-direction: column; line-height: 1.05; }
.brand-name {
    font-size: 1.15rem;
    font-weight: 800;
    letter-spacing: -0.01em;
}
.brand-sub {
    color: var(--cc-muted);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.site-nav { flex: 1 1 auto; }
.site-nav ul {
    align-items: center;
    display: flex;
    gap: 4px;
    justify-content: center;
}
.site-nav a {
    align-items: center;
    border-radius: 8px;
    color: var(--cc-slate);
    display: inline-flex;
    font-size: 0.92rem;
    font-weight: 600;
    gap: 4px;
    padding: 8px 12px;
    transition: color .15s ease, background .15s ease;
}
.site-nav a:hover, .site-nav .has-menu:hover > a {
    background: var(--cc-blue-soft);
    color: var(--cc-blue);
}
.caret { font-size: 0.7em; opacity: 0.7; }

.has-menu { position: relative; }
.has-menu::after {
    content: "";
    height: 14px;
    left: 0;
    position: absolute;
    right: 0;
    top: 100%;
}
.dropdown {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius);
    box-shadow: var(--cc-shadow-lg);
    display: grid;
    gap: 28px;
    grid-template-columns: repeat(3, minmax(180px, 1fr));
    left: 50%;
    margin-top: 14px;
    opacity: 0;
    padding: 22px;
    pointer-events: none;
    position: absolute;
    top: 100%;
    transform: translate(-50%, -8px);
    transition: opacity .18s ease, transform .18s ease;
    width: 640px;
    z-index: 40;
}
.has-menu:hover .dropdown,
.has-menu:focus-within .dropdown {
    opacity: 1;
    pointer-events: auto;
    transform: translate(-50%, 0);
}
.dropdown-col { display: flex; flex-direction: column; gap: 4px; }
.dropdown-label {
    color: var(--cc-muted);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    margin-bottom: 6px;
    padding: 0 8px;
    text-transform: uppercase;
}
.dropdown a {
    border-radius: 8px;
    color: var(--cc-navy);
    display: block;
    font-size: 0.92rem;
    font-weight: 600;
    padding: 8px 10px;
}
.dropdown a:hover { background: var(--cc-blue-soft); color: var(--cc-blue); }

.header-cta { align-items: center; display: flex; gap: 8px; flex: 0 0 auto; }
.header-account-label {
    display: inline-block;
    max-width: 7.5rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ====================== mobile nav (hamburger) ====================== */
/* Hidden on desktop — the .site-nav inline menu handles desktop navigation.
   At ≤980px the inline nav hides (existing rule) and the hamburger appears. */
.nav-toggle {
    align-items: center;
    background: transparent;
    border: 1px solid var(--cc-border-strong);
    border-radius: 10px;
    color: var(--cc-navy);
    cursor: pointer;
    display: none;
    height: 38px;
    justify-content: center;
    padding: 0;
    transition: border-color .15s ease, color .15s ease;
    width: 38px;
}
.nav-toggle:hover { border-color: var(--cc-blue); color: var(--cc-blue); }
.nav-toggle-bars {
    display: inline-flex;
    flex-direction: column;
    gap: 4px;
    width: 18px;
}
.nav-toggle-bars span {
    background: currentColor;
    border-radius: 1px;
    height: 2px;
    transition: transform .2s ease, opacity .15s ease;
    width: 100%;
}
body.nav-open .nav-toggle-bars span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
body.nav-open .nav-toggle-bars span:nth-child(2) { opacity: 0; }
body.nav-open .nav-toggle-bars span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* Drawer is always in the DOM; visibility/transform driven by body.nav-open */
.mobile-nav {
    display: none;
    inset: 0;
    position: fixed;
    z-index: 60;
}
body.nav-open { overflow: hidden; }
body.nav-open .mobile-nav { display: block; }
.mobile-nav-backdrop {
    background: rgba(14, 26, 48, 0.55);
    cursor: pointer;
    inset: 0;
    opacity: 0;
    position: absolute;
    transition: opacity .2s ease;
}
body.nav-open .mobile-nav-backdrop { opacity: 1; }
.mobile-nav-panel {
    background: var(--cc-white);
    box-shadow: -16px 0 40px rgba(14, 26, 48, 0.25);
    display: flex;
    flex-direction: column;
    height: 100%;
    margin-left: auto;
    max-width: 360px;
    position: relative;
    transform: translateX(100%);
    transition: transform .25s ease;
    width: 86vw;
}
body.nav-open .mobile-nav-panel { transform: translateX(0); }
.mobile-nav-head {
    align-items: center;
    border-bottom: 1px solid var(--cc-border);
    display: flex;
    flex: 0 0 auto;
    justify-content: space-between;
    padding: 14px 18px;
}
.mobile-nav-head .brand { gap: 8px; }
.mobile-nav-head .brand-mark { height: 30px; width: 30px; }
.mobile-nav-head .brand-mark svg { height: 16px; width: 16px; }
.mobile-nav-head .brand-name { font-size: 1rem; }
.nav-close {
    align-items: center;
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: 10px;
    color: var(--cc-navy);
    cursor: pointer;
    display: inline-flex;
    height: 38px;
    justify-content: center;
    padding: 0;
    transition: border-color .15s ease, color .15s ease;
    width: 38px;
}
.nav-close:hover { border-color: var(--cc-blue); color: var(--cc-blue); }

.mobile-nav-body {
    -webkit-overflow-scrolling: touch;
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    overflow-y: auto;
    padding: 12px 6px 18px;
}
.mobile-nav-label {
    color: var(--cc-muted);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    margin: 14px 16px 6px;
    text-transform: uppercase;
}
.mobile-nav-label:first-child { margin-top: 4px; }
.mobile-nav-body a {
    border-radius: 10px;
    color: var(--cc-navy);
    display: block;
    font-size: 0.98rem;
    font-weight: 600;
    margin: 0 8px;
    padding: 11px 14px;
    transition: background .15s ease, color .15s ease;
}
.mobile-nav-body a:hover,
.mobile-nav-body a:active { background: var(--cc-blue-soft); color: var(--cc-blue); }

.mobile-nav-foot {
    border-top: 1px solid var(--cc-border);
    flex: 0 0 auto;
    padding: 14px 18px 18px;
}
.mobile-nav-foot .button { width: 100%; }

/* ====================== buttons ====================== */
.button {
    align-items: center;
    border: 1px solid transparent;
    border-radius: 999px;
    cursor: pointer;
    display: inline-flex;
    font: inherit;
    font-weight: 700;
    gap: 8px;
    justify-content: center;
    line-height: 1;
    padding: 14px 22px;
    transition: transform .12s ease, box-shadow .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
    white-space: nowrap;
}
.button-primary {
    background: var(--cc-blue);
    box-shadow: var(--cc-shadow-glow);
    color: var(--cc-white);
}
.button-primary:hover {
    background: var(--cc-blue-dark);
    transform: translateY(-1px);
}
.button-ghost {
    background: var(--cc-white);
    border-color: var(--cc-border-strong);
    color: var(--cc-navy);
}
.button-ghost:hover {
    border-color: var(--cc-blue);
    color: var(--cc-blue);
}
.button-ghost-light {
    background: transparent;
    border-color: rgba(255, 255, 255, 0.4);
    color: var(--cc-white);
}
.button-ghost-light:hover { background: rgba(255, 255, 255, 0.1); }

.button-primary-sm, .button-ghost-sm {
    border-radius: 999px;
    font-size: 0.86rem;
    font-weight: 700;
    padding: 9px 16px;
}
.button-primary-sm {
    background: var(--cc-blue);
    color: var(--cc-white);
}
.button-primary-sm:hover { background: var(--cc-blue-dark); }
.button-ghost-sm {
    align-items: center;
    border: 1px solid var(--cc-border-strong);
    color: var(--cc-navy);
    display: inline-flex;
    gap: 6px;
}
.button-ghost-sm:hover {
    border-color: var(--cc-blue);
    color: var(--cc-blue);
}

.button-secondary {
    background: var(--cc-white);
    border-color: var(--cc-border-strong);
    color: var(--cc-navy);
}
.button-secondary:hover {
    border-color: var(--cc-blue);
    color: var(--cc-blue);
}

/* ====================== layout bands ====================== */
.band {
    margin: 0 auto;
    max-width: var(--maxw);
    padding: 92px 6vw;
}
.band-tint { background: var(--cc-ice); max-width: none; }
.band-tint > * {
    margin-left: auto;
    margin-right: auto;
    max-width: var(--maxw);
}
.band-dark {
    background:
        radial-gradient(800px 380px at 80% -10%, rgba(56, 191, 167, 0.18), transparent 60%),
        radial-gradient(900px 480px at 10% 110%, rgba(23, 105, 224, 0.25), transparent 60%),
        var(--cc-navy);
    color: var(--cc-white);
    max-width: none;
}
.band-dark > * {
    margin-left: auto;
    margin-right: auto;
    max-width: var(--maxw);
}
.band-dark h2 { color: var(--cc-white); }

.section-heading { max-width: 720px; }
.section-heading.center { margin-left: auto; margin-right: auto; text-align: center; }
.section-heading.center .lede { margin-left: auto; margin-right: auto; }
.section-heading.on-dark h2 { color: var(--cc-white); }
.section-heading.on-dark .lede { color: rgba(255, 255, 255, 0.75); }

.action-row {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

/* ====================== hero ====================== */
.hero {
    background:
        radial-gradient(700px 340px at 90% 10%, rgba(56, 191, 167, 0.12), transparent 60%),
        radial-gradient(900px 460px at 0% 100%, rgba(23, 105, 224, 0.1), transparent 60%),
        var(--cc-white);
    overflow: hidden;
    padding: 72px 6vw 96px;
}
.hero-grid {
    align-items: center;
    display: grid;
    gap: 56px;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    margin: 0 auto;
    max-width: var(--maxw);
}
.hero-copy { max-width: 600px; }
.hero-copy h1 { margin: 18px 0 22px; }
.hero-lede {
    color: var(--cc-muted);
    font-size: 1.12rem;
    max-width: 540px;
}
.hero-bullets {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 32px;
    max-width: 480px;
}
.hero-bullets li {
    align-items: center;
    color: var(--cc-navy);
    display: flex;
    font-size: 0.94rem;
    font-weight: 600;
    gap: 8px;
}
.check {
    align-items: center;
    background: var(--cc-mint-soft);
    border-radius: 999px;
    color: var(--cc-success);
    display: inline-flex;
    font-size: 0.74rem;
    font-weight: 800;
    height: 22px;
    justify-content: center;
    width: 22px;
}

.hero-visual {
    aspect-ratio: 1 / 1.04;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr) minmax(0, 1fr);
    max-width: 560px;
    position: relative;
}
.hero-image {
    background-color: var(--cc-ice);
    background-position: center;
    background-size: cover;
    border-radius: var(--cc-radius-lg);
    box-shadow: var(--cc-shadow);
    overflow: hidden;
}
.hero-image-main { grid-column: 1; grid-row: 1 / span 2; }
.hero-image-a { grid-column: 2; grid-row: 1; }
.hero-image-b { grid-column: 2; grid-row: 2; }

.hero-floating-card {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius);
    box-shadow: var(--cc-shadow-lg);
    bottom: -18px;
    display: grid;
    gap: 8px;
    left: -24px;
    max-width: 240px;
    padding: 16px 18px;
    position: absolute;
}
.hero-floating-rating {
    align-items: center;
    color: var(--cc-warning);
    display: flex;
    font-size: 0.86rem;
    gap: 6px;
}
.hero-floating-rating strong { color: var(--cc-navy); font-size: 0.96rem; }
.stars { color: #f5b942; letter-spacing: 1px; }
.hero-floating-card p {
    color: var(--cc-navy);
    font-size: 0.92rem;
    line-height: 1.4;
    margin: 0;
}
.hero-floating-name {
    color: var(--cc-muted);
    font-size: 0.78rem;
    font-weight: 600;
}

.hero-floating-badge {
    align-items: center;
    background: var(--cc-navy);
    border-radius: var(--cc-radius);
    box-shadow: var(--cc-shadow-lg);
    color: var(--cc-white);
    display: flex;
    gap: 10px;
    padding: 12px 16px;
    position: absolute;
    right: -18px;
    top: -14px;
}
.hero-floating-badge strong {
    color: var(--cc-mint);
    font-family: Fraunces, Georgia, serif;
    font-size: 1.7rem;
    font-weight: 600;
}
.hero-floating-badge span {
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.78rem;
    line-height: 1.2;
    max-width: 110px;
}

/* ====================== trust strip ====================== */
.trust-strip {
    background: var(--cc-white);
    border-bottom: 1px solid var(--cc-border);
    border-top: 1px solid var(--cc-border);
    padding: 0 6vw;
}
.trust-strip-inner {
    display: grid;
    gap: 0;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin: 0 auto;
    max-width: var(--maxw);
}
.trust-pill {
    align-items: center;
    border-left: 1px solid var(--cc-border);
    display: flex;
    gap: 14px;
    padding: 22px 18px;
}
.trust-pill:first-child { border-left: 0; }
.trust-pill-icon {
    align-items: center;
    background: var(--cc-blue-soft);
    border-radius: 999px;
    color: var(--cc-blue);
    display: inline-flex;
    font-size: 1rem;
    font-weight: 800;
    height: 38px;
    justify-content: center;
    width: 38px;
}
.trust-pill strong { color: var(--cc-navy); display: block; font-size: 0.95rem; }
.trust-pill span { color: var(--cc-muted); font-size: 0.84rem; }

/* ====================== services ====================== */
.service-grid {
    display: grid;
    gap: 22px;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    margin-top: 48px;
}
.service-card {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius-lg);
    display: flex;
    flex-direction: column;
    grid-column: span 2;
    overflow: hidden;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.service-card:hover {
    border-color: var(--cc-blue-soft);
    box-shadow: var(--cc-shadow-lg);
    transform: translateY(-3px);
}
.service-card-feature {
    grid-column: span 6;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
}
.service-card-image {
    background-color: var(--cc-ice);
    background-position: center;
    background-size: cover;
    min-height: 260px;
    position: relative;
}
.service-card-image.short { min-height: 180px; }
.service-card-tag {
    background: var(--cc-white);
    border-radius: 999px;
    box-shadow: var(--cc-shadow-sm);
    color: var(--cc-blue);
    font-size: 0.74rem;
    font-weight: 700;
    left: 16px;
    letter-spacing: 0.08em;
    padding: 6px 10px;
    position: absolute;
    text-transform: uppercase;
    top: 16px;
}
.service-card-body {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 12px;
    padding: 24px 24px 22px;
}
.service-card-feature .service-card-body { padding: 36px; }
.service-card-eyebrow {
    color: var(--cc-mint);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}
.service-card-feature h3 {
    font-family: Fraunces, Georgia, serif;
    font-size: 1.8rem;
    font-weight: 600;
}
.service-card h3 { color: var(--cc-navy); font-size: 1.18rem; }
.service-card p { color: var(--cc-muted); font-size: 0.95rem; }
.service-card-list {
    color: var(--cc-slate);
    display: grid;
    gap: 6px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 6px;
}
.service-card-list li {
    align-items: center;
    color: var(--cc-navy);
    display: flex;
    font-size: 0.9rem;
    font-weight: 600;
    gap: 8px;
    padding-left: 14px;
    position: relative;
}
.service-card-list li::before {
    background: var(--cc-mint);
    border-radius: 999px;
    content: "";
    height: 6px;
    left: 0;
    position: absolute;
    top: 9px;
    width: 6px;
}
.service-card-foot {
    align-items: center;
    border-top: 1px solid var(--cc-border);
    display: flex;
    gap: 12px;
    justify-content: space-between;
    margin-top: auto;
    padding-top: 16px;
}
.service-card-price {
    color: var(--cc-navy);
    font-weight: 800;
}
.link-arrow {
    align-items: center;
    color: var(--cc-blue);
    display: inline-flex;
    font-weight: 700;
    gap: 4px;
    transition: gap .15s ease;
}
.link-arrow:hover { gap: 8px; }

/* ====================== why ====================== */
.why-grid {
    display: grid;
    gap: 56px;
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
}
.why-copy h2 { margin-top: 14px; }
.why-copy p { color: var(--cc-muted); margin-top: 18px; }
.why-cards {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.why-card {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius);
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 22px;
    transition: border-color .15s ease, transform .15s ease;
}
.why-card:hover {
    border-color: var(--cc-blue-soft);
    transform: translateY(-2px);
}
.why-card-icon {
    align-items: center;
    background: var(--cc-blue-soft);
    border-radius: 10px;
    color: var(--cc-blue);
    display: inline-flex;
    height: 44px;
    justify-content: center;
    margin-bottom: 4px;
    width: 44px;
}
.why-card h3 { color: var(--cc-navy); font-size: 1.05rem; }
.why-card p { color: var(--cc-muted); font-size: 0.92rem; }

/* ====================== how steps ====================== */
.how-steps {
    counter-reset: step;
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 48px;
}
.how-steps li {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius);
    padding: 24px;
    position: relative;
}
.step-num {
    background: linear-gradient(140deg, var(--cc-blue), var(--cc-mint));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    font-family: Fraunces, Georgia, serif;
    font-size: 1.8rem;
    font-weight: 700;
}
.how-steps h3 { margin-top: 8px; }
.how-steps p { color: var(--cc-muted); font-size: 0.94rem; margin-top: 8px; }
.how-cta {
    align-items: center;
    display: flex;
    gap: 16px;
    justify-content: center;
    margin-top: 36px;
}
.how-cta-note { color: var(--cc-muted); font-size: 0.9rem; }

/* ====================== testimonials ====================== */
.testimonial-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 48px;
}
.testimonial {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--cc-radius);
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 28px;
}
.testimonial .stars { font-size: 1.05rem; }
.testimonial blockquote {
    color: var(--cc-white);
    font-family: Fraunces, Georgia, serif;
    font-size: 1.08rem;
    font-weight: 500;
    line-height: 1.5;
}
.testimonial figcaption {
    color: rgba(255, 255, 255, 0.7);
    display: flex;
    flex-direction: column;
    font-size: 0.86rem;
    margin-top: 4px;
}
.testimonial figcaption strong { color: var(--cc-white); font-weight: 700; }

/* ====================== pricing ====================== */
.pricing-wrap {
    display: grid;
    gap: 56px;
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
}
.pricing-table {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius);
    box-shadow: var(--cc-shadow);
    overflow: hidden;
}
.pricing-table > div {
    align-items: center;
    border-bottom: 1px solid var(--cc-border);
    display: flex;
    gap: 18px;
    justify-content: space-between;
    padding: 20px 24px;
}
.pricing-table > div:last-child { border-bottom: 0; }
.pricing-table > div > div { display: grid; gap: 4px; }
.pricing-row-label { color: var(--cc-navy); font-weight: 700; }
.pricing-row-note { color: var(--cc-muted); font-size: 0.86rem; }
.pricing-row-amt {
    color: var(--cc-blue);
    font-family: Fraunces, Georgia, serif;
    font-size: 1.2rem;
    font-weight: 600;
    white-space: nowrap;
}
.pricing-fine {
    color: var(--cc-muted);
    font-size: 0.84rem;
    margin-top: 22px;
    max-width: 720px;
}

/* ====================== about ====================== */
.about-grid {
    align-items: center;
    display: grid;
    gap: 56px;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
}
.about-image {
    aspect-ratio: 4 / 5;
    background-position: center;
    background-size: cover;
    border-radius: var(--cc-radius-lg);
    box-shadow: var(--cc-shadow);
}
.about-copy h2 { margin-top: 14px; }
.about-copy p { color: var(--cc-muted); margin-top: 18px; }
.about-stats {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 32px;
}
.about-stats > div {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius);
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 18px;
}
.about-stats strong {
    color: var(--cc-blue);
    font-family: Fraunces, Georgia, serif;
    font-size: 1.8rem;
    font-weight: 600;
}
.about-stats span { color: var(--cc-muted); font-size: 0.84rem; }

/* ====================== service areas ====================== */
.area-pills {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    margin-top: 40px;
}
.area-pills a {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius);
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 18px;
    transition: border-color .15s ease, transform .12s ease;
}
.area-pills a:hover {
    border-color: var(--cc-blue);
    transform: translateY(-2px);
}
.area-pills span { color: var(--cc-navy); font-weight: 700; }
.area-pills em {
    color: var(--cc-muted);
    font-size: 0.8rem;
    font-style: normal;
}

/* ====================== faq ====================== */
.faq-grid {
    display: grid;
    gap: 56px;
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
}
.faq-grid h2 { margin-top: 14px; }
.faq-list { display: flex; flex-direction: column; gap: 12px; }
.faq-list details {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius);
    padding: 0;
    transition: border-color .15s ease;
}
.faq-list details[open] { border-color: var(--cc-blue-soft); }
.faq-list summary {
    color: var(--cc-navy);
    cursor: pointer;
    font-weight: 700;
    list-style: none;
    padding: 18px 22px;
    position: relative;
}
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary::after {
    color: var(--cc-blue);
    content: "+";
    font-size: 1.4rem;
    font-weight: 600;
    position: absolute;
    right: 22px;
    top: 50%;
    transform: translateY(-50%);
    transition: transform .2s ease;
}
.faq-list details[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.faq-list details p {
    color: var(--cc-muted);
    padding: 0 22px 20px;
}

/* ====================== cta band ====================== */
.cta-band { padding-bottom: 92px; }
.cta-card {
    align-items: center;
    background:
        radial-gradient(700px 320px at 100% 0%, rgba(56, 191, 167, 0.22), transparent 60%),
        radial-gradient(700px 320px at 0% 100%, rgba(23, 105, 224, 0.3), transparent 60%),
        var(--cc-navy);
    border-radius: var(--cc-radius-lg);
    color: var(--cc-white);
    display: grid;
    gap: 32px;
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 0.7fr);
    padding: 56px;
}
.cta-card h2 { color: var(--cc-white); margin-top: 10px; }
.cta-card p { color: rgba(255, 255, 255, 0.78); margin-top: 14px; max-width: 560px; }
.cta-actions {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.cta-actions .button { width: 100%; }

/* ====================== footer ====================== */
.site-footer {
    background: var(--cc-navy);
    color: rgba(255, 255, 255, 0.75);
    padding: 64px 6vw 24px;
}
.footer-inner {
    display: grid;
    gap: 36px;
    grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
    margin: 0 auto;
    max-width: var(--maxw);
}
.footer-brand p { color: rgba(255, 255, 255, 0.6); font-size: 0.92rem; margin-top: 18px; }
.footer-brand .brand { color: var(--cc-white); }
.footer-brand .brand-name { color: var(--cc-white); }
.footer-brand .brand-sub { color: rgba(255, 255, 255, 0.5); }
.footer-meta {
    color: rgba(255, 255, 255, 0.45);
    font-size: 0.82rem;
    margin-top: 10px;
}
.footer-col { display: flex; flex-direction: column; gap: 10px; }
.footer-col h4 {
    color: var(--cc-white);
    font-size: 0.86rem;
    letter-spacing: 0.08em;
    margin-bottom: 6px;
    text-transform: uppercase;
}
.footer-col a {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.92rem;
    transition: color .15s ease;
}
.footer-col a:hover { color: var(--cc-mint); }
.footer-base {
    align-items: center;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.45);
    display: flex;
    flex-wrap: wrap;
    font-size: 0.82rem;
    gap: 16px;
    justify-content: space-between;
    margin: 56px auto 0;
    max-width: var(--maxw);
    padding-top: 22px;
}
.footer-links a { color: rgba(255, 255, 255, 0.6); font-size: 0.84rem; }
.footer-links a:hover { color: var(--cc-mint); }

/* ====================== service detail page ====================== */
.service-hero {
    background:
        radial-gradient(700px 340px at 90% 10%, rgba(56, 191, 167, 0.12), transparent 60%),
        radial-gradient(900px 460px at 0% 100%, rgba(23, 105, 224, 0.08), transparent 60%),
        var(--cc-white);
    padding: 60px 6vw 88px;
}
.service-hero-grid {
    align-items: center;
    display: grid;
    gap: 56px;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    margin: 0 auto;
    max-width: var(--maxw);
}
.service-hero-copy h1 { margin: 18px 0 22px; font-size: clamp(2rem, 2.6vw + 1rem, 3.4rem); }
.crumbs {
    align-items: center;
    color: var(--cc-muted);
    display: flex;
    font-size: 0.84rem;
    gap: 8px;
    margin-bottom: 18px;
}
.crumbs a { color: var(--cc-blue); font-weight: 600; }
.crumbs a:hover { text-decoration: underline; }
.crumbs span[aria-current] { color: var(--cc-navy); font-weight: 600; }
.service-hero-meta {
    border-top: 1px solid var(--cc-border);
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 36px;
    padding-top: 24px;
}
.service-hero-meta-label {
    color: var(--cc-muted);
    display: block;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    margin-bottom: 4px;
    text-transform: uppercase;
}
.service-hero-meta strong {
    color: var(--cc-navy);
    font-size: 0.98rem;
}
.service-hero-visual {
    aspect-ratio: 4 / 5;
    background-color: var(--cc-ice);
    background-position: center;
    background-size: cover;
    border-radius: var(--cc-radius-lg);
    box-shadow: var(--cc-shadow);
    position: relative;
}
.service-hero-visual .hero-floating-card {
    bottom: -22px;
    left: -22px;
}

.service-detail-grid {
    display: grid;
    gap: 48px;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
}
.check-list {
    display: grid;
    gap: 12px;
    margin-top: 28px;
}
.check-list li {
    align-items: flex-start;
    color: var(--cc-navy);
    display: flex;
    font-weight: 500;
    gap: 10px;
}
.check-list .check { margin-top: 3px; flex: 0 0 22px; }

.best-for-card {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius-lg);
    box-shadow: var(--cc-shadow);
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 28px;
    position: sticky;
    top: 100px;
}
.best-for-card h3 { font-size: 1.2rem; margin-top: 6px; }
.dot-list { display: grid; gap: 8px; }
.dot-list li {
    color: var(--cc-slate);
    font-size: 0.94rem;
    padding-left: 18px;
    position: relative;
}
.dot-list li::before {
    background: var(--cc-mint);
    border-radius: 999px;
    content: "";
    height: 6px;
    left: 0;
    position: absolute;
    top: 9px;
    width: 6px;
}
.best-for-card .button { margin-top: 8px; }

.addon-table > div {
    align-items: center;
    border-bottom: 1px solid var(--cc-border);
    display: flex;
    gap: 18px;
    justify-content: space-between;
    padding: 18px 24px;
}

.other-services-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 40px;
}
.other-service-card {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius);
    color: var(--cc-navy);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.other-service-card:hover {
    border-color: var(--cc-blue-soft);
    box-shadow: var(--cc-shadow-lg);
    transform: translateY(-3px);
}
.other-service-image {
    aspect-ratio: 4 / 3;
    background-color: var(--cc-ice);
    background-position: center;
    background-size: cover;
}
.other-service-body { display: flex; flex-direction: column; gap: 8px; padding: 18px 20px 22px; }
.other-service-eyebrow {
    color: var(--cc-mint);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}
.other-service-card h3 { color: var(--cc-navy); font-size: 1.04rem; }
.other-service-card .link-arrow { margin-top: 4px; }

/* ====================== forms (quote + referrals) ====================== */
.quote-hero {
    background:
        radial-gradient(700px 340px at 90% 10%, rgba(56, 191, 167, 0.12), transparent 60%),
        radial-gradient(900px 460px at 0% 100%, rgba(23, 105, 224, 0.1), transparent 60%),
        var(--cc-white);
    padding: 32px 6vw 18px;
}
.quote-hero-compact { padding: 26px 6vw 14px; }
.quote-hero-compact h1 {
    font-size: clamp(1.6rem, 1.6vw + 0.8rem, 2.2rem);
    margin: 8px auto 0;
}
.quote-hero-inner {
    margin: 0 auto;
    max-width: var(--maxw);
    text-align: center;
}
.quote-hero-inner h1 {
    margin: 12px auto 8px;
    max-width: 820px;
}
.quote-hero-inner .hero-lede {
    margin: 0 auto;
    max-width: 680px;
}
.quote-hero-points {
    display: flex;
    flex-wrap: wrap;
    gap: 14px 28px;
    justify-content: center;
    margin: 18px auto 0;
    max-width: 760px;
}
.quote-hero-points li {
    align-items: center;
    color: var(--cc-navy);
    display: inline-flex;
    font-size: 0.92rem;
    font-weight: 600;
    gap: 8px;
}

.page-band {
    background:
        radial-gradient(700px 320px at 100% 0%, rgba(56, 191, 167, 0.08), transparent 60%),
        radial-gradient(800px 380px at 0% 100%, rgba(23, 105, 224, 0.06), transparent 60%),
        var(--cc-ice);
    padding: 28px 6vw 56px;
}
.page-band > * {
    margin-left: auto;
    margin-right: auto;
    max-width: var(--maxw);
}
.quote-builder-page {
    align-items: start;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 380px);
}
.quote-builder-page > .quote-form { margin: 0; max-width: none; padding: 28px; }
.quote-builder-page > * { max-width: none; }

.quote-rail-sticky {
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: sticky;
    top: 96px;
}
.quote-rail .estimate-panel {
    align-items: stretch;
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius-lg);
    box-shadow: var(--cc-shadow-lg);
    color: var(--cc-navy);
    display: flex;
    flex-direction: column;
    gap: 6px;
    grid-template-columns: none;
    margin: 0;
    padding: 22px;
    transition: background .25s ease, box-shadow .25s ease;
}
.estimate-panel-head {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: 4px;
}
.estimate-panel-head .eyebrow,
.estimate-panel-head .eyebrow-light { color: var(--cc-muted); }
.estimate-badge {
    background: var(--cc-ice-2);
    border-radius: 999px;
    color: var(--cc-muted);
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    padding: 4px 10px;
    text-transform: uppercase;
}
.estimate-panel #estimate-price {
    color: var(--cc-muted-2);
    font-family: Fraunces, Georgia, serif;
    font-size: 2.1rem;
    font-weight: 600;
    letter-spacing: -0.01em;
    line-height: 1;
    margin-top: 2px;
}
.estimate-panel #estimate-time {
    color: var(--cc-muted);
    font-size: 0.9rem;
    font-weight: 600;
    margin-top: 4px;
}
.estimate-panel #estimate-message {
    color: var(--cc-muted);
    font-size: 0.88rem;
    line-height: 1.5;
    margin: 12px 0 4px;
}
.estimate-cta { margin-top: 12px; width: 100%; }
.estimate-panel .form-fine { margin-top: 10px; }
.estimate-panel .form-status { font-size: 0.86rem; margin-top: 8px; }

.quote-rail .estimate-locked #estimate-price { color: var(--cc-muted-2); }
.quote-rail .estimate-ready {
    background: linear-gradient(180deg, #fbfdff, var(--cc-blue-soft));
    border-color: #cfe3ff;
}
.quote-rail .estimate-ready .estimate-badge { background: var(--cc-blue); color: var(--cc-white); }
.quote-rail .estimate-ready #estimate-price { color: var(--cc-navy); }

.quote-rail .estimate-revealed {
    background: linear-gradient(160deg, var(--cc-navy), var(--cc-navy-soft));
    border-color: transparent;
    box-shadow: 0 18px 44px rgba(14, 26, 48, 0.22);
}
.quote-rail .estimate-revealed .estimate-panel-head .eyebrow { color: rgba(255, 255, 255, 0.7); }
.quote-rail .estimate-revealed .estimate-badge { background: var(--cc-mint); color: var(--cc-navy); }
.quote-rail .estimate-revealed #estimate-price { color: var(--cc-white); }
.quote-rail .estimate-revealed #estimate-time { color: var(--cc-mint); }
.quote-rail .estimate-revealed #estimate-message { color: rgba(255, 255, 255, 0.72); }
.quote-rail .estimate-revealed .form-fine { color: rgba(255, 255, 255, 0.55); }
.quote-rail .estimate-revealed .form-status { color: var(--cc-mint); }
.quote-rail .estimate-revealed .estimate-cta {
    background: rgba(255, 255, 255, 0.16);
    box-shadow: none;
    color: var(--cc-white);
    opacity: 0.7;
}

.rail-next {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius);
    padding: 18px 20px;
}
.rail-next h4 {
    color: var(--cc-navy);
    font-size: 0.86rem;
    letter-spacing: 0.08em;
    margin-bottom: 12px;
    text-transform: uppercase;
}
.rail-next-list {
    counter-reset: rnx;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.rail-next-list li {
    counter-increment: rnx;
    padding-left: 28px;
    position: relative;
}
.rail-next-list li::before {
    align-items: center;
    background: var(--cc-blue-soft);
    border-radius: 999px;
    color: var(--cc-blue);
    content: counter(rnx);
    display: flex;
    font-size: 0.72rem;
    font-weight: 800;
    height: 20px;
    justify-content: center;
    left: 0;
    position: absolute;
    top: 1px;
    width: 20px;
}
.rail-next-list strong { color: var(--cc-navy); display: block; font-size: 0.88rem; }
.rail-next-list span { color: var(--cc-muted); display: block; font-size: 0.82rem; margin-top: 1px; }

.rail-trust {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.rail-trust span {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius-sm);
    display: flex;
    flex-direction: column;
    font-size: 0.74rem;
    color: var(--cc-muted);
    padding: 10px 8px;
    text-align: center;
    gap: 2px;
}
.rail-trust strong { color: var(--cc-blue); font-size: 0.92rem; }

/* ====================== addons (extras section) ====================== */
.addon-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.addon-card {
    align-items: center;
    background: var(--cc-white);
    border: 1.5px solid var(--cc-border);
    border-radius: var(--cc-radius);
    cursor: pointer;
    display: grid;
    gap: 10px 12px;
    grid-template-columns: 36px minmax(0, 1fr) auto;
    margin: 0;
    padding: 12px 14px;
    transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.addon-card input {
    height: 16px;
    margin: 0;
    min-height: 16px;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    width: 16px;
}
.addon-card:hover { border-color: var(--cc-blue); }
.addon-card:has(input:checked) {
    background: var(--cc-blue-soft);
    border-color: var(--cc-blue);
    box-shadow: 0 0 0 4px rgba(23, 105, 224, 0.1);
}
.addon-icon {
    align-items: center;
    background: var(--cc-blue-soft);
    border-radius: 10px;
    color: var(--cc-blue);
    display: inline-flex;
    height: 36px;
    justify-content: center;
    transition: background .15s ease;
    width: 36px;
}
.addon-card:has(input:checked) .addon-icon { background: var(--cc-white); }
.addon-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.addon-body strong {
    color: var(--cc-navy);
    font-size: 0.94rem;
    font-weight: 700;
    line-height: 1.25;
}
.addon-body span {
    color: var(--cc-muted);
    font-size: 0.78rem;
    font-weight: 500;
}
.addon-price {
    color: var(--cc-muted);
    font-size: 0.84rem;
    font-weight: 800;
    letter-spacing: 0.01em;
}
.addon-card:has(input:checked) .addon-price { color: var(--cc-blue); }

/* ====================== rail summary (live selections) ====================== */
.rail-summary {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius-lg);
    box-shadow: var(--cc-shadow);
    padding: 18px 20px 6px;
}
.rail-summary-head { margin-bottom: 10px; }
.rail-summary-head .eyebrow,
.rail-summary-head .eyebrow-light { color: var(--cc-muted); }
.rail-summary-list {
    display: flex;
    flex-direction: column;
    margin: 0;
}
.rail-summary-row {
    align-items: baseline;
    border-top: 1px solid var(--cc-border);
    display: grid;
    gap: 10px;
    grid-template-columns: 64px minmax(0, 1fr);
    padding: 10px 0;
}
.rail-summary-row:first-child { border-top: 0; }
.rail-summary-row dt {
    color: var(--cc-muted);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.rail-summary-row dd {
    color: var(--cc-navy);
    font-size: 0.9rem;
    font-weight: 600;
    margin: 0;
    overflow-wrap: anywhere;
}
.rail-summary-row dd.is-pending {
    color: var(--cc-muted-2);
    font-weight: 500;
}

/* ====================== rail perks (unlock ladder) ====================== */
.rail-perks {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius-lg);
    padding: 16px 18px;
}
.rail-perks-head {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-bottom: 10px;
}
.rail-perks-head .eyebrow,
.rail-perks-head .eyebrow-light { color: var(--cc-muted); }
.rail-perks-hint {
    color: var(--cc-navy);
    font-size: 0.84rem;
    font-weight: 600;
}
.rail-perks-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: 0;
    padding: 0;
}
.perk-row {
    align-items: center;
    display: grid;
    gap: 10px;
    grid-template-columns: 22px minmax(0, 1fr);
    opacity: 0.55;
    transition: opacity .2s ease;
}
.perk-row.is-unlocked { opacity: 1; }
.perk-icon {
    align-items: center;
    background: var(--cc-ice-2);
    border: 1px solid var(--cc-border);
    border-radius: 999px;
    display: inline-flex;
    height: 22px;
    justify-content: center;
    width: 22px;
}
.perk-row.is-unlocked .perk-icon {
    background: var(--cc-mint);
    border-color: var(--cc-mint);
}
.perk-icon::after {
    color: var(--cc-muted-2);
    content: "○";
    font-size: 0.8rem;
    font-weight: 700;
    line-height: 1;
}
.perk-row.is-unlocked .perk-icon::after {
    color: var(--cc-white);
    content: "✓";
    font-size: 0.78rem;
}
.perk-text { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.perk-text strong {
    color: var(--cc-navy);
    font-size: 0.86rem;
    font-weight: 700;
    line-height: 1.25;
}
.perk-text em {
    color: var(--cc-muted);
    font-size: 0.76rem;
    font-style: normal;
    font-weight: 600;
}
.perk-row.is-unlocked .perk-text em { color: var(--cc-success); }

.section-heading.quote-heading,
.section-heading.referral-heading {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}
.quote-heading h1, .referral-page h1 {
    font-size: clamp(2.4rem, 3vw + 1rem, 3.4rem);
    margin: 18px 0 12px;
}
.quote-heading p, .referral-hero p { color: var(--cc-muted); }

.quote-form {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius-lg);
    box-shadow: var(--cc-shadow);
    margin: 36px auto 0;
    max-width: 880px;
    padding: 36px;
}

.form-section {
    border-bottom: 1px solid var(--cc-border);
    margin-bottom: 24px;
    padding-bottom: 24px;
    position: relative;
}
.form-section:last-of-type { border-bottom: 0; margin-bottom: 0; padding-bottom: 0; }
.form-section h2 {
    font-family: Inter, sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    margin-bottom: 0;
    margin-top: 0;
}
.form-section-head {
    align-items: center;
    display: flex;
    gap: 12px;
    margin-bottom: 16px;
}
.form-section-head .form-section-help {
    color: var(--cc-muted);
    font-size: 0.86rem;
    margin: 4px 0 0;
}
.step-badge {
    align-items: center;
    background: var(--cc-blue-soft);
    border-radius: 10px;
    color: var(--cc-blue);
    display: inline-flex;
    flex: 0 0 36px;
    font-size: 0.8rem;
    font-weight: 800;
    height: 36px;
    justify-content: center;
    letter-spacing: 0.04em;
    width: 36px;
}
.step-number {
    background: var(--cc-blue-soft);
    border-radius: 999px;
    color: var(--cc-blue);
    display: inline-block;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    margin-bottom: 12px;
    padding: 5px 10px;
}

.form-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.form-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
/* .req styles live in the quote-helpers section near .label-row */
.contact-hint {
    background: var(--cc-blue-soft);
    border-radius: 10px;
    color: var(--cc-blue);
    font-size: 0.86rem;
    font-weight: 600;
    margin: 6px 0 14px;
    padding: 10px 14px;
}
.contact-hint.is-ok { background: var(--cc-mint-soft); color: var(--cc-success); }
.choice-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.choice-card {
    background: var(--cc-white);
    border: 1.5px solid var(--cc-border);
    border-radius: var(--cc-radius);
    cursor: pointer;
    display: grid;
    gap: 6px;
    min-height: 110px;
    padding: 18px;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.choice-card input {
    height: 16px;
    min-height: 16px;
    width: 16px;
}
.choice-card:has(input:checked) {
    background: var(--cc-blue-soft);
    border-color: var(--cc-blue);
    box-shadow: 0 0 0 4px rgba(23, 105, 224, 0.1);
}
.choice-card strong { color: var(--cc-navy); font-size: 1rem; }
.choice-card span { color: var(--cc-muted); font-size: 0.86rem; }
.small-choice { min-height: 88px; }
.service-levels { margin-top: 14px; }

.calendar-strip {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}
.when-row {
    align-items: end;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1.4fr) minmax(180px, 1fr);
    margin-top: 14px;
}
.when-row .date-popover-wrap { margin-top: 0; }
.when-row .when-time { margin-bottom: 0; }
.room-grid { margin-top: 18px; }
.date-option {
    background: var(--cc-white);
    border: 1.5px solid var(--cc-border);
    border-radius: var(--cc-radius-sm);
    color: var(--cc-navy);
    cursor: pointer;
    display: grid;
    font: inherit;
    gap: 2px;
    min-height: 76px;
    padding: 10px;
    text-align: left;
    transition: border-color .15s ease;
}
.date-option strong { color: var(--cc-blue); }
.date-option span { color: var(--cc-muted); font-size: 0.78rem; }
.date-option[disabled] {
    background: var(--cc-ice-2);
    color: var(--cc-muted-2);
    cursor: not-allowed;
}
.date-option.selected {
    background: var(--cc-blue);
    border-color: var(--cc-blue);
    color: var(--cc-white);
}
.date-option.selected strong, .date-option.selected span { color: var(--cc-white); }

.estimate-panel {
    align-items: center;
    background: linear-gradient(135deg, var(--cc-navy), var(--cc-navy-soft));
    border-radius: var(--cc-radius);
    color: var(--cc-white);
    display: grid;
    gap: 16px;
    grid-template-columns: minmax(220px, 0.8fr) minmax(0, 1fr);
    margin: 8px 0 22px;
    padding: 26px;
}
.estimate-panel p { color: rgba(255, 255, 255, 0.78); margin: 0; }
.estimate-panel strong {
    color: var(--cc-white);
    display: block;
    font-family: Fraunces, Georgia, serif;
    font-size: 2rem;
    font-weight: 600;
}
.estimate-panel span {
    color: var(--cc-mint);
    display: block;
    font-weight: 700;
    margin-top: 6px;
}
.estimate-locked {
    background: linear-gradient(135deg, #f8fbff, var(--cc-blue-soft));
    border: 1px solid #cfe2ff;
}
.estimate-locked p { color: var(--cc-muted); }
.estimate-locked strong { color: var(--cc-navy); opacity: 0.6; }
.estimate-locked span { color: var(--cc-blue); }
.estimate-live {
    background: linear-gradient(135deg, var(--cc-navy), var(--cc-navy-soft));
    box-shadow: 0 16px 36px rgba(23, 105, 224, 0.18);
}
.estimate-saved {
    background: linear-gradient(135deg, #0f3d2b, #176a4a);
}
.estimate-saved span { color: #b9f0d8; }

label {
    color: var(--cc-navy);
    display: grid;
    font-size: 0.86rem;
    font-weight: 700;
    gap: 8px;
    margin-bottom: 16px;
}
input, select, textarea {
    background: var(--cc-white);
    border: 1.5px solid var(--cc-border);
    border-radius: var(--cc-radius-sm);
    color: var(--cc-navy);
    font: inherit;
    font-weight: 500;
    min-height: 46px;
    padding: 10px 14px;
    width: 100%;
    transition: border-color .15s ease, box-shadow .15s ease;
}
input::placeholder, textarea::placeholder { color: var(--cc-muted-2); }
textarea { resize: vertical; }
input:focus, select:focus, textarea:focus {
    border-color: var(--cc-blue);
    box-shadow: 0 0 0 4px rgba(23, 105, 224, 0.12);
    outline: none;
}

.form-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 8px;
}
.form-status {
    color: var(--cc-success);
    font-weight: 700;
    margin: 14px 0 0;
}
.form-status.is-error { color: var(--cc-error); }

/* ====================== quote helpers ====================== */
/* number stepper used for room counts on the quote form. The native input
   stays in the DOM (so form submission is unchanged) but is readonly and
   purely a value display; the – / + buttons drive it via JS. Big tap
   targets so it works without a keyboard on mobile. */
.stepper {
    align-items: stretch;
    background: var(--cc-white);
    border: 1.5px solid var(--cc-border);
    border-radius: var(--cc-radius-sm);
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) 44px;
    overflow: hidden;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.stepper:focus-within {
    border-color: var(--cc-blue);
    box-shadow: 0 0 0 4px rgba(23, 105, 224, 0.12);
}
.stepper input[type="number"] {
    background: var(--cc-white);
    border: 0;
    border-radius: 0;
    color: var(--cc-navy);
    font-size: 1.05rem;
    font-weight: 700;
    min-height: 0;
    padding: 0;
    text-align: center;
    /* hide native spinner buttons since we have our own */
    -moz-appearance: textfield;
}
.stepper input[type="number"]::-webkit-outer-spin-button,
.stepper input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.stepper input[type="number"]:focus {
    box-shadow: none;
    outline: none;
}
.stepper-btn {
    align-items: center;
    background: var(--cc-ice);
    border: 0;
    color: var(--cc-navy);
    cursor: pointer;
    display: inline-flex;
    font: inherit;
    font-size: 1.25rem;
    font-weight: 700;
    justify-content: center;
    line-height: 1;
    padding: 0;
    transition: background .15s ease, color .15s ease;
    -webkit-tap-highlight-color: transparent;
    user-select: none;
}
.stepper-btn:hover { background: var(--cc-blue-soft); color: var(--cc-blue); }
.stepper-btn:active { background: var(--cc-blue); color: var(--cc-white); }
.stepper-btn:disabled {
    color: var(--cc-muted-2);
    cursor: not-allowed;
    opacity: 0.45;
    background: var(--cc-ice);
}
.stepper-label { display: grid; gap: 6px; }

/* label content row — keeps the "Field name *" or "Field name (optional)" on
   a single line above the input, instead of letting the asterisk wrap to its
   own grid row inside the `display: grid` label. */
.label-row {
    align-items: baseline;
    color: var(--cc-navy);
    display: inline-flex;
    flex-wrap: wrap;
    gap: 6px;
    line-height: 1.2;
}
.label-optional {
    background: var(--cc-ice-2);
    border-radius: 999px;
    color: var(--cc-muted);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    padding: 2px 8px;
    text-transform: uppercase;
}
.req {
    color: var(--cc-error);
    font-weight: 800;
    margin-left: 0;
}

.form-section-help {
    color: var(--cc-muted);
    font-size: 0.94rem;
    margin: -6px 0 18px;
}
.form-subhead {
    color: var(--cc-navy);
    font-size: 0.88rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    margin-bottom: 10px;
    margin-top: 22px;
    text-transform: uppercase;
}

.choice-icon {
    align-items: center;
    background: var(--cc-blue-soft);
    border-radius: 10px;
    color: var(--cc-blue);
    display: inline-flex;
    height: 40px;
    justify-content: center;
    margin-bottom: 6px;
    width: 40px;
}
.choice-card { padding-top: 22px; }
.choice-card:has(input:checked) .choice-icon { background: var(--cc-white); color: var(--cc-blue); }

.date-status {
    color: var(--cc-muted);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}
.date-option.selected .date-status { color: rgba(255, 255, 255, 0.85); }

.date-popover-wrap { margin-top: 12px; position: relative; }
.date-popover-trigger {
    align-items: center;
    background: var(--cc-white);
    border: 1.5px solid var(--cc-border);
    border-radius: var(--cc-radius);
    color: var(--cc-navy);
    cursor: pointer;
    display: flex;
    font: inherit;
    gap: 14px;
    padding: 14px 18px;
    text-align: left;
    transition: border-color .15s ease, box-shadow .15s ease;
    width: 100%;
}
.date-popover-trigger:hover { border-color: var(--cc-blue); }
.date-popover-trigger[aria-expanded="true"] {
    border-color: var(--cc-blue);
    box-shadow: 0 0 0 4px rgba(23, 105, 224, 0.12);
}
.date-popover-icon {
    align-items: center;
    background: var(--cc-blue-soft);
    border-radius: 10px;
    color: var(--cc-blue);
    display: inline-flex;
    flex: 0 0 40px;
    height: 40px;
    justify-content: center;
    width: 40px;
}
.date-popover-text { display: flex; flex: 1 1 auto; flex-direction: column; gap: 2px; }
.date-popover-text strong { color: var(--cc-navy); font-size: 0.98rem; }
.date-popover-text em {
    color: var(--cc-muted);
    font-size: 0.82rem;
    font-style: normal;
    font-weight: 500;
}
.date-popover-caret { color: var(--cc-muted); flex: 0 0 auto; transition: transform .18s ease; }
.date-popover-trigger[aria-expanded="true"] .date-popover-caret { transform: rotate(180deg); }

.date-popover {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius);
    box-shadow: var(--cc-shadow-lg);
    left: 0;
    margin-top: 8px;
    padding: 18px;
    position: absolute;
    right: 0;
    top: 100%;
    width: 100%;
    z-index: 30;
}
.date-popover[hidden] { display: none; }
.date-popover-head {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: 12px;
}
.date-popover-head strong {
    color: var(--cc-navy);
    font-size: 1.02rem;
    font-weight: 700;
}
.date-popover-head button {
    align-items: center;
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: 10px;
    color: var(--cc-navy);
    cursor: pointer;
    display: inline-flex;
    height: 36px;
    justify-content: center;
    padding: 0;
    transition: border-color .15s ease, color .15s ease;
    width: 36px;
}
.date-popover-head button:hover:not(:disabled) {
    border-color: var(--cc-blue);
    color: var(--cc-blue);
}
.date-popover-head button:disabled {
    color: var(--cc-muted-2);
    cursor: not-allowed;
    opacity: 0.5;
}
.date-popover-weekdays {
    color: var(--cc-muted);
    display: grid;
    font-size: 0.74rem;
    font-weight: 700;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    letter-spacing: 0.06em;
    margin-bottom: 6px;
    text-align: center;
    text-transform: uppercase;
}
.date-popover-grid {
    display: grid;
    gap: 4px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}
.date-cell {
    align-items: center;
    background: var(--cc-white);
    border: 0;
    border-radius: 10px;
    color: var(--cc-navy);
    cursor: pointer;
    display: inline-flex;
    font: inherit;
    font-size: 0.9rem;
    font-weight: 600;
    height: 42px;
    justify-content: center;
    padding: 0;
    transition: background .12s ease, color .12s ease;
}
.date-cell:hover:not(:disabled):not(.is-selected) { background: var(--cc-blue-soft); color: var(--cc-blue); }
.date-cell:disabled {
    color: var(--cc-muted-2);
    cursor: not-allowed;
    opacity: 0.5;
}
.date-cell.is-empty { background: transparent; cursor: default; }
.date-cell.is-selected {
    background: var(--cc-blue);
    color: var(--cc-white);
}

.photo-uploader {
    background: var(--cc-white);
    border: 1.5px dashed var(--cc-border-strong);
    border-radius: var(--cc-radius);
    margin-top: 6px;
    padding: 18px;
}
.photo-uploader-label {
    align-items: center;
    color: var(--cc-slate);
    cursor: pointer;
    display: flex;
    flex-wrap: wrap;
    font-weight: 600;
    gap: 14px;
    margin: 0;
}
.photo-uploader-icon {
    align-items: center;
    background: var(--cc-blue-soft);
    border-radius: 12px;
    color: var(--cc-blue);
    display: inline-flex;
    flex: 0 0 44px;
    height: 44px;
    justify-content: center;
    width: 44px;
}
.photo-uploader-text { display: flex; flex: 1 1 200px; flex-direction: column; gap: 2px; }
.photo-uploader-text strong { color: var(--cc-navy); font-size: 0.98rem; }
.photo-uploader-text span { color: var(--cc-muted); font-size: 0.86rem; font-weight: 500; }
.photo-uploader-button {
    background: var(--cc-blue);
    border-radius: 999px;
    color: var(--cc-white);
    font-size: 0.86rem;
    font-weight: 700;
    padding: 10px 18px;
    transition: background .15s ease;
}
.photo-uploader-label:hover .photo-uploader-button { background: var(--cc-blue-dark); }

.photo-preview {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
}
.photo-preview:empty { display: none; }
.photo-thumb {
    background-color: var(--cc-ice);
    background-position: center;
    background-size: cover;
    border-radius: 10px;
    height: 92px;
    overflow: hidden;
    position: relative;
    width: 92px;
}
.photo-thumb-name {
    background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.7));
    bottom: 0;
    color: var(--cc-white);
    font-size: 0.7rem;
    font-weight: 600;
    left: 0;
    overflow: hidden;
    padding: 18px 8px 6px;
    position: absolute;
    right: 0;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.photo-thumb-more {
    align-items: center;
    background: var(--cc-blue-soft);
    border-radius: 10px;
    color: var(--cc-blue);
    display: inline-flex;
    font-weight: 700;
    height: 92px;
    justify-content: center;
    width: 92px;
}

.form-fine {
    color: var(--cc-muted);
    font-size: 0.82rem;
    margin: 14px 0 0;
}

/* legacy side-rail removed; replaced by .quote-rail + .quote-rail-sticky */

/* ====================== referrals page ====================== */
.referral-page h1 {
    font-family: Fraunces, Georgia, serif;
    font-weight: 600;
}
.referral-hero {
    align-items: center;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 0.5fr);
    margin: 0 auto 32px;
    max-width: 1040px;
}
.reward-card {
    background: linear-gradient(140deg, var(--cc-navy), var(--cc-navy-soft));
    border-radius: var(--cc-radius);
    box-shadow: var(--cc-shadow);
    color: var(--cc-white);
    display: grid;
    gap: 10px;
    padding: 28px;
}
.reward-card span {
    color: var(--cc-mint);
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}
.reward-card strong {
    color: var(--cc-white);
    font-family: Fraunces, Georgia, serif;
    font-size: 2.4rem;
    font-weight: 600;
}
.reward-card p { color: rgba(255, 255, 255, 0.78); margin: 0; }

.referral-form { max-width: 1040px; }

/* ====================== area pages ====================== */
.area-hero { padding-top: 36px; }
.area-hero-visual { min-height: 380px; }

.service-hero-grid.one-col { grid-template-columns: 1fr; }
.service-hero-grid.one-col .service-hero-copy.center {
    margin: 0 auto;
    max-width: 720px;
    text-align: center;
}
.service-hero-grid.one-col .service-hero-copy.center .crumbs {
    justify-content: center;
}
.service-hero-grid.one-col .service-hero-copy.center .eyebrow-line {
    justify-content: center;
}
.action-row.center-row { justify-content: center; }

.area-intro-grid {
    display: grid;
    gap: 36px;
    grid-template-columns: 1.5fr 1fr;
    align-items: start;
}
.area-intro-copy h2 { margin-top: 10px; }
.area-intro-copy p {
    color: var(--cc-muted);
    margin-top: 16px;
    font-size: 0.98rem;
}
.area-intro-local {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-left: 3px solid var(--cc-mint);
    border-radius: 10px;
    color: var(--cc-navy) !important;
    margin-top: 22px !important;
    padding: 14px 16px;
    font-size: 0.94rem !important;
}
.area-intro-local strong { color: var(--cc-blue); margin-right: 4px; }

.area-facts-card {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: 18px;
    padding: 24px;
    position: sticky;
    top: 96px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.area-facts-card h3 {
    color: var(--cc-navy);
    font-family: Fraunces, Georgia, serif;
    font-size: 1.35rem;
    margin: 0;
}
.area-facts {
    display: grid;
    gap: 10px;
    margin: 4px 0 8px;
}
.area-facts > div {
    border-top: 1px solid var(--cc-border);
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 12px;
    padding-top: 10px;
}
.area-facts > div:first-child { border-top: 0; padding-top: 0; }
.area-facts dt {
    color: var(--cc-muted);
    font-size: 0.82rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.area-facts dd {
    color: var(--cc-navy);
    font-size: 0.92rem;
    font-weight: 600;
    margin: 0;
    text-align: right;
}

.area-services-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    margin-top: 32px;
}
.area-service-card {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: 16px;
    color: inherit;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    text-decoration: none;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
.area-service-card:hover {
    border-color: var(--cc-blue-soft);
    box-shadow: 0 18px 40px -28px rgba(13, 31, 65, 0.4);
    transform: translateY(-2px);
}
.area-service-image {
    background-position: center;
    background-size: cover;
    min-height: 140px;
}
.area-service-body {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 18px 20px 22px;
}
.area-service-eyebrow {
    color: var(--cc-blue);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.area-service-card h3 {
    color: var(--cc-navy);
    font-size: 1.08rem;
    margin: 0;
}
.area-service-card p {
    color: var(--cc-muted);
    font-size: 0.92rem;
    margin: 0;
}
.area-service-card .link-arrow { margin-top: 6px; }

.neighborhood-pills, .other-areas-pills { margin-top: 24px; }
.area-pills-cta { display: flex; justify-content: center; margin-top: 24px; }

/* area-index page */
.area-index-hero { padding: 36px 6vw 24px; }

.area-index-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    margin-top: 32px;
}
.area-index-card {
    background: var(--cc-white);
    border: 1px solid var(--cc-border);
    border-radius: 16px;
    color: inherit;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    text-decoration: none;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
.area-index-card:hover {
    border-color: var(--cc-blue-soft);
    box-shadow: 0 18px 40px -28px rgba(13, 31, 65, 0.45);
    transform: translateY(-2px);
}
.area-index-image {
    background-position: center;
    background-size: cover;
    min-height: 160px;
}
.area-index-body {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 18px 20px 22px;
}
.area-index-eyebrow {
    color: var(--cc-blue);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.area-index-card h3 {
    color: var(--cc-navy);
    font-size: 1.18rem;
    font-family: Fraunces, Georgia, serif;
    margin: 0;
}
.area-index-card p {
    color: var(--cc-muted);
    font-size: 0.92rem;
    margin: 4px 0 2px;
}
.area-index-zip {
    color: var(--cc-muted);
    font-size: 0.78rem;
    letter-spacing: 0.04em;
}
.area-index-card .link-arrow { margin-top: 8px; }

/* ====================== responsive ====================== */
@media (max-width: 1100px) {
    .footer-inner { grid-template-columns: 1.4fr 1fr 1fr 1fr; }
    .footer-contact { grid-column: span 3; flex-direction: row; flex-wrap: wrap; align-items: center; }
}
@media (max-width: 980px) {
    .top-strip-inner { flex-direction: column; gap: 6px; padding: 8px 6vw; text-align: center; }
    .site-nav { display: none; }
    .header-cta .button-ghost-sm { display: none; }
    .nav-toggle { display: inline-flex; }
    .hero-grid { grid-template-columns: 1fr; gap: 36px; }
    .hero-visual { max-width: 100%; }
    .hero-floating-card { left: 12px; bottom: 12px; }
    .hero-floating-badge { right: 12px; top: 12px; }
    .trust-strip-inner { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .trust-pill { border-left: 0; border-top: 1px solid var(--cc-border); }
    .trust-pill:nth-child(odd) { border-left: 0; }
    .trust-pill:nth-child(-n+2) { border-top: 0; }
    .trust-pill:nth-child(even) { border-left: 1px solid var(--cc-border); }
    .service-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .service-card { grid-column: span 1; }
    .service-card-feature { grid-column: span 2; grid-template-columns: 1fr; }
    .why-grid, .about-grid, .faq-grid, .pricing-wrap, .service-hero-grid, .service-detail-grid, .quote-builder-page, .area-intro-grid { grid-template-columns: 1fr; gap: 28px; }
    .best-for-card, .quote-rail-sticky, .area-facts-card { position: static; }
    .area-hero-visual { min-height: 240px; }
    .area-services-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .area-index-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .form-grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .addon-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .other-services-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .service-hero-meta { grid-template-columns: 1fr; }
    .why-cards, .how-steps, .area-pills, .testimonial-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .about-image { aspect-ratio: 4/3; }
    .cta-card { grid-template-columns: 1fr; padding: 36px; }
    .footer-inner { grid-template-columns: 1fr 1fr; }
    .footer-contact { grid-column: span 2; flex-direction: column; align-items: flex-start; }
    .band { padding: 64px 6vw; }
    .hero { padding-bottom: 72px; }
}
@media (max-width: 720px) {
    /* tighten the in-between range so tablets/large phones don't feel huge */
    .band { padding: 48px 5vw; }
    .hero { padding: 40px 5vw 56px; }
    h1 { font-size: clamp(1.85rem, 6vw + 0.6rem, 2.6rem); }
    h2 { font-size: clamp(1.45rem, 3vw + 0.7rem, 1.95rem); }
    .lede, .hero-lede { font-size: 0.98rem; }
}
@media (max-width: 640px) {
    /* ---- base + typography ---- */
    body { font-size: 15px; line-height: 1.55; }
    h1 {
        font-size: clamp(1.65rem, 8vw, 2.15rem);
        line-height: 1.1;
    }
    h2 { font-size: 1.45rem; line-height: 1.15; }
    h3 { font-size: 1.02rem; }
    h4 { font-size: 0.92rem; }
    .eyebrow { font-size: 0.7rem; letter-spacing: 0.12em; }
    .lede, .hero-lede { font-size: 0.95rem; line-height: 1.55; margin-top: 10px; }

    /* ---- spacing / bands ---- */
    .band { padding: 40px 5vw; }
    .hero { padding: 28px 5vw 40px; }
    .action-row { gap: 8px; margin-top: 18px; }

    /* ---- top strip + header ---- */
    .top-strip { font-size: 0.74rem; }
    .top-strip-inner { gap: 2px; padding: 6px 5vw; }
    .top-strip-links { flex-wrap: wrap; gap: 10px; justify-content: center; }
    .site-header-inner { min-height: 60px; padding: 0 5vw; gap: 10px; }
    .brand { gap: 8px; }
    .brand-mark { height: 32px; width: 32px; }
    .brand-mark svg { height: 18px; width: 18px; }
    .brand-name { font-size: 0.98rem; }
    .brand-sub { font-size: 0.6rem; letter-spacing: 0.07em; }

    /* ---- buttons ---- */
    .button { padding: 11px 16px; font-size: 0.92rem; gap: 6px; }
    .button-primary-sm, .button-ghost-sm { padding: 7px 12px; font-size: 0.78rem; }
    .cta-actions .button,
    .hero-cta .button { width: 100%; }

    /* ---- hero ---- */
    .hero-grid { gap: 24px; }
    .hero-copy { max-width: 100%; }
    .hero-copy h1 { margin: 10px 0 14px; }
    /* note: .calendar-strip is intentionally NOT in this collapse list — it must stay
       7-col on mobile (Sun..Sat days side-by-side). The override below also pins it. */
    .hero-bullets, .service-card-list, .form-grid, .choice-grid,
    .service-grid, .why-cards, .how-steps, .area-pills, .testimonial-grid,
    .about-stats, .trust-strip-inner,
    .area-services-grid, .area-index-grid {
        grid-template-columns: 1fr;
    }
    /* area-services and area-index look better as 2-col on mobile (visual cards) */
    .area-services-grid, .area-index-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
    .area-service-image, .area-index-image { min-height: 110px; }
    .area-service-body, .area-index-body { padding: 12px 14px 14px; gap: 4px; }
    .area-service-card h3 { font-size: 0.96rem; }
    /* hide the description on mobile to match the home-page service-card pattern —
       keeps each tile in the ~150–180px range so the 2-col grid stays readable */
    .area-service-card p { display: none; }
    .area-index-card h3 { font-size: 1.02rem; }
    .area-index-card p { font-size: 0.82rem; margin: 2px 0 0; }
    .area-index-eyebrow, .area-service-eyebrow { font-size: 0.66rem; }
    .area-index-zip { font-size: 0.72rem; }

    /* area-hero mobile */
    .area-hero { padding-top: 18px; }
    .area-hero-visual { min-height: 200px; }
    /* compress meta block — 3-col, tiny labels — same approach as .about-stats */
    .area-hero .service-hero-meta {
        background: var(--cc-white);
        border: 1px solid var(--cc-border);
        border-radius: 12px;
        display: grid;
        gap: 0;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        margin-top: 14px;
        padding: 10px 8px;
    }
    .area-hero .service-hero-meta > div {
        border-left: 1px solid var(--cc-border);
        padding: 4px 8px;
        text-align: center;
    }
    .area-hero .service-hero-meta > div:first-child { border-left: 0; }
    .area-hero .service-hero-meta-label { font-size: 0.62rem; }
    .area-hero .service-hero-meta strong { font-size: 0.78rem; line-height: 1.2; }

    /* area intro layout */
    .area-intro-grid { gap: 18px; }
    .area-intro-copy p { font-size: 0.92rem; margin-top: 12px; }
    .area-intro-local { font-size: 0.88rem !important; padding: 12px 14px; }
    .area-facts-card { padding: 18px; gap: 10px; }
    .area-facts-card h3 { font-size: 1.18rem; }
    .area-facts dt { font-size: 0.72rem; }
    .area-facts dd { font-size: 0.86rem; }
    .hero-bullets { gap: 6px; margin-top: 18px; }
    .hero-bullets li { font-size: 0.88rem; }
    .hero-visual { aspect-ratio: 1.1 / 1; gap: 10px; }
    .hero-floating-card {
        bottom: 8px; left: 8px;
        max-width: 180px; padding: 10px 12px;
    }
    .hero-floating-card p { font-size: 0.82rem; }
    .hero-floating-rating strong { font-size: 0.86rem; }
    .hero-floating-name { font-size: 0.72rem; }
    .hero-floating-badge {
        padding: 8px 12px; right: 8px; top: 8px; gap: 6px;
    }
    .hero-floating-badge strong { font-size: 1.3rem; }
    .hero-floating-badge span { font-size: 0.7rem; max-width: 92px; }

    /* ---- trust strip ---- */
    .trust-pill { border-left: 0 !important; border-top: 1px solid var(--cc-border); padding: 14px 4px; gap: 12px; }
    .trust-pill:first-child { border-top: 0; }
    .trust-pill-icon { height: 32px; width: 32px; font-size: 0.86rem; }
    .trust-pill strong { font-size: 0.88rem; }
    .trust-pill span { font-size: 0.78rem; }

    /* ---- services grid ---- */
    /* Service cards have image + eyebrow + h3 + p + bullets + foot. On desktop
       that's a balanced tall card; on mobile it ends up ~500px, much taller
       than the why/how cards (~115px). Shorten the image, tighten body padding,
       and hide the bullet list (the description already conveys the gist —
       users can tap "See checklist / Explore" for full detail). */
    .service-grid { gap: 14px; margin-top: 26px; }
    .service-card { grid-column: span 1; border-radius: var(--cc-radius); }
    .service-card-feature { grid-column: span 1; }
    .service-card-image { min-height: 130px; }
    .service-card-image.short { min-height: 120px; }
    .service-card-body, .service-card-feature .service-card-body { padding: 14px 16px 12px; gap: 6px; }
    .service-card-feature h3 { font-size: 1.2rem; }
    .service-card h3 { font-size: 1.02rem; }
    .service-card p { font-size: 0.86rem; line-height: 1.5; }
    .service-card-list { display: none; }
    .service-card-feature .service-card-list { display: grid; grid-template-columns: 1fr; gap: 4px; margin-top: 4px; }
    .service-card-feature .service-card-list li { font-size: 0.84rem; }
    .service-card-foot { padding-top: 10px; }
    .service-card-price { font-size: 0.92rem; }
    .service-card-tag { font-size: 0.64rem; padding: 4px 8px; left: 12px; top: 12px; }

    /* ---- why / how / pricing / testimonials / areas ---- */
    /* why-cards — go horizontal on mobile (icon left, title + desc stacked right) */
    .why-cards { gap: 10px; }
    .why-card {
        border-radius: var(--cc-radius);
        display: grid;
        flex-direction: row;
        gap: 2px 14px;
        grid-template-columns: 36px minmax(0, 1fr);
        grid-template-areas:
            "icon title"
            "icon desc";
        padding: 14px 16px;
    }
    .why-card-icon {
        align-self: center;
        grid-area: icon;
        height: 36px;
        margin-bottom: 0;
        width: 36px;
    }
    .why-card h3 { align-self: end; grid-area: title; font-size: 0.98rem; margin: 0; }
    .why-card p { align-self: start; grid-area: desc; font-size: 0.85rem; line-height: 1.5; margin-top: 2px; }
    /* how-steps — go horizontal on mobile: big number on the left, title +
       description stacked on the right. Cuts each card height roughly in half. */
    .how-steps { gap: 10px; margin-top: 22px; }
    .how-steps li {
        display: grid;
        gap: 2px 14px;
        grid-template-columns: 36px minmax(0, 1fr);
        grid-template-areas:
            "num title"
            "num desc";
        padding: 14px 16px;
    }
    .how-steps .step-num {
        align-self: center;
        font-size: 1.5rem;
        grid-area: num;
        line-height: 1;
    }
    .how-steps h3 {
        align-self: end;
        font-size: 0.98rem;
        grid-area: title;
        margin-top: 0;
    }
    .how-steps p {
        align-self: start;
        font-size: 0.85rem;
        grid-area: desc;
        line-height: 1.5;
        margin-top: 2px;
    }
    .how-cta { flex-direction: column; gap: 8px; margin-top: 22px; }
    .how-cta .button { width: 100%; }

    /* pricing — tighten rows, keep label/amount on one row, smaller amount serif */
    .pricing-wrap { gap: 22px; }
    .pricing-table { border-radius: var(--cc-radius); }
    .pricing-table > div { padding: 14px 16px; gap: 12px; }
    .pricing-row-label { font-size: 0.95rem; line-height: 1.25; }
    .pricing-row-note { font-size: 0.78rem; }
    .pricing-row-amt { font-size: 1rem; }
    .pricing-fine { font-size: 0.76rem; margin-top: 14px; }

    .testimonial-grid { gap: 12px; }
    .testimonial { padding: 16px; gap: 8px; }
    .testimonial .stars { font-size: 0.92rem; }
    .testimonial blockquote { font-size: 0.9rem; line-height: 1.5; margin: 4px 0; }
    .testimonial figcaption { font-size: 0.8rem; }

    /* area-pills — 2-col on mobile so 6+ cards don't stretch forever */
    .area-pills {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
        margin-top: 22px;
    }
    .area-pills a { padding: 12px 14px; gap: 2px; }
    .area-pills span { font-size: 0.92rem; }
    .area-pills em { font-size: 0.74rem; }

    /* about stats — small 3-col numeric pills, kept tight */
    .about-stats { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; margin-top: 14px; }
    .about-stats > * { padding: 10px 6px; text-align: center; gap: 2px; }
    .about-stats strong { font-size: 1.1rem; line-height: 1.1; }
    .about-stats span { font-size: 0.7rem; line-height: 1.3; }
    .about-image { aspect-ratio: 16 / 11; max-height: 220px; }
    .about-grid { gap: 18px; }
    .about-copy p { font-size: 0.92rem; line-height: 1.55; }

    /* ---- FAQ ---- */
    .faq-list summary { font-size: 0.95rem; padding: 14px 38px 14px 16px; }
    .faq-list details p { padding: 0 16px 14px; font-size: 0.9rem; }

    /* ---- about + cta ---- */
    .cta-card { padding: 24px; gap: 16px; border-radius: var(--cc-radius); }
    .cta-card h2 { font-size: 1.5rem; }
    .about-stats > * { padding: 14px; }

    /* ---- footer ---- */
    /* Footer was stacking 5 sections vertically on mobile and getting very tall.
       Brand stays full-width on top, then a 2-col grid for the link sections,
       then contact full-width at the bottom. */
    .site-footer { padding: 40px 5vw 18px; }
    .footer-inner {
        gap: 18px 16px;
        grid-template-columns: 1fr 1fr;
        padding: 0;
    }
    .footer-brand { grid-column: 1 / -1; }
    .footer-brand p { font-size: 0.86rem; margin-top: 12px; }
    .footer-meta { font-size: 0.76rem; }
    .footer-col h4 { font-size: 0.74rem; margin-bottom: 4px; }
    .footer-col { gap: 6px; }
    .footer-col a { font-size: 0.84rem; }
    .footer-contact { grid-column: auto; flex-direction: column; align-items: flex-start; }
    .footer-base {
        flex-direction: column;
        font-size: 0.72rem;
        gap: 8px;
        margin-top: 28px;
        padding-top: 16px;
        text-align: left;
    }
    .footer-disclaimer { line-height: 1.5; }

    /* ---- quote page ---- */
    .quote-hero, .quote-hero-compact { padding: 18px 5vw 10px; }
    .page-band { padding: 18px 5vw 36px; }
    .quote-builder-page { gap: 18px; }
    .quote-form, .quote-builder-page > .quote-form { padding: 18px; border-radius: var(--cc-radius); }
    .form-section { margin-bottom: 18px; padding-bottom: 18px; }
    .form-section h2 { font-size: 1rem; }
    .form-section-head { gap: 10px; margin-bottom: 12px; }
    .form-section-head .form-section-help { font-size: 0.8rem; }
    .step-badge { flex: 0 0 30px; height: 30px; width: 30px; font-size: 0.72rem; border-radius: 8px; }
    .form-section-help { font-size: 0.86rem; margin: -4px 0 12px; }

    /* property type cards (Apartment/House/Business) — go horizontal on mobile.
       The HTML order is: radio, .choice-icon, <strong>, <span>. We use grid
       areas to lay out: icon left | strong/span stacked right, radio top-right. */
    .choice-grid { gap: 8px; }
    .choice-card {
        min-height: 0;
        padding: 10px 12px;
        gap: 4px 12px;
        grid-template-columns: 36px minmax(0, 1fr) auto;
        grid-template-areas:
            "icon text radio"
            "icon desc desc";
        align-items: center;
    }
    .choice-card > input[type="radio"] { grid-area: radio; }
    .choice-card .choice-icon { grid-area: icon; margin-bottom: 0; align-self: center; }
    .choice-card > strong { grid-area: text; align-self: end; }
    .choice-card > strong + span { grid-area: desc; align-self: start; }
    .choice-card { padding-top: 10px; }
    .choice-card strong { font-size: 0.94rem; line-height: 1.2; }
    .choice-card span { font-size: 0.78rem; line-height: 1.3; }
    .choice-icon { height: 36px; width: 36px; margin-bottom: 0; border-radius: 8px; }

    /* service level "small choice" cards have no icon — keep horizontal but simpler */
    .choice-card.small-choice {
        grid-template-columns: auto minmax(0, 1fr) auto;
        grid-template-areas:
            "radio text radio2"
            "radio desc radio2";
        padding: 10px 14px;
        gap: 2px 10px;
    }
    .choice-card.small-choice > input[type="radio"] { grid-area: radio; align-self: center; }
    .choice-card.small-choice > strong { grid-area: text; align-self: end; }
    .choice-card.small-choice > strong + span { grid-area: desc; align-self: start; }
    .service-levels { margin-top: 10px; }
    .form-subhead { font-size: 0.76rem; margin-top: 14px; margin-bottom: 8px; }

    /* room counter grid — 2-col on mobile (was 1-col which was wasteful) */
    .form-grid.form-grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px 10px; }
    .room-grid { margin-top: 14px; }
    .room-grid label,
    .room-grid .stepper-label { margin-bottom: 0; }
    /* stepper sized so each cell is a clear tap target — 44px button cells, ~44px tall */
    .stepper { grid-template-columns: 44px minmax(0, 1fr) 44px; }
    .stepper-btn { font-size: 1.3rem; min-height: 44px; }
    .stepper input[type="number"] { font-size: 1.05rem; min-height: 44px; }

    /* quote hero — slim down further so the form starts higher */
    .quote-hero-compact h1 { font-size: 1.45rem; }
    .quote-hero-inner .eyebrow { font-size: 0.65rem; }

    .estimate-panel { grid-template-columns: 1fr; padding: 18px; }
    .estimate-panel #estimate-price { font-size: 1.7rem; }
    .when-row { grid-template-columns: 1fr; gap: 10px; }
    .addon-grid { grid-template-columns: 1fr; gap: 10px; }
    .addon-card { padding: 10px 12px; gap: 8px 10px; grid-template-columns: 32px minmax(0, 1fr) auto; }
    .addon-icon { height: 32px; width: 32px; border-radius: 8px; }
    .addon-body strong { font-size: 0.9rem; }
    .addon-body span { font-size: 0.74rem; }

    .calendar-strip { grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 4px; }
    .date-option { min-height: 0; padding: 8px 4px; gap: 0; text-align: center; font-size: 0.72rem; border-radius: 8px; }
    .date-option strong { font-size: 0.78rem; }
    .date-option span { font-size: 0.66rem; }
    .date-status { display: none; }

    .date-popover-trigger { padding: 12px 14px; gap: 10px; }
    .date-popover-icon { height: 32px; width: 32px; flex: 0 0 32px; }
    .date-popover-text strong { font-size: 0.92rem; }
    .date-popover-text em { font-size: 0.78rem; }
    .date-popover { padding: 14px; }
    .date-cell { height: 36px; font-size: 0.84rem; }
    .date-popover-head button { height: 32px; width: 32px; }

    label { font-size: 0.82rem; margin-bottom: 12px; gap: 6px; }
    input, select, textarea { min-height: 42px; padding: 9px 12px; font-size: 0.92rem; }
    .contact-hint { font-size: 0.82rem; padding: 9px 12px; }

    /* About-you section — tighten the field stack so the form feels less endless */
    [data-section="about"] label { margin-bottom: 10px; gap: 4px; }
    [data-section="about"] .form-grid { gap: 10px; }
    [data-section="about"] .contact-hint { margin: 4px 0 12px; padding: 8px 12px; }
    [data-section="about"] textarea { min-height: 80px; }
    .label-row { font-size: 0.84rem; gap: 4px; }
    .label-optional { font-size: 0.62rem; padding: 1px 6px; }
    .req { font-size: 0.95rem; }

    .photo-uploader { padding: 12px; margin-top: 4px; }
    .photo-uploader-label { gap: 10px; }
    .photo-uploader-icon { height: 36px; width: 36px; flex: 0 0 36px; }
    .photo-uploader-text { flex: 1 1 140px; min-width: 0; }
    .photo-uploader-text strong { font-size: 0.92rem; }
    .photo-uploader-text span { font-size: 0.78rem; line-height: 1.4; }
    .photo-uploader-button { font-size: 0.8rem; padding: 8px 14px; }
    .photo-thumb, .photo-thumb-more { height: 72px; width: 72px; }

    /* ---- sticky rail cards (stacked below form on mobile) ----
       Form controls all sit in the 40-80px range; these were 220-350px.
       Tighter padding + smaller text without losing legibility. */
    .rail-summary { padding: 12px 14px 2px; border-radius: var(--cc-radius); }
    .rail-summary-head { margin-bottom: 6px; }
    .rail-summary-row { grid-template-columns: 56px minmax(0, 1fr); padding: 6px 0; gap: 8px; }
    .rail-summary-row dt { font-size: 0.62rem; }
    .rail-summary-row dd { font-size: 0.82rem; }

    .rail-perks { padding: 12px 14px; border-radius: var(--cc-radius); }
    .rail-perks-head { margin-bottom: 6px; gap: 1px; }
    .rail-perks-hint { font-size: 0.78rem; }
    .rail-perks-list { gap: 6px; }
    .perk-row { grid-template-columns: 18px minmax(0, 1fr); gap: 8px; }
    .perk-icon { height: 18px; width: 18px; }
    .perk-icon::after { font-size: 0.66rem; }
    .perk-row.is-unlocked .perk-icon::after { font-size: 0.66rem; }
    .perk-text strong { font-size: 0.82rem; }
    .perk-text em { font-size: 0.72rem; }

    .rail-next { padding: 12px 14px; border-radius: var(--cc-radius); }
    .rail-next h4 { font-size: 0.74rem; margin-bottom: 8px; }
    .rail-next-list { gap: 8px; }
    .rail-next-list li { padding-left: 26px; }
    .rail-next-list li::before { height: 18px; width: 18px; font-size: 0.66rem; }
    .rail-next-list strong { font-size: 0.84rem; }
    .rail-next-list span { font-size: 0.78rem; }

    .quote-rail .estimate-panel { padding: 14px; border-radius: var(--cc-radius); }
    .quote-rail .estimate-panel #estimate-price { font-size: 1.5rem; }
    .quote-rail .estimate-panel #estimate-time { font-size: 0.82rem; }
    .quote-rail .estimate-panel #estimate-message { font-size: 0.82rem; margin: 8px 0 2px; }
    .estimate-cta { margin-top: 8px; }
    .estimate-panel .form-fine { font-size: 0.74rem; margin-top: 8px; }

    .rail-trust { gap: 6px; }
    .rail-trust span { font-size: 0.7rem; padding: 8px 6px; }
    .rail-trust strong { font-size: 0.86rem; }

    /* ---- service detail ---- */
    .service-hero-meta { gap: 10px; }
    .service-hero-grid { gap: 20px; }
    .service-hero-copy h1 { margin: 12px 0 14px; font-size: 1.7rem; }
    .other-services-grid { grid-template-columns: 1fr; }

    /* ---- referrals ---- */
    .referral-hero { grid-template-columns: 1fr; gap: 18px; }
    .reward-card { padding: 20px; }
    .reward-card strong { font-size: 1.85rem; }
}
@media (max-width: 380px) {
    h1 { font-size: 1.55rem; }
    h2 { font-size: 1.35rem; }
    .button { padding: 10px 14px; font-size: 0.88rem; }
    .brand-name { font-size: 0.92rem; }
    .brand-sub { font-size: 0.56rem; }
    .top-strip { font-size: 0.7rem; }
}

/* ---------- auth pages (sign in / sign up / reset) ---------- */
.auth-band { padding: 56px 0 80px; }
.auth-shell { display: grid; grid-template-columns: minmax(0, 1fr) minmax(360px, 440px); gap: 56px; max-width: 1080px; margin: 0 auto; padding: 0 24px; align-items: start; }
.auth-aside { padding-top: 8px; }
.auth-h1 { font-family: 'Fraunces', serif; font-size: 2.4rem; font-weight: 600; color: var(--cc-navy); line-height: 1.1; margin: 12px 0 14px; }
.auth-lede { font-size: 1.02rem; color: #4a586c; line-height: 1.55; max-width: 460px; }
.auth-perks { list-style: none; padding: 0; margin: 22px 0 0; display: grid; gap: 12px; }
.auth-perks li { font-size: 0.92rem; color: #3a4860; line-height: 1.5; padding-left: 22px; position: relative; }
.auth-perks li::before { content: ""; position: absolute; left: 0; top: 7px; width: 12px; height: 12px; border-radius: 50%; background: linear-gradient(135deg, var(--cc-blue), var(--cc-mint)); }
.auth-perks li strong { color: var(--cc-navy); display: block; margin-bottom: 2px; }
.auth-aside-foot { margin-top: 22px; font-size: 0.88rem; color: #5d6b80; padding: 12px 14px; background: rgba(23, 105, 224, 0.06); border-radius: 12px; border-left: 3px solid var(--cc-blue); }
.auth-card { background: #fff; border: 1px solid #e6ecf3; border-radius: 18px; padding: 28px 26px 22px; box-shadow: 0 18px 40px -28px rgba(15, 26, 48, 0.25); }
.auth-card-h2 { font-family: 'Fraunces', serif; font-size: 1.4rem; font-weight: 600; color: var(--cc-navy); margin: 0 0 16px; }
.auth-card-body { font-size: 0.94rem; color: #4a586c; line-height: 1.55; margin: 0 0 14px; }
.auth-socials { display: grid; gap: 10px; margin-bottom: 14px; }
.auth-social { width: 100%; display: inline-flex; align-items: center; justify-content: center; gap: 10px; font-weight: 600; }
.auth-divider { text-align: center; font-size: 0.78rem; color: #8593a8; margin: 8px 0 14px; position: relative; }
.auth-divider::before, .auth-divider::after { content: ""; position: absolute; top: 50%; width: calc(50% - 60px); height: 1px; background: #e6ecf3; }
.auth-divider::before { left: 0; }
.auth-divider::after { right: 0; }
.auth-form { display: grid; gap: 12px; }
.auth-form label { display: grid; gap: 6px; font-size: 0.84rem; color: #4a586c; font-weight: 500; }
.auth-form input[type="email"], .auth-form input[type="password"], .auth-form input[type="text"] { width: 100%; padding: 10px 12px; border: 1px solid #d6dee9; border-radius: 10px; font: inherit; font-size: 0.95rem; background: #fff; min-height: 44px; }
.auth-form input:focus { outline: none; border-color: var(--cc-blue); box-shadow: 0 0 0 3px rgba(23, 105, 224, 0.15); }
.auth-checkbox { display: flex !important; flex-direction: row; align-items: center; gap: 8px; font-size: 0.84rem; grid-template-columns: none; }
.auth-checkbox input { width: 16px; height: 16px; flex-shrink: 0; }
.auth-submit { width: 100%; margin-top: 4px; }
.auth-error { background: #fdeded; color: #8a1a1a; padding: 10px 12px; border-radius: 10px; font-size: 0.88rem; }
.auth-fineprint { font-size: 0.78rem; color: #7c8aa0; line-height: 1.45; margin: 6px 0 0; }
.auth-foot { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px; margin-top: 16px; padding-top: 14px; border-top: 1px solid #eef2f6; font-size: 0.86rem; color: #5d6b80; }
.auth-foot a { color: var(--cc-blue); font-weight: 600; text-decoration: none; }
.auth-foot a:hover { text-decoration: underline; }

/* ---------- quote page: signed-in strip + address picker ---------- */
.signed-in-strip { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 14px; background: rgba(56, 191, 167, 0.08); border: 1px solid rgba(56, 191, 167, 0.25); border-radius: 12px; margin: 0 0 14px; font-size: 0.9rem; }
.signed-in-strip strong { display: block; color: var(--cc-navy); font-size: 0.95rem; line-height: 1.2; }
.signed-in-eyebrow { display: block; font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.12em; color: #5d6b80; margin-bottom: 2px; }
.signed-in-meta { display: block; color: #5d6b80; font-size: 0.82rem; margin-top: 2px; }
.signed-in-edit { font-size: 0.84rem; color: var(--cc-blue); text-decoration: none; font-weight: 600; white-space: nowrap; }
.signed-in-edit:hover { text-decoration: underline; }
.saved-address-picker { width: 100%; padding: 10px 12px; border: 1px solid #d6dee9; border-radius: 10px; background: #fff; font: inherit; font-size: 0.92rem; min-height: 44px; margin-bottom: 8px; }
.form-grid-full { grid-column: 1 / -1; }

/* ---------- quote page: sign-in nudge banner ---------- */
.quote-account-nudge { grid-column: 1 / -1; display: flex; align-items: center; justify-content: space-between; gap: 14px; background: linear-gradient(135deg, rgba(23, 105, 224, 0.08), rgba(56, 191, 167, 0.08)); border: 1px solid rgba(23, 105, 224, 0.18); border-radius: 14px; padding: 12px 16px; margin: 0 0 18px; font-size: 0.9rem; color: var(--cc-navy); }
.quote-account-nudge strong { font-weight: 600; }
.quote-account-nudge a { color: var(--cc-blue); font-weight: 700; text-decoration: none; white-space: nowrap; }
.quote-account-nudge a:hover { text-decoration: underline; }

/* ---------- dashboard ---------- */
.dash-band { padding: 36px 0 80px; min-height: 60vh; }
.dash-shell { display: grid; grid-template-columns: 240px minmax(0, 1fr); gap: 32px; max-width: 1180px; margin: 0 auto; padding: 0 24px; }
.dash-sidebar { background: #fff; border: 1px solid #e6ecf3; border-radius: 16px; padding: 18px 16px; position: sticky; top: 96px; align-self: start; box-shadow: 0 12px 28px -22px rgba(15, 26, 48, 0.2); }
.dash-greeting { padding: 4px 6px 14px; border-bottom: 1px solid #eef2f6; margin-bottom: 12px; }
.dash-eyebrow { display: block; font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.12em; color: #8593a8; margin-bottom: 4px; }
.dash-greeting strong { display: block; font-size: 0.94rem; color: var(--cc-navy); line-height: 1.25; overflow-wrap: anywhere; }
.dash-email { display: block; font-size: 0.78rem; color: #7c8aa0; margin-top: 2px; word-break: break-all; }
.dash-phone { display: block; color: #4a586c; font-size: 0.78rem; margin-top: 4px; }
.dash-profile-mini-link { color: var(--cc-blue); display: inline-block; font-size: 0.78rem; font-weight: 700; margin-top: 6px; text-decoration: none; }
.dash-profile-mini-link:hover { text-decoration: underline; }
.dash-nav { display: grid; gap: 2px; margin-bottom: 14px; }
.dash-nav a { display: block; padding: 8px 10px; border-radius: 8px; font-size: 0.88rem; color: #4a586c; text-decoration: none; font-weight: 500; transition: background 0.12s, color 0.12s; }
.dash-nav a:hover { background: #f6f9fc; color: var(--cc-navy); }
.dash-nav a.is-active { background: rgba(23, 105, 224, 0.1); color: var(--cc-blue); font-weight: 600; }
.dash-book { width: 100%; text-align: center; }
.dash-main { min-width: 0; }
.dash-flash { display: grid; gap: 8px; margin-bottom: 16px; }
.dash-flash-item { background: rgba(56, 191, 167, 0.12); color: #0d6f5e; padding: 10px 14px; border-radius: 10px; font-size: 0.9rem; border-left: 3px solid var(--cc-mint); }
.dash-header { margin-bottom: 22px; }
.dash-header h1 { font-family: 'Fraunces', serif; font-weight: 600; font-size: 1.9rem; color: var(--cc-navy); margin: 6px 0 4px; line-height: 1.15; }
.dash-sub { font-size: 0.95rem; color: #5d6b80; margin: 0 0 12px; }
.dash-back { font-size: 0.84rem; color: var(--cc-blue); text-decoration: none; font-weight: 600; }
.dash-profile-prompt {
    align-items: center;
    background: linear-gradient(135deg, rgba(23, 105, 224, 0.08), rgba(56, 191, 167, 0.12));
    border: 1px solid rgba(23, 105, 224, 0.18);
    border-radius: 16px;
    box-shadow: 0 14px 34px -28px rgba(15, 26, 48, 0.28);
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 0.9fr) minmax(440px, 1.1fr);
    margin-bottom: 20px;
    padding: 18px;
}
.dash-profile-prompt-copy h2 { color: var(--cc-navy); font-family: 'Fraunces', serif; font-size: 1.25rem; line-height: 1.15; margin: 4px 0 6px; }
.dash-profile-prompt-copy p { color: #4a586c; font-size: 0.9rem; line-height: 1.55; margin: 0; }
.dash-quick-profile-form {
    align-items: end;
    display: grid;
    gap: 10px;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
}
.dash-quick-profile-form label { display: grid; gap: 6px; font-size: 0.76rem; font-weight: 700; color: #4a586c; }
.dash-quick-profile-form input { width: 100%; min-height: 42px; padding: 10px 12px; border: 1px solid #cdd9e8; border-radius: 10px; background: #fff; font: inherit; font-size: 0.9rem; }
.dash-quick-profile-form input:focus { outline: none; border-color: var(--cc-blue); box-shadow: 0 0 0 3px rgba(23, 105, 224, 0.14); }
.dash-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 20px; }
.dash-stat { background: #fff; border: 1px solid #e6ecf3; border-radius: 14px; padding: 14px 16px; text-align: center; }
.dash-stat strong { display: block; font-family: 'Fraunces', serif; font-size: 1.7rem; color: var(--cc-navy); line-height: 1; }
.dash-stat span { display: block; font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.1em; color: #7c8aa0; margin-top: 6px; }
.dash-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; }
.dash-card { background: #fff; border: 1px solid #e6ecf3; border-radius: 16px; padding: 18px 18px 16px; box-shadow: 0 10px 24px -22px rgba(15, 26, 48, 0.22); display: flex; flex-direction: column; gap: 10px; }
.dash-card-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding-bottom: 8px; border-bottom: 1px solid #eef2f6; margin-bottom: 4px; }
.dash-card-head h2 { font-family: 'Fraunces', serif; font-weight: 600; font-size: 1.05rem; color: var(--cc-navy); margin: 0; }
.dash-card-sub { color: #7c8aa0; font-size: 0.82rem; line-height: 1.45; margin: 4px 0 0; }
.dash-card-link { font-size: 0.82rem; color: var(--cc-blue); text-decoration: none; font-weight: 600; }
.dash-card-link:hover { text-decoration: underline; }
.dash-bignum { font-family: 'Fraunces', serif; font-size: 1.9rem; font-weight: 600; color: var(--cc-blue); margin: 4px 0 8px; }
.dash-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.dash-list li { display: grid; grid-template-columns: 1fr auto; gap: 4px 12px; align-items: center; padding: 8px 0; border-bottom: 1px dashed #eef2f6; font-size: 0.88rem; }
.dash-list li:last-child { border-bottom: 0; }
.dash-list strong { color: var(--cc-navy); grid-column: 1; }
.dash-list span { color: #5d6b80; font-size: 0.82rem; grid-column: 1; }
.dash-list .dash-card-link, .dash-list .dash-badge { grid-column: 2; grid-row: 1 / span 2; }
.dash-empty { color: #7c8aa0; font-size: 0.9rem; margin: 8px 0; }
.dash-empty a { color: var(--cc-blue); text-decoration: none; font-weight: 600; }
.dash-empty-state { background: #fff; border: 1px dashed #d6dee9; border-radius: 16px; padding: 36px 24px; text-align: center; }
.dash-empty-state h2 { font-family: 'Fraunces', serif; font-weight: 600; color: var(--cc-navy); margin: 0 0 6px; }
.dash-empty-state p { color: #5d6b80; margin: 0 0 14px; }
.dash-badge { display: inline-block; padding: 3px 10px; border-radius: 99px; font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; background: #eef2f6; color: #5d6b80; }
.dash-badge-quote_ready, .dash-badge-scheduled, .dash-badge-paid { background: rgba(56, 191, 167, 0.15); color: #0d6f5e; }
.dash-badge-needs_review, .dash-badge-awaiting_payment { background: rgba(245, 167, 35, 0.2); color: #8a5400; }
.dash-badge-cancelled, .dash-badge-expired, .dash-badge-failed { background: rgba(220, 53, 69, 0.12); color: #8a1a1a; }
.dash-tips { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; font-size: 0.88rem; color: #4a586c; }
.dash-tips strong { color: var(--cc-navy); }
.dash-card-tip { background: linear-gradient(180deg, #f6f9fc, #fff); }
.dash-table-wrap { background: #fff; border: 1px solid #e6ecf3; border-radius: 14px; overflow-x: auto; }
.dash-table { width: 100%; border-collapse: collapse; min-width: 580px; }
.dash-table th, .dash-table td { padding: 12px 14px; text-align: left; font-size: 0.88rem; }
.dash-table th { background: #f6f9fc; font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.1em; color: #7c8aa0; border-bottom: 1px solid #e6ecf3; }
.dash-table td { border-bottom: 1px solid #eef2f6; color: #4a586c; }
.dash-table tbody tr:last-child td { border-bottom: 0; }
.dash-table td:first-child { color: var(--cc-navy); font-weight: 600; }
.dash-pagination { display: flex; justify-content: center; align-items: center; gap: 16px; margin-top: 16px; font-size: 0.86rem; color: #5d6b80; }
.dash-pagination a { color: var(--cc-blue); text-decoration: none; font-weight: 600; }
.dash-photo-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 8px; }
.dash-photo-grid-lg { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
.dash-photo { position: relative; display: block; aspect-ratio: 1 / 1; overflow: hidden; border-radius: 10px; background: #f6f9fc; }
.dash-photo img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.2s; }
.dash-photo:hover img { transform: scale(1.04); }
.dash-photo-caption { position: absolute; bottom: 0; left: 0; right: 0; padding: 4px 8px; font-size: 0.7rem; color: #fff; background: linear-gradient(180deg, transparent, rgba(15, 26, 48, 0.8)); }
.dash-form { display: grid; gap: 12px; }
.dash-form label { display: grid; gap: 6px; font-size: 0.84rem; color: #4a586c; font-weight: 500; }
.dash-field-help { color: #7c8aa0; font-size: 0.76rem; font-weight: 400; line-height: 1.35; }
.dash-form input[type="text"], .dash-form input[type="email"], .dash-form input[type="tel"], .dash-form textarea { width: 100%; padding: 10px 12px; border: 1px solid #d6dee9; border-radius: 10px; font: inherit; font-size: 0.95rem; background: #fff; min-height: 44px; }
.dash-form textarea { min-height: 84px; }
.dash-form input:focus, .dash-form textarea:focus { outline: none; border-color: var(--cc-blue); box-shadow: 0 0 0 3px rgba(23, 105, 224, 0.15); }
.dash-check { display: flex !important; flex-direction: row; align-items: center; gap: 10px; font-weight: 500; grid-template-columns: none; }
.dash-check input { width: 18px; height: 18px; flex-shrink: 0; }
.dash-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 4px; }
.dash-muted { color: #7c8aa0; font-size: 0.86rem; }
.dash-error { color: #8a1a1a; font-size: 0.78rem; }
.dash-card-soon { background: linear-gradient(135deg, rgba(23, 105, 224, 0.06), rgba(56, 191, 167, 0.06)); border-color: rgba(23, 105, 224, 0.2); }
.dash-soon-badge { display: inline-block; padding: 3px 10px; border-radius: 99px; font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; background: var(--cc-navy); color: #fff; width: max-content; }
.dash-card-soon h2 { margin: 6px 0 4px; }
.dash-card-soon p { color: #4a586c; font-size: 0.9rem; line-height: 1.55; margin: 0; }

@media (max-width: 980px) {
    .auth-shell { grid-template-columns: 1fr; gap: 24px; }
    .auth-aside { padding-top: 0; }
    .auth-h1 { font-size: 1.9rem; }
    .dash-shell { grid-template-columns: 1fr; gap: 18px; padding: 0 16px; }
    .dash-sidebar { position: static; padding: 14px 12px; }
    .dash-nav { grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); }
    .dash-nav a { text-align: center; padding: 8px 6px; font-size: 0.82rem; }
    .dash-stats { grid-template-columns: repeat(2, 1fr); }
    .dash-header h1 { font-size: 1.5rem; }
    .dash-profile-prompt { grid-template-columns: 1fr; }
    .dash-quick-profile-form { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto; }
}
@media (max-width: 640px) {
    .dash-band { padding: 20px 0 60px; }
    .dash-stat strong { font-size: 1.4rem; }
    .dash-stat span { font-size: 0.66rem; }
    .dash-profile-prompt { padding: 14px; }
    .dash-quick-profile-form { align-items: stretch; grid-template-columns: 1fr; }
    .dash-quick-profile-form .button { width: 100%; }
    .quote-account-nudge { flex-direction: column; align-items: flex-start; gap: 10px; }
}
