: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); }

/* ====================== 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; }

/* ====================== 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;
}

/* ====================== 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 { color: var(--cc-error); font-weight: 800; margin-left: 2px; }
.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 ====================== */
.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; }

/* ====================== 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; }
    .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 { grid-template-columns: 1fr; gap: 28px; }
    .best-for-card, .quote-rail-sticky { position: static; }
    .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: 640px) {
    .hero-bullets, .service-card-list, .form-grid, .choice-grid, .calendar-strip,
    .service-grid, .why-cards, .how-steps, .area-pills, .testimonial-grid,
    .about-stats, .trust-strip-inner {
        grid-template-columns: 1fr;
    }
    .service-card { grid-column: span 1; }
    .service-card-feature { grid-column: span 1; }
    .trust-pill { border-left: 0 !important; border-top: 1px solid var(--cc-border); }
    .trust-pill:first-child { border-top: 0; }
    .quote-form { padding: 24px; }
    .estimate-panel { grid-template-columns: 1fr; }
    .when-row { grid-template-columns: 1fr; }
    .addon-grid { grid-template-columns: 1fr; }
    .hero-floating-card { max-width: 200px; padding: 12px 14px; }
    .hero-floating-badge { padding: 10px 14px; }
    .referral-hero { grid-template-columns: 1fr; }
}
