:root{
  --navy:#0b1c2d;
  --navy-2:#0a1726;
  --ink:#0b0f14;
  --gold:#d6b26a;
  --gold-2:#caa056;
  --paper:#f7f5f0;
  --stone:#ebe9e3;
  --muted: rgba(247,245,240,.72);
  --shadow: 0 18px 60px rgba(0,0,0,.25);
  --radius: 18px;
  --max: 1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--paper);
  background: var(--navy);
  line-height:1.6;
}
img{max-width:100%; height:auto; display:block}
a{color:inherit}
.container{width:min(var(--max), calc(100% - 2rem)); margin-inline:auto}
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
.skip-link{
  position:absolute; left:-999px; top:0; background:var(--gold); color:var(--ink);
  padding:.75rem 1rem; z-index:9999; border-radius:0 0 12px 0;
}
.skip-link:focus{left:0}

h1,h2,h3{
  font-family:"Cormorant Garamond", Georgia, serif;
  letter-spacing:.2px;
  margin:0 0 .75rem;
  line-height:1.15;
}
p{margin:0 0 1rem}

.btn{
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.9rem 1.05rem;
  border-radius:999px;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);
  color:var(--paper);
  transition:transform .12s ease, background .12s ease, border-color .12s ease;
  font-weight:600;
}
.btn:hover{transform:translateY(-1px); background:rgba(255,255,255,.10); border-color:rgba(255,255,255,.26)}
.btn--gold{background:var(--gold); color:var(--ink); border-color:transparent}
.btn--gold:hover{background:var(--gold-2)}
.btn--sm{padding:.7rem .9rem; font-size:.95rem}

.site-header{position:sticky; top:0; z-index:50; background:rgba(10,23,38,.90); backdrop-filter: blur(14px) saturate(120%); border-bottom:1px solid rgba(255,255,255,.08); transition: background .18s ease}
.topbar{
  font-size:.9rem;
  color:var(--muted);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition: font-size .18s ease;
}

.topbar__inner{display:flex; justify-content:space-between; align-items:center; gap:1rem; padding:.55rem 0}
.topbar__label{color:rgba(247,245,240,.55); margin-right:.35rem}
.topbar__phone{
  color:var(--paper);
  text-decoration:none;
  font-weight:750;
  font-size:1.15rem;
  letter-spacing:.2px;
}
.topbar__sep{opacity:.45; margin:0 .5rem}
.topbar__link{color:var(--muted); text-decoration:none}
.topbar__link:hover{color:var(--paper)}

.navwrap__inner{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:1.35rem;
  padding:.85rem 0;
  transition: padding .18s ease;
}

.brand{
  display:flex;
  align-items:center;
  gap:.9rem;
  text-decoration:none;
  min-width:0;
  position:relative;
  padding-right:1.2rem;
}
.brand::after{
  content:"";
  position:absolute;
  right:0;
  top:50%;
  transform:translateY(-50%);
  width:1px;
  height:44px;
  background: rgba(214,178,106,.18);
}

.brand__mark{
  width:56px;
  height:56px;
  border-radius:18px;
  border:1.6px solid rgba(214,178,106,.78);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  flex:0 0 auto;
  background: rgba(255,255,255,.02);
  transition: width .18s ease, height .18s ease;
}
.brand__mark::after{
  content:"";
  position:absolute;
  left:50%;
  top:20%;
  transform:translateX(-0.5px);
  width:1px;
  height:60%;
  background: rgba(214,178,106,.55);
}
.brand__initial{
  font-family:"Cormorant Garamond", Georgia, serif;
  font-weight:700;
  font-size:1.85rem;
  line-height:1;
  color: rgba(247,245,240,.95);
}
.brand__initial:first-child{margin-right:.16rem}
.brand__initial:last-child{margin-left:.16rem}

.brand__text{
  display:flex;
  flex-direction:column;
  line-height:1.05;
  white-space:nowrap;
}
.brand__eyebrow{
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  color: rgba(247,245,240,.58);
  font-weight:500;
}
.brand__name{
  font-family:"Cormorant Garamond", Georgia, serif;
  font-weight:700;
  font-size:1.62rem;
  letter-spacing:.2px;
  color: rgba(247,245,240,.96);
  transition: font-size .18s ease;
}
.nav{
  flex:1;
  display:flex;
  align-items:center;
  gap:1.25rem;
  justify-content:flex-start;
  min-width:0;
}
.nav .btn{margin-left:auto}
.nav a{
  text-decoration:none;
  color:rgba(247,245,240,.82);
  font-weight:500;
  letter-spacing:.2px;
}
.nav a:hover{color:var(--paper)}

.nav-toggle{
  display:none;
  width:46px; height:44px; border-radius:12px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  cursor:pointer;
}
.nav-toggle__bar{display:block; width:22px; height:2px; background:rgba(247,245,240,.88); margin:5px auto}

/* Sticky header refined on scroll */
.site-header[data-scrolled="true"]{
  background: rgba(10,23,38,.96);
}
.site-header[data-scrolled="true"] .topbar{font-size:.85rem}
.site-header[data-scrolled="true"] .topbar__inner{padding:.35rem 0}
.site-header[data-scrolled="true"] .navwrap__inner{padding:.65rem 0}
.site-header[data-scrolled="true"] .brand__mark{width:52px; height:52px}
.site-header[data-scrolled="true"] .brand__initial:first-child{margin-right:.13rem}
.site-header[data-scrolled="true"] .brand__initial:last-child{margin-left:.13rem}
.site-header[data-scrolled="true"] .brand__name{font-size:1.48rem}

.hero{
  min-height:86vh;
  display:grid;
  align-items:end;
  background:
    radial-gradient(1200px 600px at 20% 20%, rgba(214,178,106,.16), transparent 55%),
    radial-gradient(900px 520px at 80% 30%, rgba(214,178,106,.10), transparent 56%),
    linear-gradient(180deg, rgba(0,0,0,.58), rgba(0,0,0,.74)),
    url("/assets/images/downtown-winchester-2048.jpg") 50% 55% / cover no-repeat;
  position:relative;
  overflow:hidden;
}
@supports (background-image: image-set(url("x") 1x)) {
  .hero{
    background:
      radial-gradient(1200px 600px at 20% 20%, rgba(214,178,106,.16), transparent 55%),
      radial-gradient(900px 520px at 80% 30%, rgba(214,178,106,.10), transparent 56%),
      linear-gradient(180deg, rgba(0,0,0,.58), rgba(0,0,0,.74)),
      image-set(
        url("/assets/images/downtown-winchester-1280.jpg") 1x,
        url("/assets/images/downtown-winchester-2048.jpg") 2x
      ) 50% 55% / cover no-repeat;
  }
}

.hero::after{
  content:"";
  position:absolute; inset:-40%;
  background-image: url("/assets/pattern.svg");
  opacity:.08;
  transform: rotate(-7deg);
  pointer-events:none;
}
.hero__inner{
  position:relative;
  padding: clamp(3rem, 6vw, 5.5rem) 0 4rem;
  z-index:1;
}
.kicker{
  display:inline-flex; align-items:center; gap:.7rem;
  text-transform:uppercase;
  letter-spacing:.2em;
  font-size:.86rem;
  color:rgba(247,245,240,.72);
  margin-bottom:1rem;
}
.kicker__line{width:52px; height:2px; background:var(--gold); opacity:.95}
.hero h1{
  font-size: clamp(2.5rem, 4.9vw, 4.25rem);
  max-width: 18ch;
  margin-bottom:1rem;
}
.accent{color:var(--gold)}
.hero p{max-width: 60ch; color:rgba(247,245,240,.80)}
.hero__cta{display:flex; flex-wrap:wrap; gap:.8rem; margin-top:1.4rem; align-items:center}
.hero__badge{
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.55rem .85rem;
  border-radius:999px;
  background:rgba(214,178,106,.13);
  border:1px solid rgba(214,178,106,.26);
  color:rgba(247,245,240,.88);
  font-size:.95rem;
}
.explore{
  position:absolute; left:50%; bottom:20px; transform:translateX(-50%);
  text-decoration:none;
  color:rgba(247,245,240,.70);
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.7rem 1rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
}
.explore:hover{color:var(--paper); border-color:rgba(255,255,255,.22)}
.explore__dot{width:9px; height:9px; border-radius:50%; background:var(--gold)}
.explore__arrow{opacity:.8}

.section{
  padding: clamp(3.5rem, 6vw, 5rem) 0;
  background: var(--navy);
}
.section--stone{
  color:var(--ink);
  background:
    radial-gradient(1200px 620px at 10% 0%, rgba(214,178,106,.12), transparent 60%),
    var(--stone);
}
.section--stone a{color:var(--ink)}
.section--stone .muted{color:rgba(0,0,0,.68)}
.section__grid{
  display:grid;
  grid-template-columns: 1.1fr 1.4fr;
  gap:2.5rem;
  align-items:start;
}
.section__title{
  position:relative;
  padding-left: 22px;
}
.section__title::before{
  content:"";
  position:absolute; left:0; top:.35rem;
  width:6px; height: 92%;
  background: var(--gold);
  border-radius: 999px;
}
.section__title h2{
  font-size: clamp(2rem, 3.2vw, 2.75rem);
  margin-bottom:.4rem;
}
.section__title p{margin:0; color:rgba(0,0,0,.68)}

.cards{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:1.25rem;
  margin-top:1.25rem;
}
.card{
  border-radius: var(--radius);
  padding:1.35rem 1.25rem;
  background: rgba(255,255,255,.72);
  border:1px solid rgba(0,0,0,.07);
  box-shadow: 0 18px 50px rgba(0,0,0,.08);
}
.card h3{
  margin:.15rem 0 .4rem;
  font-size:1.55rem;
}
.card p{margin:0; color:rgba(0,0,0,.72)}
.card a:not(.btn){display:inline-flex; align-items:center; gap:.5rem; margin-top:.7rem; text-decoration:none; font-weight:600}

.testimonials-grid{
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.testimonial-card__name{
  margin-top:.85rem;
  font-weight:700;
  color:rgba(0,0,0,.62);
}

.practice-list{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:.6rem 1.2rem;
  padding:0;
  margin:0;
  list-style:none;
}
.practice-list a{
  text-decoration:none;
  display:flex; align-items:flex-start; gap:.65rem;
  padding:.55rem .7rem;
  border-radius: 14px;
  background: rgba(255,255,255,.64);
  border:1px solid rgba(0,0,0,.06);
}
.practice-list a:hover{background: rgba(255,255,255,.82)}
.bullet{
  width:10px; height:10px; border-radius:50%;
  background: var(--gold);
  margin-top:.5rem;
  flex:0 0 auto;
}
.practice-list span{color:rgba(0,0,0,.76)}

.split{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap:2rem;
  align-items:center;
}
.panel{
  border-radius: var(--radius);
  padding:1.6rem 1.5rem;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
}
.panel p{color:rgba(247,245,240,.78)}
.panel h2{margin-bottom:.5rem}

.page-hero{
  padding: 3.2rem 0 2.6rem;
  background:
    radial-gradient(950px 520px at 20% 10%, rgba(214,178,106,.14), transparent 55%),
    linear-gradient(180deg, rgba(0,0,0,.48), rgba(0,0,0,.62)),
    linear-gradient(135deg, #0e2034, #0a1726 60%, #0b1c2d);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.page-hero h1{font-size: clamp(2.2rem, 3.7vw, 3.1rem); margin-bottom:.45rem}
.page-hero p{margin:0; color:rgba(247,245,240,.75); max-width: 70ch}
.page-hero--photo{
  padding: var(--page-hero-padding, 5.2rem 0 4.4rem);
  background:
    radial-gradient(950px 520px at 20% 10%, rgba(214,178,106,.12), transparent 58%),
    linear-gradient(180deg, rgba(0,0,0,.28), rgba(0,0,0,.78)),
    linear-gradient(90deg, rgba(0,0,0,.52), rgba(0,0,0,.14) 55%, rgba(0,0,0,.62)),
    var(--page-hero-image, linear-gradient(135deg, #0e2034, #0a1726 60%, #0b1c2d));
  background-size: auto, auto, auto, var(--page-hero-image-size, cover);
  background-position: 0 0, 0 0, 0 0, var(--page-hero-position, 50% 50%);
}
.crumbs{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  align-items:center;
  margin:0 0 .8rem;
  font-size:.92rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(247,245,240,.72);
}
.crumbs a{color:rgba(247,245,240,.78); text-decoration:none}
.crumbs a:hover{color:var(--paper)}

.page{
  padding: 3rem 0 4.5rem;
}
.page--stone{
  background: var(--stone);
  color: var(--ink);
}
.page--stone a{color: var(--ink)}
.page__prose{
  max-width: 900px;
}
.page__prose p, .page__prose li{color: rgba(0,0,0,.78)}
.page__prose ul{padding-left:1.1rem}
.page__prose blockquote{
  margin: 1.15rem 0;
  padding: 1rem 1.05rem;
  border-left:6px solid var(--gold);
  background: rgba(214,178,106,.10);
  border-radius: 12px;
  color: rgba(0,0,0,.78);
  font-style: italic;
}
.page__prose blockquote > :first-child{margin-top:0}
.page__prose blockquote > :last-child{margin-bottom:0}

.profile{
  display:grid;
  grid-template-columns: 340px 1fr;
  gap:2rem;
  align-items:start;
}
.profile__aside{position:relative}
.profile-card{
  border-radius: 22px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.82);
  box-shadow: 0 18px 50px rgba(0,0,0,.12);
}
.profile-card__img{background: rgba(0,0,0,.04)}
.profile-card__img img{width:100%; height:auto; display:block}
.profile-card__body{padding: 1.2rem 1.1rem 1.25rem}
.profile-card__name{margin:0 0 .25rem}
.profile-card__title{margin:0 0 .9rem; color:rgba(0,0,0,.62); font-weight:600}
.profile-card__list{
  list-style:none;
  padding:0;
  margin:0 0 1.05rem;
  display:grid;
  gap:.55rem;
  color:rgba(0,0,0,.78);
}
.profile-card__list a{text-decoration:none}
.profile-card__list a:hover{text-decoration:underline}
.profile__main h2{margin-top:0}

.bio{
  display:grid;
  grid-template-columns: 340px 1fr;
  gap:2rem;
  align-items:start;
}
.bio__img{
  border-radius: 22px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.10);
  box-shadow: 0 18px 50px rgba(0,0,0,.12);
}
.bio__img img{width:100%; height:auto}
.bio__name{margin-top:0}
.note{
  padding:1rem 1rem;
  border-left:6px solid var(--gold);
  background: rgba(214,178,106,.12);
  border-radius: 12px;
}

.posts{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:1.25rem;
}
.posts--list{grid-template-columns: 1fr}
.post{
  border-radius: var(--radius);
  padding:1.3rem 1.25rem;
  background: rgba(255,255,255,.72);
  border:1px solid rgba(0,0,0,.07);
  box-shadow: 0 18px 50px rgba(0,0,0,.08);
}
.post__meta{font-size:.92rem; color:rgba(0,0,0,.62); letter-spacing:.02em}
.post h3{margin:.25rem 0 .45rem}
.post h3 a{color:inherit; text-decoration:none}
.post h3 a:hover{text-decoration:underline}
.post p{margin:0; color:rgba(0,0,0,.72)}
.post a{display:inline-flex; align-items:center; gap:.5rem; margin-top:.75rem; font-weight:700; text-decoration:none}

.form{
  display:grid; gap:.9rem;
  padding:1.6rem 1.5rem;
  border-radius: var(--radius);
  background: rgba(255,255,255,.72);
  border:1px solid rgba(0,0,0,.07);
  box-shadow: 0 18px 50px rgba(0,0,0,.08);
}
.form label{font-weight:600; color:rgba(0,0,0,.72)}
.form input,.form textarea{
  width:100%;
  padding:.85rem .9rem;
  border-radius: 14px;
  border:1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.86);
  font:inherit;
}
.form textarea{min-height:140px; resize:vertical}
.form .btn{justify-content:center}

.site-footer{
  background: rgba(0,0,0,.28);
  border-top:1px solid rgba(255,255,255,.10);
  padding: 3rem 0 1.2rem;
}
.footer__grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap: 2rem;
}
.footer__logo{width:220px; opacity:.95}
.footer__tagline{color:rgba(247,245,240,.72); margin:.65rem 0 0}
.footer__heading{
  font-size:1.35rem;
  margin:0 0 .65rem;
}
.footer__text{color:rgba(247,245,240,.72)}
.footer__links{list-style:none; padding:0; margin:0; display:grid; gap:.45rem}
.footer__links a{color:rgba(247,245,240,.72); text-decoration:none}
.footer__links a:hover{color:var(--paper)}
.footer__bottom{
  margin-top:2.2rem;
  padding-top:1.1rem;
  border-top:1px solid rgba(255,255,255,.10);
}
.footer__fineprint{
  margin:0;
  color:rgba(247,245,240,.58);
  font-size:.92rem;
}
.footer__sep{opacity:.45; margin:0 .5rem}

@media (max-width: 980px){
  .section__grid{grid-template-columns: 1fr; gap:1.8rem}
  .cards{grid-template-columns: 1fr}
  .split{grid-template-columns: 1fr}
  .profile{grid-template-columns: 1fr; max-width: 760px}
  .bio{grid-template-columns: 1fr; max-width: 760px}
  .footer__grid{grid-template-columns: 1fr 1fr}
}
@media (max-width: 760px){
  .topbar__inner{flex-direction:column; align-items:flex-start}
  .topbar__phone{font-size:1.08rem}
  .nav-toggle{display:inline-block}
  .nav{
    position:absolute;
    right: 1rem;
    top: 104px;
    width: min(360px, calc(100% - 2rem));
    padding: 1rem;
    border-radius: 18px;
    background: rgba(10,23,38,.98);
    border:1px solid rgba(255,255,255,.12);
    box-shadow: var(--shadow);
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:.8rem;
  }
  .nav a{padding:.35rem .2rem}
  .nav[data-open="true"]{display:flex}
  .nav .btn{margin-left:0; justify-content:center}
  .brand::after{display:none}
  .brand{padding-right:0}
  .brand__text{white-space:normal}
  .brand__name{font-size:1.35rem}
    .practice-list{grid-template-columns: 1fr}
  .posts{grid-template-columns: 1fr}
}
