:root {
  --faq-white: #ffffff;
  --faq-cream: #f8f6f3;
  --faq-cream-2: #f1ebe2;
  --faq-black: #1d1d1d;
  --faq-text: #59534d;
  --faq-gold: #c8a97e;
  --faq-gold-dark: #a78255;
  --faq-border: rgba(29, 29, 29, .12);
  --faq-serif: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --faq-sans: "Montserrat", "Poppins", Arial, sans-serif;
}

.esthecoach-faq-page { background: var(--faq-white); color: var(--faq-black); font-family: var(--faq-sans); overflow: hidden; }
.faq-container { width: min(1180px, calc(100% - 48px)); margin: 0 auto; }
.faq-container--narrow { width: min(820px, calc(100% - 48px)); text-align: center; }
.faq-kicker { font-size: 12px; letter-spacing: .18em; text-transform: uppercase; color: var(--faq-gold-dark); margin: 0 0 22px; }

/* .faq-hero { background: linear-gradient(100deg, var(--faq-cream), #fff 62%); } */
.faq-hero { background-position: right center;background-repeat: no-repeat;background-size: cover; }
@media screen and (max-width:980px){
  .faq-hero{
    background: #E0CAB4;
    background-image: none;
  }
  .faq-hero__content{
    width: 100% !important;
  }
}
.faq-hero__inner { display: grid; grid-template-columns: minmax(0, 1fr) minmax(420px, 52vw); min-height: 620px; align-items: center; }
.faq-hero__content { padding: 90px 7vw; max-width: 720px; }
.faq-hero h1, .faq-expertise h2, .faq-popular h2, .faq-local h2 { font-family: var(--faq-serif); font-weight: 400; line-height: .98; letter-spacing: -.03em; }
.faq-hero h1 { font-size: clamp(44px, 5vw, 76px); margin: 0 0 30px; }
.faq-hero__intro { font-size: 17px; line-height: 1.85; color: var(--faq-text); max-width: 600px; }
.faq-hero__actions { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 34px; }
.faq-hero__media { height: 100%; position: relative; display: block; clip-path: ellipse(86% 72% at 66% 50%); }
.faq-hero__media img { width: 100%; height: 100%; object-fit: cover; display: block; }

.faq-btn { display: inline-flex; align-items: center; justify-content: center; min-height: 50px; padding: 15px 28px; border: 1px solid var(--faq-gold); text-transform: uppercase; letter-spacing: .12em; font-size: 11px; font-weight: 600; text-decoration: none; transition: .25s ease; }
.faq-btn--primary { background: var(--faq-gold); color: #fff; }
.faq-btn--primary:hover { background: var(--faq-gold-dark); border-color: var(--faq-gold-dark); color: #fff; }
.faq-btn--secondary { background: transparent; color: var(--faq-black); border-color: rgba(29,29,29,.35); }
.faq-btn--secondary:hover { border-color: var(--faq-gold); color: var(--faq-gold-dark); }

.faq-expertise { padding: 80px 0 54px; }
.faq-expertise h2 { font-size: clamp(34px, 3vw, 48px); margin: 0 0 22px; }
.faq-richtext { color: var(--faq-text); font-size: 16px; line-height: 1.85; }
.faq-richtext p { margin: 0 0 1em; }

.faq-anchor-nav { position: sticky; top: 0; z-index: 5; background: rgba(255,255,255,.94); backdrop-filter: blur(14px); border-top: 1px solid var(--faq-border); border-bottom: 1px solid var(--faq-border); }
.faq-anchor-nav__inner { width: min(1180px, calc(100% - 48px)); margin: 0 auto; display: flex; gap: 0; overflow-x: auto; }
.faq-anchor-nav span { flex: 0 0 auto; padding: 22px 26px 22px 0; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; }
.faq-anchor-nav a { flex: 0 0 auto; padding: 18px 20px; border-left: 1px solid var(--faq-border); text-decoration: none; color: var(--faq-black); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; display: grid; gap: 7px; text-align: center; }
.faq-anchor-nav a em { font-style: normal; color: var(--faq-gold); font-size: 18px; }

.faq-main { display: grid; grid-template-columns: 285px minmax(0, 1fr); border: 1px solid var(--faq-border); margin-top: 44px; margin-bottom: 72px; align-items: start; }
.faq-sidebar { position: sticky; top: 92px; min-height: 640px; padding: 45px 36px; border-right: 1px solid var(--faq-border); background: #fff; }
.faq-sidebar p { margin: 0 0 28px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; }
.faq-sidebar ol { list-style: none; margin: 0; padding: 0; display: grid; gap: 16px; }
.faq-sidebar a { color: var(--faq-black); text-decoration: none; font-family: var(--faq-serif); font-size: 17px; line-height: 1.2; }
.faq-sidebar span { font-family: var(--faq-sans); color: var(--faq-gold-dark); font-size: 11px; margin-right: 16px; }
.faq-main > *{
  background: linear-gradient(100deg, var(--faq-cream), #fff 62%)
}
.faq-sections { padding: 45px 44px; }
.faq-section { scroll-margin-top: 120px; border-bottom: 1px solid var(--faq-border); padding: 0 0 22px; margin-bottom: 22px; }
.faq-section:last-child { border-bottom: 0; }
.faq-section__header { display: flex; gap: 18px; align-items: baseline; margin-bottom: 18px; }
.faq-section__header span { color: var(--faq-gold-dark); font-size: 13px; font-weight: 700; letter-spacing: .12em; }
.faq-section h2 { margin: 0; color: var(--faq-gold-dark); font-size: 14px; text-transform: uppercase; letter-spacing: .16em; font-weight: 700; }

.faq-item { border-top: 1px solid var(--faq-border); }
.faq-item__toggle { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: 24px; padding: 28px 0 18px; border: 0; background: transparent; cursor: pointer; text-align: left; color: var(--faq-black); }
.faq-item__toggle h3 { font-family: var(--faq-serif); font-weight: 400; font-size: clamp(25px, 2.5vw, 36px); line-height: 1.12; letter-spacing: -.02em; margin: 0; }
.faq-item__toggle span { color: var(--faq-gold-dark); font-size: 24px; transition: transform .25s ease; }
.faq-item.is-open .faq-item__toggle span { transform: rotate(45deg); }
.faq-item__answer { max-height: none; padding: 0 60px 28px 0; }
.js .faq-item:not(.is-open) .faq-item__answer { display: none; }
.faq-inline-link { display: inline-block; margin-top: 12px; color: var(--faq-gold-dark); text-transform: uppercase; letter-spacing: .12em; font-size: 11px; font-weight: 700; text-decoration: none; }

.faq-popular { background: var(--faq-cream); padding: 70px 0; }
.faq-popular__grid { display: grid; grid-template-columns: 1fr 360px; gap: 48px; align-items: center; }
.faq-popular h2 { font-size: clamp(32px, 3vw, 46px); margin: 0 0 28px; }
.faq-popular__cards { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.faq-popular__cards a { background: #fff; border: 1px solid rgba(29,29,29,.06); padding: 18px 20px; min-height: 68px; color: var(--faq-black); text-decoration: none; font-size: 14px; line-height: 1.35; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.faq-popular__cards span { color: var(--faq-gold-dark); font-size: 22px; }
.faq-popular img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; }

.faq-local { display: grid; grid-template-columns: 1.15fr 1fr 1fr 260px; gap: 40px; padding: 58px 0; border-top: 1px solid var(--faq-border); }
.faq-local h2 { font-size: 36px; margin: 0 0 16px; }
.faq-local h3 { font-family: var(--faq-serif); font-size: 24px; font-weight: 400; margin: 0 0 16px; }
.faq-local p, .faq-local a { color: var(--faq-text); line-height: 1.75; }
.faq-local__cta { border: 1px solid var(--faq-border); padding: 28px; text-align: center; }
.faq-local__cta p { font-family: var(--faq-serif); font-size: 24px; color: var(--faq-black); line-height: 1.2; margin-top: 0; }

@media (max-width: 980px) {
  .faq-hero__inner, .faq-main, .faq-popular__grid, .faq-local { grid-template-columns: 1fr; }
  .faq-hero__inner { min-height: 0; }
  .faq-hero__content { padding: 70px 24px 40px; }
  .faq-hero__media { clip-path: none; height: 340px; }
  .faq-sidebar { display: none; }
  .faq-sections { padding: 28px 22px; }
  .faq-main { width: min(100% - 28px, 1180px); }
  .faq-popular__cards { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .faq-container, .faq-container--narrow, .faq-anchor-nav__inner { width: calc(100% - 28px); }
  .faq-hero h1 { font-size: 42px; }
  .faq-hero__actions { display: grid; }
  .faq-anchor-nav a { padding: 14px 16px; }
  .faq-item__toggle h3 { font-size: 25px; }
  .faq-item__answer { padding-right: 0; }
  .faq-local { gap: 24px; }
}
