/* ============================================================
   Back to Life — global styles + shared chrome
   ============================================================ */
:root {
    --primary-deep:  #6B7A99;   /* slate-blue accent */
    --primary-light: #B8C9DC;
    --accent-warm:   #E2D4BC;
    --accent:        #76C3EF;   /* light blue CTA */
    --accent-d:      #5AAFE0;   /* CTA hover */
    --dark:          #2A2E33;   /* text + dark footer */
    --muted:         #6B7280;
    --white:         #fff;

    --ff-h: 'Oswald', sans-serif;
    --ff-b: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

    --max-w: 80rem;             /* 1280px ~ max-w-7xl */
    --r:     999px;
    --tr:    .18s ease;
}

*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: var(--ff-b);
    color: var(--dark);
    background: var(--white);
    -webkit-font-smoothing: antialiased;
    line-height: 1.6;
    /* leave room for fixed action bar */
    padding-bottom: 64px;
}
h1,h2,h3,h4,h5,h6 { font-family: var(--ff-h); font-weight: 600; line-height: 1.1; color: var(--dark); margin: 0 0 .5em; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }

.container { max-width: var(--max-w); margin-inline: auto; padding-inline: clamp(16px, 5vw, 32px); }
.section   { padding-block: clamp(48px, 8vw, 96px); }
.rich p { margin: 0 0 1em; }

/* ---------- Buttons ---------- */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
    font-family: var(--ff-b); font-weight: 600; font-size: .9rem;
    padding: .7rem 1.5rem; border-radius: var(--r); border: 2px solid transparent;
    cursor: pointer; transition: background var(--tr), color var(--tr), box-shadow var(--tr), border-color var(--tr);
    white-space: nowrap;
}
.btn--accent       { background: var(--accent); color: var(--dark); }
.btn--accent:hover { background: var(--accent-d); box-shadow: 0 8px 20px rgba(118,195,239,.3); }
.btn--dark         { background: var(--dark); color: var(--white); }
.btn--dark:hover   { background: #1c1f23; }
.btn--outline-dark { background: transparent; border-color: var(--dark); color: var(--dark); }
.btn--outline-dark:hover { background: var(--dark); color: var(--white); }
.btn--block        { display: flex; width: 100%; margin-top: 1rem; }

/* ---------- Top banner ---------- */
.topbar { background: var(--primary-deep); color: #fff; padding: 10px 0; font-size: .875rem; }
.topbar__inner { display: flex; align-items: center; justify-content: space-between; }
.topbar__note { margin: 0; opacity: .9; }
.topbar__phone { display: inline-flex; align-items: center; gap: .5rem; font-weight: 500; transition: opacity var(--tr); }
.topbar__phone:hover { opacity: .8; }

/* ---------- Sticky header ---------- */
.site-header { position: sticky; top: 0; z-index: 50; transition: background .4s ease, box-shadow .4s ease; background: transparent; }
.site-header.is-scrolled { background: rgba(255,255,255,.85); backdrop-filter: blur(10px); box-shadow: 0 1px 6px rgba(0,0,0,.06); }
.site-header__inner { display: flex; align-items: center; justify-content: space-between; height: 80px; gap: 1rem; }
.site-logo img { height: 44px; width: auto; }

.primary-nav { display: flex; align-items: center; }
.nav-item { position: relative; }
.nav-link { display: inline-flex; align-items: center; gap: 4px; padding: 8px 10px; font-size: .875rem; font-weight: 500; color: var(--dark); position: relative; transition: color var(--tr); white-space: nowrap; }
.nav-link:hover { color: var(--primary-deep); }
.nav-link::after { content: ''; position: absolute; bottom: 2px; left: 10px; right: 10px; height: 2px; width: 0; background: var(--primary-deep); transition: width var(--tr); }
.nav-item:hover > .nav-link::after { width: calc(100% - 20px); }
.nav-caret { transition: transform var(--tr); }
.nav-item:hover .nav-caret { transform: rotate(180deg); }

.nav-dropdown { position: absolute; top: 100%; left: 0; padding-top: 8px; opacity: 0; visibility: hidden; transform: translateY(8px); transition: opacity var(--tr), transform var(--tr), visibility var(--tr); }
.nav-item.has-children:hover .nav-dropdown { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-dropdown-inner { background: #fff; border: 1px solid #f0f0f0; border-radius: 12px; box-shadow: 0 12px 30px rgba(0,0,0,.12); padding: 8px 0; min-width: 210px; }
.nav-dropdown-inner a { display: block; padding: 10px 16px; font-size: .875rem; color: var(--dark); transition: background var(--tr), color var(--tr); }
.nav-dropdown-inner a:hover { background: rgba(184,201,220,.2); color: var(--primary-deep); }

.header-cta .btn { font-weight: 600; }

/* ---------- Mobile menu ---------- */
.mobile-toggle { display: none; background: none; border: 0; padding: 6px; color: var(--dark); cursor: pointer; }
.mobile-toggle .icon-close { display: none; }
.mobile-toggle.is-open .icon-menu { display: none; }
.mobile-toggle.is-open .icon-close { display: block; }
.mobile-menu { display: none; background: #fff; border-top: 1px solid #eee; overflow: hidden; max-height: 0; transition: max-height .3s ease; }
.mobile-menu.is-open { max-height: 90vh; overflow-y: auto; }
.mobile-menu__inner { padding: 1.5rem clamp(16px,5vw,32px); }
.m-nav-link { display: block; padding: 12px 16px; font-weight: 500; border-radius: 10px; transition: background var(--tr); }
.m-nav-link:hover { background: rgba(184,201,220,.2); }
.m-nav-sub { margin-left: 1rem; }
.m-nav-sub a { display: block; padding: 8px 16px; font-size: .875rem; color: var(--muted); transition: color var(--tr); }
.m-nav-sub a:hover { color: var(--primary-deep); }

/* ---------- Fixed bottom action bar ---------- */
.actionbar { position: fixed; bottom: 0; left: 0; right: 0; z-index: 40; background: #fff; box-shadow: 0 -1px 8px rgba(0,0,0,.08); padding: 8px 0; }
.actionbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.actionbar__note { font-size: .875rem; color: rgba(42,46,51,.8); }
.actionbar__btns { display: flex; align-items: center; gap: .5rem; margin-left: auto; }
.actionbar .btn { padding: .55rem 1.1rem; font-size: .85rem; }

/* ---------- Footer ---------- */
.site-footer { background: var(--dark); color: #fff; margin-bottom: 64px; }
.site-footer .container { padding-block: 64px; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr; gap: 2.5rem; }
.footer-logo { height: 40px; filter: brightness(0) invert(1); margin-bottom: 1.25rem; }
.footer-tagline { color: rgba(255,255,255,.7); font-size: .875rem; margin-bottom: 1.25rem; }
.footer-contact-link { display: flex; align-items: center; gap: .5rem; color: var(--accent); font-weight: 500; margin-bottom: .5rem; transition: opacity var(--tr); }
.footer-contact-link:hover { opacity: .8; }
.footer-social { display: flex; gap: 1rem; margin-top: 1rem; }
.footer-social a { color: #fff; transition: color var(--tr); }
.footer-social a:hover { color: var(--accent); }
.footer-col h4 { color: var(--accent); font-family: var(--ff-b); font-weight: 600; margin-bottom: 1.25rem; }
.footer-col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .75rem; }
.footer-col a { color: rgba(255,255,255,.7); font-size: .875rem; transition: color var(--tr); }
.footer-col a:hover { color: #fff; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); margin-top: 3rem; padding-top: 2rem; display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; }
.footer-bottom p { color: rgba(255,255,255,.5); font-size: .875rem; margin: 0; }
.footer-legal { display: flex; gap: 1.5rem; font-size: .875rem; }
.footer-legal a { color: rgba(255,255,255,.5); transition: color var(--tr); }
.footer-legal a:hover { color: #fff; }

/* ---------- Mobile floating call ---------- */
.float-call { display: none; position: fixed; bottom: 84px; right: 20px; z-index: 45; width: 56px; height: 56px; align-items: center; justify-content: center; background: var(--accent); color: var(--dark); border-radius: 50%; box-shadow: 0 8px 20px rgba(118,195,239,.35); transition: transform var(--tr); }
.float-call:hover { transform: scale(1.05); }

/* ---------- Popup ---------- */
.popup-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.62); z-index: 9998; display: none; align-items: center; justify-content: center; opacity: 0; transition: opacity .3s ease; padding: 1rem; }
.popup-overlay.is-open { display: flex; opacity: 1; }
.popup { background: #fff; border-radius: 18px; padding: 2rem; max-width: 480px; width: 100%; position: relative; }
.popup__close { position: absolute; top: 14px; right: 16px; background: none; border: 0; font-size: 1.2rem; cursor: pointer; color: var(--muted); }

/* ---------- Reveal ---------- */
.reveal { opacity: 0; transform: translateY(32px); transition: opacity .75s ease, transform .75s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

.hide-mobile { display: inline; }
.show-mobile { display: none; }

/* ============ Interior pages (shared) ============ */
.page-header { position: relative; overflow: hidden; padding-block: clamp(64px, 10vw, 112px); background: linear-gradient(135deg, #F8F9FA, #fff 50%, rgba(184,201,220,.1)); }
.page-header__blob { position: absolute; border-radius: 50%; filter: blur(80px); }
.page-header__blob--1 { top: -100px; right: -100px; width: 500px; height: 500px; background: rgba(184,201,220,.1); }
.page-header__blob--2 { bottom: -80px; left: -80px; width: 300px; height: 300px; background: rgba(226,212,188,.12); }
.page-header__inner { position: relative; text-align: center; max-width: 48rem; margin: 0 auto; }
.page-header__eyebrow { display: block; color: var(--primary-deep); font-weight: 500; font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 1rem; }
.page-header__title { font-size: clamp(2rem, 5vw, 3rem); line-height: 1.1; margin-bottom: 1.25rem; }
.page-header__desc { font-size: 1.2rem; color: var(--muted); margin: 0; line-height: 1.6; }

.interior { padding-block: clamp(48px, 7vw, 80px); }
.interior--alt { background: #F8F9FA; }
.interior--dark { background: var(--dark); color: #fff; }
.interior__head { text-align: center; max-width: 44rem; margin: 0 auto clamp(36px,5vw,56px); }
.interior__head h2 { font-size: clamp(1.75rem,3.5vw,2.5rem); margin-bottom: 1rem; }
.interior__head p { color: var(--muted); font-size: 1.1rem; margin: 0; }

/* two-column split */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.split__media img { width: 100%; border-radius: 18px; box-shadow: 0 20px 40px rgba(0,0,0,.12); }
.split h2 { font-size: clamp(1.6rem,3vw,2.2rem); margin-bottom: 1.25rem; }
.split p { color: var(--muted); margin-bottom: 1rem; }

/* check list */
.check-list { list-style: none; margin: 1.5rem 0 0; padding: 0; display: flex; flex-direction: column; gap: .9rem; }
.check-list li { display: flex; gap: .75rem; color: var(--muted); }
.check-list svg { color: var(--primary-deep); flex-shrink: 0; margin-top: 3px; }

/* feature/icon cards grid */
.feature-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.feature-grid--2 { grid-template-columns: repeat(2,1fr); }
.feature-grid--4 { grid-template-columns: repeat(4,1fr); }
.feature-card { background: #fff; border: 1px solid rgba(0,0,0,.05); border-radius: 18px; padding: 2rem; transition: box-shadow var(--tr), transform var(--tr); }
.feature-card:hover { box-shadow: 0 20px 40px rgba(0,0,0,.1); transform: translateY(-2px); }
.feature-card__icon { width: 52px; height: 52px; border-radius: 14px; background: linear-gradient(135deg, rgba(184,201,220,.3), rgba(226,212,188,.3)); display: flex; align-items: center; justify-content: center; color: var(--primary-deep); margin-bottom: 1.25rem; }
.feature-card h3 { font-size: 1.2rem; margin-bottom: .6rem; }
.feature-card p { color: var(--muted); margin: 0; font-size: .95rem; }

/* numbered timeline */
.timeline { max-width: 52rem; margin: 0 auto; display: flex; flex-direction: column; gap: 1.25rem; }
.timeline__step { background: #fff; border-radius: 18px; padding: 1.75rem; display: flex; gap: 1.25rem; align-items: flex-start; box-shadow: 0 2px 12px rgba(0,0,0,.05); }
.interior--alt .timeline__step { background: #fff; }
.timeline__num { flex-shrink: 0; width: 42px; height: 42px; border-radius: 50%; background: var(--primary-deep); color: #fff; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.timeline__step h3 { font-size: 1.2rem; margin-bottom: .4rem; }
.timeline__step p { color: var(--muted); margin: 0; }

/* contact CTA band */
.contact-cta { background: var(--dark); padding-block: clamp(48px,7vw,72px); }
.contact-cta__inner { text-align: center; }
.contact-cta__title { color: #fff; font-size: clamp(1.5rem,3vw,2rem); margin-bottom: 1rem; }
.contact-cta__desc { color: rgba(255,255,255,.7); max-width: 40rem; margin: 0 auto 2rem; }
.contact-cta__btns { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; }
.contact-cta__outline { background: transparent; color: #fff; border: 2px solid rgba(255,255,255,.3); }
.contact-cta__outline:hover { border-color: rgba(255,255,255,.6); background: rgba(255,255,255,.1); }

/* Team carousel (About Us) */
.hscroll { position: relative; }
.hscroll__track { display: flex; gap: 1.5rem; overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: 1rem; scrollbar-width: none; }
.hscroll__track::-webkit-scrollbar { display: none; }
.team-card { position: relative; flex: 0 0 clamp(220px,30vw,300px); aspect-ratio: 3/4; border-radius: 24px; overflow: hidden; box-shadow: 0 10px 24px rgba(0,0,0,.12); scroll-snap-align: center; }
.team-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: top; transition: transform .5s ease; }
.team-card:hover img { transform: scale(1.05); }
.team-card__ph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--primary-deep), var(--primary-light)); color: #fff; font-family: var(--ff-h); font-size: 4rem; font-weight: 600; }
.team-card__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.8), rgba(0,0,0,.2) 50%, transparent); }
.team-card__meta { position: absolute; left: 0; right: 0; bottom: 0; padding: 1.25rem; }
.team-card__meta h4 { color: #fff; font-size: 1.05rem; margin: 0 0 .2rem; line-height: 1.2; }
.team-card__role { color: var(--accent); font-size: .875rem; margin: 0; }
.team-card__cred { color: rgba(255,255,255,.6); font-size: .75rem; margin: .15rem 0 0; }
.hscroll__btn { position: absolute; top: 50%; transform: translateY(-50%); z-index: 2; width: 40px; height: 40px; border: 0; border-radius: 50%; background: #fff; box-shadow: 0 6px 16px rgba(0,0,0,.15); color: var(--dark); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background var(--tr), color var(--tr); }
.hscroll__btn:hover { background: var(--accent); }
.hscroll__btn--prev { left: -10px; } .hscroll__btn--next { right: -10px; }
@media (max-width: 767px){ .hscroll__btn { display: none; } }

/* Core Services accordion (About Us) */
.svc-list { display: flex; flex-direction: column; gap: 1rem; }
.svc-item { background: #fff; border: 1px solid #f0f0f0; border-radius: 18px; box-shadow: 0 2px 12px rgba(0,0,0,.04); overflow: hidden; }
.svc-item summary { list-style: none; cursor: pointer; padding: 1.5rem 1.75rem; display: flex; align-items: flex-start; gap: 1.25rem; transition: background var(--tr); }
.svc-item summary::-webkit-details-marker { display: none; }
.svc-item summary:hover { background: #fafafa; }
.svc-num { color: var(--accent); font-family: var(--ff-h); font-weight: 700; font-size: 1.5rem; flex-shrink: 0; }
.svc-head { flex: 1; min-width: 0; }
.svc-title { display: block; font-weight: 700; color: var(--dark); font-size: 1.15rem; margin-bottom: .25rem; }
.svc-purpose { display: block; color: var(--muted); font-size: .9rem; }
.svc-item .faq-chevron { flex-shrink: 0; margin-top: .35rem; color: var(--primary-deep); transition: transform var(--tr); }
.svc-item[open] .faq-chevron { transform: rotate(180deg); }
.svc-body { padding: 0 1.75rem 1.75rem; border-top: 1px solid #f0f0f0; padding-top: 1.5rem; }
.svc-body > p { color: #4B5563; line-height: 1.7; margin: 0 0 1.25rem; }
.svc-label { font-size: .8rem; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; color: var(--dark); margin: 0 0 .75rem; }
.svc-grid { list-style: none; padding: 0; margin: 0 0 1.25rem; display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; }
.svc-grid li { display: flex; gap: .5rem; font-size: .9rem; color: var(--muted); }
.svc-outcome { background: #F0F5FB; border-radius: 12px; padding: 1rem 1.25rem; }
.svc-outcome strong { display: block; color: var(--dark); font-size: .9rem; margin-bottom: .25rem; }
.svc-outcome { color: #4B5563; font-size: .9rem; line-height: 1.6; }
@media (max-width: 640px){ .svc-grid { grid-template-columns: 1fr; } }

/* About Us dark hero */
.au-hero { position: relative; background: var(--dark); padding-block: clamp(72px,10vw,112px); overflow: hidden; text-align: center; }
.au-hero__inner { position: relative; max-width: 48rem; margin: 0 auto; }
.au-hero__inner .section-head__eyebrow { color: var(--accent); }
.au-hero__inner h1 { color: #fff; font-size: clamp(2.5rem,6vw,4rem); margin-bottom: 0; }
.au-hero__inner .founder__rule { margin: 1.25rem auto; }
.au-hero__inner p { color: rgba(255,255,255,.7); font-size: 1.25rem; max-width: 36rem; margin: 0 auto; }

/* Blog */
.blog-featured { display: grid; grid-template-columns: 1fr 1fr; background: #F8F9FA; border-radius: 24px; overflow: hidden; }
.blog-featured__media img { width: 100%; height: 100%; min-height: 280px; object-fit: cover; }
.blog-featured__body { padding: clamp(2rem,4vw,3rem); display: flex; flex-direction: column; justify-content: center; }
.blog-meta { display: flex; align-items: center; gap: 1rem; }
.blog-tag { padding: .3rem .8rem; background: rgba(107,122,153,.1); color: var(--primary-deep); border-radius: 999px; font-size: .8rem; font-weight: 500; }
.blog-time { color: var(--muted); font-size: .8rem; }
@media (max-width: 767px){ .blog-featured { grid-template-columns: 1fr; } }

/* FAQ accordion */
.faq-cat { margin-bottom: 3rem; }
.faq-item { border: 1px solid #e5e7eb; border-radius: 12px; overflow: hidden; margin-bottom: 1rem; }
.faq-item summary { list-style: none; cursor: pointer; padding: 1rem 1.5rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; font-weight: 500; color: var(--dark); transition: background var(--tr); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:hover { background: #F8F9FA; }
.faq-chevron { flex-shrink: 0; color: var(--primary-deep); transition: transform var(--tr); }
.faq-item[open] .faq-chevron { transform: rotate(180deg); }
.faq-answer { padding: 0 1.5rem 1.25rem; color: var(--muted); line-height: 1.7; }

/* crisis notice */
.crisis-notice { background: #FEF2F2; border-bottom: 1px solid #FEE2E2; }
.crisis-notice .container { display: flex; align-items: center; justify-content: center; gap: .75rem; padding-block: 14px; }
.crisis-notice svg { color: #DC2626; flex-shrink: 0; }
.crisis-notice p { color: #991B1B; margin: 0; font-size: .95rem; }
.crisis-notice a { text-decoration: underline; font-weight: 600; }

/* prose (legal pages) */
.prose { max-width: 48rem; margin: 0 auto; color: var(--muted); }
.prose h2 { color: var(--dark); font-size: 1.5rem; margin: 2rem 0 .75rem; }
.prose h3 { color: var(--dark); font-size: 1.2rem; margin: 1.5rem 0 .5rem; }
.prose p, .prose li { line-height: 1.8; }
.prose ul { padding-left: 1.25rem; }
.page-title { font-size: clamp(2rem,4vw,2.75rem); margin-bottom: 1.5rem; }

@media (max-width: 1024px) {
    .split { grid-template-columns: 1fr; }
    .feature-grid, .feature-grid--4 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 767px) {
    .feature-grid, .feature-grid--2, .feature-grid--4 { grid-template-columns: 1fr; }
}

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
    .primary-nav, .header-cta { display: none; }
    .mobile-toggle { display: inline-flex; }
    .mobile-menu { display: block; }
    .site-header { background: rgba(255,255,255,.92); backdrop-filter: blur(8px); }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 767px) {
    .topbar__note { display: none; }
    .topbar__phone { margin-inline: auto; }
    .actionbar__note { display: none; }
    .actionbar__call { display: none; }
    .float-call { display: flex; }
    .hide-mobile { display: none; }
    .show-mobile { display: inline; }
    .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
    .footer-bottom { flex-direction: column; text-align: center; }
}
