
:root{
  --green:#2E5743;
  --pine:#1E3A2C;
  --brass:#C2A14D;
  --brass-deep:#A6873A;
  --parchment:#F7F4EC;
  --paper:#FFFFFF;
  --ink:#20241F;
  --ink-soft:#4C534B;
  --rule:rgba(46,87,67,.18);
  --display:'Fraunces',Georgia,serif;
  --body:'Public Sans',-apple-system,Segoe UI,sans-serif;
  --max:1120px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{font-family:var(--body);color:var(--ink);background:var(--parchment);line-height:1.65;font-size:17px}
img{max-width:100%;display:block}
a{color:var(--green)}
:focus-visible{outline:3px solid var(--brass);outline-offset:2px}

.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--body);font-weight:700;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-deep)}
.section{padding:88px 0}
h1,h2,h3{font-family:var(--display);font-weight:500;line-height:1.15;color:var(--pine)}
h2{font-size:clamp(1.8rem,3.4vw,2.6rem);margin:.5rem 0 1.2rem}
h3{font-size:1.25rem;margin-bottom:.5rem}
p{margin-bottom:1rem;color:var(--ink-soft)}
p:last-child{margin-bottom:0}

.slats{display:grid;gap:6px;width:96px;margin-bottom:8px}
.slats span{height:4px;background:var(--green);border-radius:2px}
.slats span:nth-child(2){width:88%}
.slats span:nth-child(3){width:96%}
.slats span:nth-child(4){width:80%}
.slats span:nth-child(5){width:90%}
.slats.brass span{background:var(--brass)}
.slats.center{margin-left:auto;margin-right:auto}

.btn{display:inline-block;font-weight:600;text-decoration:none;border-radius:6px;padding:14px 28px;font-size:1rem;border:none;cursor:pointer;transition:transform .15s ease}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 2px 0 var(--pine)}
.btn-primary:hover{background:var(--pine)}
.btn-ghost{border:2px solid var(--green);color:var(--green);background:transparent}
.btn-ghost:hover{background:rgba(46,87,67,.07)}
.btn-brass{background:var(--brass);color:var(--pine);box-shadow:0 2px 0 var(--brass-deep)}
.btn-brass:hover{background:#d1b15e}

/* header */
.topbar{background:var(--pine);color:#E9E4D6;font-size:.85rem;padding:8px 0}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.topbar a{color:var(--brass);text-decoration:none;font-weight:600}
header.site{position:sticky;top:0;z-index:50;background:rgba(247,244,236,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--rule)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand-mark{width:40px;height:40px;display:grid;gap:4px;align-content:center}
.brand-mark span{height:5px;background:var(--green);border-radius:2px}
.brand-mark span:nth-child(2){width:85%}
.brand-mark span:nth-child(3){width:95%}
.brand-mark span:nth-child(4){width:75%}
.brand-name{font-family:var(--display);font-size:1.25rem;color:var(--pine);line-height:1.05}
.brand-name small{display:block;font-family:var(--body);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-deep);font-weight:700;margin-top:3px}
nav.links{display:flex;gap:26px;align-items:center}
nav.links a{text-decoration:none;color:var(--ink);font-weight:500;font-size:.95rem}
nav.links a:hover{color:var(--green)}
nav.links a.cta{background:var(--green);color:#fff;padding:10px 20px;border-radius:6px;font-weight:600}
nav.links a.cta:hover{background:var(--pine)}
.menu-btn{display:none;background:none;border:2px solid var(--green);border-radius:6px;padding:8px 12px;color:var(--green);font-weight:700;font-size:.85rem;cursor:pointer}

/* hero */
.hero{background:linear-gradient(180deg,var(--parchment) 0%,#EFEADD 100%);overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:center;padding-top:88px;padding-bottom:96px}
.hero h1{font-size:clamp(2.4rem,5vw,3.7rem);margin:.6rem 0 1.2rem}
.hero h1 em{font-style:italic;color:var(--green)}
.hero .lede{font-size:1.15rem;max-width:34rem}
.hero-actions{display:flex;gap:14px;margin-top:1.8rem;flex-wrap:wrap}
.hero-cred{margin-top:2.2rem;display:flex;gap:10px;flex-wrap:wrap}
.chip{font-size:.78rem;font-weight:600;letter-spacing:.04em;border:1px solid var(--rule);background:var(--paper);color:var(--ink-soft);border-radius:999px;padding:6px 14px}
/* the bench — for the litigation brand, gavel-block plaque & courtroom caption */
.bench{position:relative;padding:30px 0}
.bench-back{display:grid;gap:12px}
.bench-back span{height:26px;background:var(--green);border-radius:6px;box-shadow:inset 0 -4px 0 rgba(0,0,0,.18)}
.bench-back span:nth-child(odd){background:#356350}
.bench-seat{margin-top:26px;display:grid;gap:10px}
.bench-seat span{height:20px;background:var(--green);border-radius:5px;box-shadow:inset 0 -3px 0 rgba(0,0,0,.18)}
.bench-legs{display:flex;justify-content:space-between;padding:0 28px}
.bench-legs span{width:16px;height:64px;background:var(--pine);border-radius:0 0 5px 5px}
.bench-plaque{position:absolute;top:-6px;left:50%;transform:translateX(-50%);background:var(--brass);color:var(--pine);font-family:var(--body);font-weight:700;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;padding:6px 16px;border-radius:4px;box-shadow:0 2px 0 var(--brass-deep);white-space:nowrap}
.bench-caption{text-align:center;font-size:.85rem;color:var(--ink-soft);font-style:italic;margin-top:18px}

/* family law feature */
.family{background:var(--paper);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.family .wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:64px;align-items:start}
.fl-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:1.6rem}
.fl-item{background:var(--parchment);border:1px solid var(--rule);border-radius:8px;padding:16px 18px}
.fl-item h3{font-size:1.02rem;margin-bottom:.25rem}
.fl-item p{font-size:.88rem;margin:0}

/* cards */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:2.2rem}
.card{background:var(--paper);border:1px solid var(--rule);border-radius:10px;padding:30px 28px;display:flex;flex-direction:column;transition:transform .15s ease,box-shadow .15s ease}
.card:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(31,58,44,.10)}
.card .slats{width:56px;gap:4px;margin-bottom:18px}
.card .slats span{height:3px}
.card ul{margin:8px 0 0 0;padding-left:1.1rem;color:var(--ink-soft);font-size:.95rem}
.card ul li{margin-bottom:5px}
.card .tag{margin-top:auto;padding-top:18px;font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brass-deep)}

/* mediation referral strip */
.referral{background:var(--pine);color:#E9E4D6}
.referral .wrap{padding:64px 24px;display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:center}
.referral h2{color:#F3EFE2}
.referral p{color:#CBD6CB}
.referral strong{color:var(--brass)}
.referral .panel{background:rgba(255,255,255,.06);border:1px solid rgba(194,161,77,.4);border-radius:12px;padding:30px;text-align:center}
.referral .panel .mm{font-family:var(--display);font-size:1.5rem;color:#F3EFE2;margin-bottom:.4rem}

/* about */
.about .wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:start}
.cred-list{list-style:none;display:grid;gap:12px;margin-top:1.4rem}
.cred-list li{display:flex;gap:14px;align-items:flex-start;background:var(--paper);border:1px solid var(--rule);border-radius:8px;padding:13px 18px;font-size:.95rem;color:var(--ink-soft)}
.cred-list .dot{flex:none;width:10px;height:10px;border-radius:50%;background:var(--brass);margin-top:7px}
.about blockquote{font-family:var(--display);font-size:1.45rem;font-style:italic;color:var(--pine);line-height:1.4;border-left:4px solid var(--brass);padding-left:22px;margin:1.6rem 0}
.lang-note{display:inline-flex;align-items:center;gap:10px;background:var(--paper);border:1px solid var(--rule);border-radius:8px;padding:12px 18px;font-size:.92rem;color:var(--ink-soft);margin-top:.6rem}

/* blog */
.blog{background:var(--paper);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.post-card{background:var(--parchment);border:1px solid var(--rule);border-radius:10px;padding:28px;display:flex;flex-direction:column;transition:transform .15s ease,box-shadow .15s ease}
.post-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(31,58,44,.10)}
.post-card .date{font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brass-deep);margin-bottom:10px}
.post-card h3 a{color:var(--pine);text-decoration:none}
.post-card h3 a:hover{color:var(--green)}
.post-card .more{margin-top:auto;padding-top:16px;font-weight:600;text-decoration:none}

/* contact */
.contact{background:linear-gradient(180deg,#EFEADD 0%,var(--parchment) 100%)}
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.contact-info{display:grid;gap:18px;margin-top:1.4rem}
.contact-info a{font-weight:600;text-decoration:none}
.contact-info .big-phone{font-family:var(--display);font-size:2rem;color:var(--pine);text-decoration:none}
.cal-card{background:var(--paper);border:1px solid var(--rule);border-radius:12px;padding:26px;margin-top:1.6rem;box-shadow:0 12px 28px rgba(31,58,44,.08)}
.cal-card h3{margin-bottom:.4rem}
form.intake{background:var(--paper);border:1px solid var(--rule);border-radius:12px;padding:34px;display:grid;gap:18px;box-shadow:0 12px 28px rgba(31,58,44,.08)}
form.intake label{font-weight:600;font-size:.9rem;color:var(--pine);display:grid;gap:6px}
form.intake input,form.intake select,form.intake textarea{font:inherit;padding:12px 14px;border:1.5px solid var(--rule);border-radius:6px;background:#FDFCF8;color:var(--ink);width:100%}
form.intake input:focus,form.intake select:focus,form.intake textarea:focus{border-color:var(--green);outline:none}
form.intake .fine{font-size:.78rem;color:var(--ink-soft);margin:0}
.billpay{margin-top:1.6rem;background:var(--pine);border-radius:10px;padding:22px 26px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.billpay p{color:#CBD6CB;margin:0;font-size:.95rem}
.billpay strong{color:#F3EFE2}

/* footer */
footer{background:var(--ink);color:#B9BCB4;font-size:.88rem}
footer .wrap{padding:56px 24px 36px;display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:48px}
footer h4{font-family:var(--display);color:#F3EFE2;font-weight:500;font-size:1.05rem;margin-bottom:14px}
footer a{color:#D8D3C2;text-decoration:none}
footer a:hover{color:var(--brass)}
footer ul{list-style:none;display:grid;gap:8px}
.disclaimer{border-top:1px solid rgba(255,255,255,.12);margin-top:8px}
.disclaimer .wrap{display:block;padding:24px;font-size:.78rem;color:#8E927F;line-height:1.6}

@media (max-width:920px){
  .hero .wrap,.about .wrap,.contact .wrap,.family .wrap,.referral .wrap{grid-template-columns:1fr;gap:48px}
  .grid{grid-template-columns:1fr 1fr}
  .bench{max-width:420px;margin:0 auto}
  footer .wrap{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .grid,.fl-list,footer .wrap{grid-template-columns:1fr}
  nav.links{display:none;position:absolute;top:76px;left:0;right:0;background:var(--parchment);border-bottom:1px solid var(--rule);flex-direction:column;align-items:stretch;padding:18px 24px;gap:16px}
  nav.links.open{display:flex}
  .menu-btn{display:block}
  .section{padding:64px 0}
}
