/* =========================================================
   Blu Legacy Law — editorial luxury stylesheet
   Palette: navy #0F2A5A · gold #D4AF37 · white #FFFFFF
   ========================================================= */

:root{
  --navy:        #0F2A5A;
  --navy-deep:   #0A1F44;
  --navy-soft:   #1A3A6E;
  --gold:        #D4AF37;
  --gold-soft:   #B8962E;
  --gold-faint:  rgba(212,175,55,0.22);
  --ivory:       #F5F1E8;
  --white:       #FFFFFF;
  --muted:       rgba(255,255,255,0.88);
  --hairline:    rgba(212,175,55,0.28);
  --serif:       "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --sans:        "Inter", "Lato", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --script:      "Pinyon Script", "Allura", cursive;
  --maxw:        1280px;
  --gutter:      clamp(20px, 5vw, 64px);
  --section-y:   clamp(48px, 6vw, 84px);
  --section-y-tight: clamp(36px, 4vw, 56px);
  --ease:        cubic-bezier(.2,.6,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--navy);
  color:var(--ivory);
  font-family:var(--sans);
  font-weight:400;
  font-size:17px;
  line-height:1.75;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  /* very faint film grain + subtle radial gradient */
  background-image:
    radial-gradient(1200px 800px at 80% -10%, rgba(212,175,55,0.05), transparent 60%),
    radial-gradient(900px 700px at -10% 110%, rgba(212,175,55,0.04), transparent 55%);
}
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.06;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

.skip{position:absolute;left:-9999px}
.skip:focus{left:1rem;top:1rem;background:var(--gold);color:var(--navy);padding:.5rem 1rem;z-index:9999}

/* =========================================================
   TYPOGRAPHY
   ========================================================= */
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.08;letter-spacing:-.005em;margin:0;color:var(--white)}
h1{font-size:clamp(2.6rem, 6.2vw, 5.4rem)}
h2{font-size:clamp(2rem, 4.4vw, 3.6rem)}
h3{font-size:clamp(1.25rem, 1.8vw, 1.55rem)}
em{font-style:italic;color:var(--gold)}
p{margin:0 0 1.1em}
.eyebrow{
  font-family:var(--sans);
  font-size:.82rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin:0 0 1.6rem;
  display:inline-block;
}
.section__title{margin-bottom:1.2rem}
.section__head{max-width:780px;margin:0 auto clamp(28px,3.5vw,48px);text-align:center;padding:0 var(--gutter)}

/* =========================================================
   BUTTONS / LINKS
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:1rem 2.2rem;
  font-family:var(--sans);font-size:.78rem;font-weight:500;
  letter-spacing:.28em;text-transform:uppercase;
  border:1px solid var(--gold);
  color:var(--gold);
  background:transparent;
  position:relative;
  transition:color .35s var(--ease), background .35s var(--ease), letter-spacing .4s var(--ease);
}
.btn:hover{background:var(--gold);color:var(--navy);letter-spacing:.32em}
.btn--gold{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.btn--gold:hover{background:transparent;color:var(--gold)}
.btn--xl{padding:1.2rem 3rem;font-size:.82rem}

.link-arrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--sans);font-size:.78rem;font-weight:500;
  letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);
  padding-bottom:.35rem;
  border-bottom:1px solid var(--gold-faint);
  transition:border-color .3s var(--ease), gap .3s var(--ease);
}
.link-arrow:hover{border-bottom-color:var(--gold);gap:1rem}

/* hairline rule */
.rule{height:1px;background:linear-gradient(90deg, transparent, var(--gold-faint) 18%, var(--gold-faint) 82%, transparent)}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  padding:1.6rem var(--gutter);
  transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(15,42,90,0.85);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  padding:1.1rem var(--gutter);
  border-bottom:1px solid var(--hairline);
}
.nav__inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
}
.brand{display:inline-flex;align-items:baseline;gap:.55rem;line-height:1;white-space:nowrap;flex-shrink:0}
.brand__script{
  font-family:var(--script);
  color:var(--white);
  font-size:2.4rem;
  letter-spacing:.01em;
}
.brand__mark{
  font-family:var(--sans);
  color:var(--gold);
  font-size:.78rem;
  letter-spacing:.42em;
  font-weight:500;
  padding-left:.7rem;
  border-left:1px solid var(--hairline);
}
.nav__links{display:flex;align-items:center;gap:2.4rem}
.nav__links a{
  font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ivory);position:relative;padding:.4rem 0;
  transition:color .3s var(--ease);
}
.nav__links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.nav__links a:hover::after,
.nav__links a.is-active::after{transform:scaleX(1)}
.nav__links a:hover{color:var(--white)}
.nav__cta{
  border:1px solid var(--gold);
  color:var(--gold) !important;
  padding:.65rem 1.3rem !important;
  transition:background .3s var(--ease), color .3s var(--ease) !important;
}
.nav__cta::after{display:none}
.nav__cta:hover{background:var(--gold);color:var(--navy) !important}

.nav__toggle{
  display:none;
  width:36px;height:36px;
  flex-direction:column;justify-content:center;align-items:flex-end;gap:6px;
  padding:0;
  position:relative;z-index:81;
}
.nav__toggle span{display:block;height:1px;background:var(--gold);width:24px;transition:transform .35s var(--ease), width .25s var(--ease), opacity .25s var(--ease)}
.nav__toggle span:nth-child(2){width:18px}
.nav__toggle[aria-expanded="true"] span{width:24px}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(3.5px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){transform:translateY(-3.5px) rotate(-45deg)}

.nav__mobile{
  display:none;
  position:fixed;top:0;left:0;right:0;bottom:0;
  height:100vh;height:100dvh;width:100%;
  background:var(--navy-deep);
  padding:6rem var(--gutter) 2rem;
  flex-direction:column;gap:0;
  z-index:95;
  overflow-y:auto;
}
body.menu-open .callfab{display:none !important}
.nav__mobile a{
  font-family:var(--serif);font-size:1.6rem;color:var(--ivory);
  letter-spacing:0;
  padding:1.3rem 0;
  border-bottom:1px solid var(--hairline);
  transition:color .3s var(--ease);
}
.nav__mobile a:hover{color:var(--gold)}
.nav__mobile .nav__cta{
  font-family:var(--sans) !important;
  font-size:.85rem !important;
  letter-spacing:.28em !important;
  text-transform:uppercase;
  text-align:center;
  color:var(--gold) !important;
  border:1px solid var(--gold) !important;
  margin-top:2rem;
  padding:1.1rem !important;
}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;
  display:flex;align-items:flex-start;justify-content:center;
  padding:160px var(--gutter) 140px;
  overflow:hidden;
  isolation:isolate;
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(60% 50% at 50% 40%, rgba(212,175,55,0.06), transparent 70%),
    linear-gradient(180deg, var(--navy) 0%, var(--navy-soft) 50%, var(--navy) 100%);
}
.hero__watermark{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:var(--gold);opacity:.05;z-index:-1;pointer-events:none;
}
.hero__watermark svg{width:min(720px,75vw);height:auto}
.hero__inner{max-width:980px;text-align:center;position:relative;z-index:1}
.hero__title{margin:0 0 1.8rem}
.hero__title em{display:block;color:var(--gold);font-style:italic}
.hero__sub{
  max-width:880px;margin:0 auto 2.6rem;
  font-size:clamp(1.3rem,1.7vw,1.55rem);
  color:var(--muted);line-height:1.65;
  font-weight:300;
}
.hero__cta{display:flex;flex-direction:column;align-items:center;gap:1.1rem}
.hero__fineprint{
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--muted);
}
.hero__scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  font-size:.65rem;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);
}
.hero__scroll .line{width:1px;height:28px;background:var(--gold);opacity:.5;animation:scrollHint 2.4s var(--ease) infinite}
@keyframes scrollHint{
  0%{transform:scaleY(.2);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(.2);transform-origin:bottom}
}

/* =========================================================
   CREDIBILITY STRIP
   ========================================================= */
.credstrip{
  padding:2.6rem var(--gutter);
  display:flex;flex-direction:column;gap:1.6rem;
}
.credstrip__list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:1rem 3rem;
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ivory);
}
.credstrip__list li{position:relative;padding:0 .2rem;color:var(--ivory)}
.credstrip__list li + li::before{
  content:"·";position:absolute;left:-1.6rem;top:50%;transform:translateY(-50%);
  color:var(--gold);font-size:1.2rem;
}

/* =========================================================
   ABOUT (editorial — ivory section)
   ========================================================= */
.about{
  padding:var(--section-y) var(--gutter);
  background:var(--ivory);
  color:var(--navy-deep);
  position:relative;
}
.about .eyebrow{color:var(--gold-soft)}
.about h2{color:var(--navy-deep)}
.about em{color:var(--gold-soft)}
.about__grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;gap:clamp(40px,5vw,72px);
  grid-template-columns:1.05fr 1fr;align-items:center;
}
.about__copy p{color:rgba(15,42,90,0.82);font-size:1.18rem;line-height:1.75;max-width:54ch;margin-bottom:1.1em}
.about__copy .link-arrow{
  margin-top:1.2rem;color:var(--gold-soft);
  border-bottom-color:rgba(184,150,46,0.35);
}
.about__copy .link-arrow:hover{border-bottom-color:var(--gold-soft)}
.about__media{display:flex;justify-content:center}
.portrait{position:relative;width:min(100%,420px)}
.portrait__frame{
  position:relative;
  border:1px solid rgba(15,42,90,0.18);
  padding:12px;
  background:var(--white);
}
.portrait__frame::before{
  content:"";position:absolute;inset:-9px;border:1px solid var(--gold-soft);opacity:.45;pointer-events:none;
}
.portrait__img{
  display:block;
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  object-position:50% 28%;
  filter:saturate(1.02) contrast(1.02);
}
.portrait__caption{
  margin-top:1.4rem;
  display:flex;align-items:center;gap:1rem;
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(15,42,90,0.6);
}
.portrait__caption .caption__line{width:34px;height:1px;background:var(--gold-soft)}

/* =========================================================
   PRACTICE
   ========================================================= */
.practice{padding:var(--section-y) var(--gutter) var(--section-y-tight)}
.practice__list{
  list-style:none;padding:0;margin:0 auto;max-width:920px;
}
.practice__list li{
  display:grid;grid-template-columns:auto 1fr;align-items:baseline;gap:2.2rem;
  padding:1.4rem 0;
  border-bottom:1px solid var(--hairline);
  transition:padding-left .5s var(--ease), color .35s var(--ease);
}
.practice__list li:first-child{border-top:1px solid var(--hairline)}
.practice__list li:hover{padding-left:1.2rem}
.practice__list .num{
  font-family:var(--serif);font-style:italic;font-size:1rem;color:var(--gold);
  letter-spacing:.04em;
}
.practice__list .label{
  font-family:var(--serif);font-size:clamp(1.6rem, 3.2vw, 2.4rem);
  color:var(--white);letter-spacing:-.005em;
}

/* =========================================================
   WHY
   ========================================================= */
.why{padding:var(--section-y-tight) var(--gutter)}
.why__grid{
  max-width:1080px;margin:0 auto;
  display:grid;grid-template-columns:repeat(2, 1fr);
  gap:0;
}
.why__item{
  padding:2.2rem 2.2rem;
  border-top:1px solid var(--hairline);
  position:relative;
}
.why__item:nth-child(2n){border-left:1px solid var(--hairline)}
.why__item:nth-last-child(-n+2){border-bottom:1px solid var(--hairline)}
.why__item h3{font-family:var(--serif);font-style:italic;color:var(--gold);margin:0 0 1rem;font-weight:400;font-size:clamp(1.5rem,2.4vw,1.9rem);letter-spacing:.005em}
.why__item p{color:var(--muted);font-size:1.1rem;line-height:1.75;margin:0;max-width:44ch}

/* =========================================================
   PROCESS
   ========================================================= */
.process{padding:var(--section-y-tight) var(--gutter)}
.process__steps{
  list-style:none;padding:0;margin:0 auto;max-width:1080px;
  display:grid;grid-template-columns:repeat(3, 1fr);gap:0;
}
.process__steps li{
  padding:2rem 1.6rem;
  text-align:center;position:relative;
}
.process__steps li + li{border-left:1px solid var(--hairline)}
.process__steps .step__num{
  display:block;font-family:var(--serif);font-style:italic;
  color:var(--gold);font-size:2.2rem;margin-bottom:1.2rem;
  letter-spacing:.05em;
}
.process__steps h3{margin:0 0 .8rem;color:var(--white)}
.process__steps p{color:var(--muted);font-size:1.08rem;line-height:1.7;margin:0;max-width:36ch;margin-inline:auto}

/* =========================================================
   RESULTS
   ========================================================= */
.results{padding:var(--section-y-tight) var(--gutter);position:relative}
.results::before,.results::after{
  content:"";display:block;height:1px;
  background:linear-gradient(90deg, transparent, var(--hairline), transparent);
}
.results__inner{max-width:880px;margin:0 auto;text-align:center;padding:clamp(40px,5vw,64px) 0}
.results__quote{margin:0 0 3rem;position:relative}
.results__quote .mark{
  font-family:var(--serif);font-style:italic;font-size:5rem;color:var(--gold);
  display:block;line-height:1;margin-bottom:.5rem;
}
.results__quote p{
  font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,2.4vw,1.8rem);
  color:var(--ivory);line-height:1.5;max-width:32ch;margin:0 auto 1.5rem;
}
.results__quote footer{
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--muted);
}
.results__meta{
  display:flex;justify-content:center;gap:3rem;flex-wrap:wrap;
  font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);
}
.results__meta div{display:flex;align-items:center;gap:.7rem}
.results__meta span{color:var(--gold)}
.results__meta p{margin:0}

/* =========================================================
   FAQ — ivory section on homepage
   ========================================================= */
.faq{
  padding:var(--section-y) var(--gutter);
  background:var(--ivory);
  color:var(--navy-deep);
}
.faq__head{text-align:center;margin:0 auto clamp(36px,5vw,60px);max-width:780px}
.faq .eyebrow{color:var(--gold-soft)}
.faq h2{color:var(--navy-deep);font-size:clamp(2.6rem,5.4vw,4.4rem)}
.faq em{color:var(--gold-soft)}
.faq__list{max-width:880px;margin:0 auto 2.6rem}
.faq details{
  border-top:1px solid rgba(15,42,90,0.14);
  padding:1.5rem 0;
}
.faq details:last-child{border-bottom:1px solid rgba(15,42,90,0.14)}
.faq summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
  font-family:var(--serif);font-size:clamp(1.4rem,2.2vw,1.75rem);
  color:var(--navy-deep);
  padding:.5rem 0;
  transition:color .3s var(--ease);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"";width:14px;height:14px;flex:none;
  background:
    linear-gradient(var(--gold-soft),var(--gold-soft)) center/100% 1px no-repeat,
    linear-gradient(var(--gold-soft),var(--gold-soft)) center/1px 100% no-repeat;
  transition:transform .35s var(--ease);
}
.faq details[open] summary::after{
  transform:rotate(45deg);
  background:linear-gradient(var(--gold-soft),var(--gold-soft)) center/100% 1px no-repeat;
}
.faq summary:hover{color:var(--gold-soft)}
.faq__answer{padding-top:.8rem;color:rgba(15,42,90,0.78);max-width:68ch;font-size:1.08rem;line-height:1.75}
.faq__answer p{margin:0}
.faq > .link-arrow{
  display:flex;justify-content:center;margin:0 auto;width:fit-content;
  color:var(--gold-soft);border-bottom-color:rgba(184,150,46,0.4);
}
.faq > .link-arrow:hover{border-bottom-color:var(--gold-soft)}

/* FAQ page question list — ivory section, navy text */
.faqpage .faq__list{margin:0 auto 2.6rem}
.faqpage .faq__list details{
  border-top:1px solid rgba(15,42,90,0.14);
  padding:1.5rem 0;
}
.faqpage .faq__list details:last-child{border-bottom:1px solid rgba(15,42,90,0.14)}
.faqpage .faq__list summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
  font-family:var(--serif);font-size:clamp(1.4rem,2.2vw,1.75rem);
  color:var(--navy-deep);
  padding:.5rem 0;
  transition:color .3s var(--ease);
}
.faqpage .faq__list summary::-webkit-details-marker{display:none}
.faqpage .faq__list summary::after{
  content:"";width:14px;height:14px;flex:none;
  background:
    linear-gradient(var(--gold-soft),var(--gold-soft)) center/100% 1px no-repeat,
    linear-gradient(var(--gold-soft),var(--gold-soft)) center/1px 100% no-repeat;
  transition:transform .35s var(--ease);
}
.faqpage .faq__list details[open] summary::after{
  transform:rotate(45deg);
  background:linear-gradient(var(--gold-soft),var(--gold-soft)) center/100% 1px no-repeat;
}
.faqpage .faq__list summary:hover{color:var(--gold-soft)}
.faqpage .faq__list .faq__answer{
  padding-top:.8rem;color:rgba(15,42,90,0.78);max-width:68ch;
  font-size:1.1rem;line-height:1.75;
}
.faqpage .faq__list .faq__answer p{margin:0}

/* =========================================================
   LOCALE PLATE — Shreveport image, cinematic fade in/out
   ========================================================= */
.locale{
  padding:0;
  background:var(--navy-deep);
}
.locale__figure{
  position:relative;
  margin:0;
  height:clamp(260px, 36vw, 420px);
  overflow:hidden;
}
.locale__figure img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:50% 50%;
  display:block;
}

/* =========================================================
   CONTACT
   ========================================================= */
.contact{
  padding:var(--section-y) var(--gutter);
  position:relative;
  background:
    radial-gradient(70% 50% at 50% 0%, rgba(212,175,55,0.06), transparent 70%),
    var(--navy-deep);
  border-top:1px solid var(--hairline);
}
.contact__inner{max-width:780px;margin:0 auto;text-align:center}
.contact__title{font-size:clamp(2.2rem,4.6vw,3.6rem);margin:0 0 1.4rem}
.contact__lede{color:var(--muted);max-width:56ch;margin:0 auto 3.4rem;font-size:1.15rem;line-height:1.75}
.contact__rows{margin:0 0 3.2rem;border-top:1px solid var(--hairline)}
.contact__row{
  display:grid;grid-template-columns:1fr 2fr;align-items:center;gap:2rem;
  text-align:left;padding:1.6rem 0;border-bottom:1px solid var(--hairline);
}
.contact__label{
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);
}
.contact__value{
  font-family:var(--serif);font-size:clamp(1.3rem,2vw,1.7rem);color:var(--white);
  transition:color .3s var(--ease);
}
a.contact__value:hover{color:var(--gold)}
.contact__fine{margin-top:1.6rem;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{padding:3rem var(--gutter) 2.4rem;border-top:1px solid var(--hairline);background:var(--navy-deep)}
.footer__inner{max-width:var(--maxw);margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.2rem}
.footer__brand{display:inline-flex;align-items:baseline;gap:.55rem}
.footer__addr{font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin:0}
.footer__legal{font-size:.72rem;letter-spacing:.06em;color:rgba(245,241,232,0.45);max-width:60ch;margin:0;line-height:1.7}

/* =========================================================
   FLOATING CALL FAB (mobile)
   ========================================================= */
.callfab{
  display:none;
  position:fixed;bottom:18px;left:18px;right:18px;
  background:#E8C24A;color:var(--navy);
  padding:1rem;border-radius:0;
  align-items:center;justify-content:center;gap:.7rem;
  font-size:.84rem;letter-spacing:.32em;text-transform:uppercase;font-weight:600;
  z-index:90;
  box-shadow:0 10px 30px rgba(0,0,0,0.35);
}
.callfab svg{width:18px;height:18px}
.callfab{transition:opacity .3s var(--ease), transform .3s var(--ease)}
.callfab.is-hidden{opacity:0;transform:translateY(20px);pointer-events:none}

/* =========================================================
   REVEAL ON SCROLL
   ========================================================= */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .9s var(--ease), transform .9s var(--ease)}
.reveal.is-in{opacity:1;transform:none}

/* =========================================================
   ABOUT PAGE
   ========================================================= */
.page-hero{
  padding:160px var(--gutter) clamp(40px,5vw,72px);
  text-align:center;
  position:relative;
  background:linear-gradient(180deg, var(--navy-deep), var(--navy));
  color:var(--ivory);
}
.page-hero h1{margin:0 auto 1.4rem;max-width:18ch}
.page-hero p{color:var(--muted);max-width:60ch;margin:0 auto;font-size:1.15rem;line-height:1.75}

/* About page (light-hero) keeps the ivory hero */
body.light-hero .page-hero{
  background:var(--ivory);
  color:var(--navy-deep);
}
body.light-hero .page-hero .eyebrow{color:var(--gold-soft)}
body.light-hero .page-hero h1{color:var(--navy-deep)}
body.light-hero .page-hero h1 em{color:var(--gold-soft)}
body.light-hero .page-hero p{color:rgba(15,42,90,0.72)}

.bio{padding:var(--section-y-tight) var(--gutter) var(--section-y)}
.bio__inner{max-width:920px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:clamp(40px,6vw,80px)}
.bio__lead{
  font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,2.4vw,2rem);
  color:var(--white);line-height:1.45;text-align:center;
  max-width:36ch;margin:0 auto;
}
.bio__lead::before,.bio__lead::after{
  content:"";display:block;width:60px;height:1px;background:var(--gold);margin:2rem auto;
}
.bio__section{display:grid;grid-template-columns:240px 1fr;gap:3rem;align-items:start}
.bio__section h2{font-size:clamp(1.4rem,2vw,1.7rem);font-style:italic;color:var(--gold);margin:0;font-weight:400}
.bio__section .label{
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);
  display:block;margin-bottom:.8rem;
}
.bio__section p{color:var(--muted);max-width:62ch;font-size:1.1rem;line-height:1.8}
.bio__section ul{margin:0;padding:0;list-style:none}
.bio__section li{padding:.7rem 0;border-bottom:1px solid var(--hairline);color:var(--ivory)}
.bio__section li:first-child{border-top:1px solid var(--hairline)}

/* =========================================================
   FAQ PAGE
   ========================================================= */
.faqpage{
  padding:var(--section-y) var(--gutter);
  background:var(--ivory);
  color:var(--navy-deep);
}
.faqpage__inner{max-width:880px;margin:0 auto}
.faqpage .faqpage__cta p{color:rgba(15,42,90,0.72) !important}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 960px){
  .nav{padding:.85rem var(--gutter)}
  .nav.is-stuck{padding:.7rem var(--gutter)}
  .nav__inner{gap:1rem}
  .brand{gap:.5rem}
  .brand__script{font-size:1.8rem}
  .brand__mark{font-size:.65rem;padding-left:.55rem;letter-spacing:.38em}

  .nav__links{display:none}
  .nav__toggle{display:flex}
  .nav__mobile.is-open{display:flex}

  .hero{padding:130px var(--gutter) 110px}
  .page-hero{padding:130px var(--gutter) clamp(36px,5vw,60px)}

  .about__grid{grid-template-columns:1fr;gap:3.5rem}
  .why__grid{grid-template-columns:1fr}
  .why__item{border-left:0 !important;border-top:1px solid var(--hairline)}
  .why__item:last-child{border-bottom:1px solid var(--hairline)}

  .process__steps{grid-template-columns:1fr}
  .process__steps li + li{border-left:0;border-top:1px solid var(--hairline)}

  .contact__row{grid-template-columns:1fr;gap:.4rem;text-align:left}

  .bio__section{grid-template-columns:1fr;gap:1rem}

  .callfab{display:flex}
  .footer{padding-bottom:90px}
}

@media (max-width: 560px){
  .nav{padding:.75rem 18px}
  .brand__script{font-size:1.55rem}
  .brand__mark{font-size:.6rem;padding-left:.45rem;letter-spacing:.34em}

  .hero{padding:100px 22px 80px}
  .page-hero{padding:100px 22px clamp(28px,4vw,44px)}
  .credstrip__list{gap:.6rem 1.6rem;font-size:.66rem;letter-spacing:.26em}
  .credstrip__list li + li::before{left:-1rem}
  .practice__list li{gap:1.2rem;padding:1.4rem 0}
  .nav__mobile a{font-size:1.35rem;padding:1.1rem 0}
  .nav__mobile{padding:5rem var(--gutter) 2rem}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .reveal{opacity:1;transform:none}
}
