/* ====================================================================
   THE MIND — Shared CSS for secondary/SEO pages
   Import this + Google Fonts in every service page and blog post.
   ==================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Chakra+Petch:wght@400;500;600;700&family=Urbanist:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; }
body {
  font-family: 'Urbanist', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-weight: 500;
  color: #0A0A0A;
  background: #F5F3EE;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }

:root {
  --ink:       #0A0A0A;
  --paper:     #F5F3EE;
  --muted:     #55555C;
  --cobalt:    #375FA7;
  --mint:      #8BD0BC;
  --sky:       #75BDE1;
  --lav:       #B6A2D7;
  --coral:     #E8637A;
  --signature: linear-gradient(115deg, #75BDE1 0%, #B6A2D7 35%, #E8637A 65%, #375FA7 100%);
  --max:       1360px;
  --gutter:    32px;
  --ease-out:  cubic-bezier(.19, 1, .22, 1);
}

h1, h2, h3, h4 {
  font-family: 'Chakra Petch', -apple-system, BlinkMacSystemFont, sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -.035em;
  line-height: .98;
  color: #0A0A0A;
}
h1 { font-size: clamp(2.2rem, 5vw, 4.8rem); line-height: .92; letter-spacing: -.045em; }
h2 { font-size: clamp(1.6rem, 3vw, 2.6rem); margin-bottom: 1.5rem; }
h3 { font-size: clamp(1rem, 1.6vw, 1.2rem); letter-spacing: -.01em; font-weight: 600; margin-bottom: .75rem; }
p  { font-size: 1rem; line-height: 1.6; color: var(--muted); margin-bottom: 1.2rem; }
p:last-child { margin-bottom: 0; }

.eyebrow {
  font-family: 'Chakra Petch', sans-serif;
  font-size: .8rem; font-weight: 500;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--muted); margin-bottom: 1rem; display: block;
}
.grad-text {
  background: var(--signature);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}

/* Nav */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 20px var(--gutter);
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(245,243,238,.92);
  backdrop-filter: blur(18px) saturate(160%);
  border-bottom: 1px solid rgba(10,10,10,.08);
}
.nav-logo {
  font-family: 'Chakra Petch', sans-serif;
  font-weight: 700; font-size: 1rem;
  text-transform: uppercase; letter-spacing: .06em;
}
.nav-pill {
  font-family: 'Chakra Petch', sans-serif;
  font-size: .8rem; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase;
  background: var(--ink); color: #fff;
  padding: 10px 20px; border-radius: 999px;
  transition: opacity .25s;
}
.nav-pill:hover { opacity: .75; }

/* Page hero */
.page-hero {
  padding: 160px var(--gutter) 100px;
  max-width: var(--max); margin: 0 auto;
}
.page-hero h1 { margin-bottom: 1.5rem; }
.hero-lead {
  font-size: 1.1rem; line-height: 1.6; color: var(--muted);
  max-width: 640px; margin-bottom: 2rem;
}
.hero-lead strong { font-family: 'Chakra Petch', sans-serif; font-weight: 600; color: var(--ink); }

/* Sections */
.section { padding: 80px var(--gutter); border-top: 1px solid rgba(10,10,10,.1); }
.section-inner { max-width: var(--max); margin: 0 auto; }
.section--dark { background: var(--ink); color: #fff; border-top-color: rgba(255,255,255,.08); }
.section--dark h2, .section--dark h3 { color: #fff; }
.section--dark p { color: rgba(255,255,255,.65); }
.section--dark .eyebrow { color: rgba(255,255,255,.4); }

/* Two-col */
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 60px 80px; align-items: start; }
@media (max-width: 768px) { .two-col { grid-template-columns: 1fr; gap: 40px; } }

/* Service list */
.svc-list { display: flex; flex-direction: column; gap: 1px; margin-top: 2rem; }
.svc-item { padding: 28px 0; border-top: 1px solid rgba(10,10,10,.1); display: flex; gap: 24px; align-items: start; }
.section--dark .svc-item { border-top-color: rgba(255,255,255,.1); }
.svc-num { font-family: 'Chakra Petch', sans-serif; font-size: .75rem; font-weight: 600; letter-spacing: .08em; color: var(--muted); min-width: 32px; padding-top: 3px; }
.section--dark .svc-num { color: rgba(255,255,255,.35); }
.svc-body h3 { margin-bottom: .5rem; }
.svc-link {
  font-family: 'Chakra Petch', sans-serif;
  font-size: .75rem; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--cobalt); margin-top: .75rem; display: inline-block;
  transition: opacity .2s;
}
.svc-link:hover { opacity: .65; }

/* FAQ accordion */
.faq-list { display: flex; flex-direction: column; gap: 0; margin-top: 2rem; }
.faq-item { border-top: 1px solid rgba(10,10,10,.1); }
.section--dark .faq-item { border-top-color: rgba(255,255,255,.1); }
.faq-item:last-child { border-bottom: 1px solid rgba(10,10,10,.1); }
.section--dark .faq-item:last-child { border-bottom-color: rgba(255,255,255,.1); }
.faq-q {
  width: 100%; background: none; border: none; cursor: pointer;
  font-family: 'Chakra Petch', sans-serif; font-weight: 600; font-size: 1rem;
  text-transform: uppercase; letter-spacing: -.01em;
  color: inherit; text-align: left;
  padding: 24px 0; display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.faq-q::after { content: '+'; font-size: 1.4rem; font-weight: 300; flex-shrink: 0; transition: transform .3s var(--ease-out); font-family: 'Urbanist', sans-serif; text-transform: none; }
.faq-item.open .faq-q::after { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .45s var(--ease-out), padding .3s; }
.faq-item.open .faq-a { max-height: 600px; padding-bottom: 24px; }
.faq-a p { color: var(--muted); font-size: .95rem; margin: 0; }
.section--dark .faq-a p { color: rgba(255,255,255,.6); }

/* CTA band */
.cta-band { background: var(--ink); color: #fff; padding: 100px var(--gutter); text-align: center; }
.cta-band h2 { margin-bottom: 1rem; }
.cta-band p { color: rgba(255,255,255,.6); max-width: 480px; margin: 0 auto 2rem; }
.cta-btn {
  display: inline-block;
  font-family: 'Chakra Petch', sans-serif; font-weight: 700; font-size: .85rem;
  letter-spacing: .08em; text-transform: uppercase;
  padding: 16px 36px; border-radius: 999px; transition: opacity .25s;
  background: #fff; color: var(--ink);
}
.cta-btn.grad { background: var(--signature); color: #fff; }
.cta-btn:hover { opacity: .85; }

/* Footer */
.footer { background: var(--ink); color: rgba(255,255,255,.5); padding: 40px var(--gutter); border-top: 1px solid rgba(255,255,255,.08); }
.footer-inner { max-width: var(--max); margin: 0 auto; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.footer-legal { font-family: 'Chakra Petch', sans-serif; font-size: .75rem; text-transform: uppercase; letter-spacing: .06em; }
.footer-link { color: rgba(255,255,255,.4); transition: color .3s; font-family: 'Chakra Petch', sans-serif; font-size: .75rem; text-transform: uppercase; letter-spacing: .06em; }
.footer-link:hover { color: rgba(255,255,255,.8); }

/* Responsive */
@media (max-width: 600px) {
  :root { --gutter: 20px; }
  .page-hero { padding: 140px var(--gutter) 60px; }
  .section { padding: 60px var(--gutter); }
  .nav { padding: 16px var(--gutter); }
  .cta-band { padding: 60px var(--gutter); }
}

/* FAQ script */
