/* ============================================================
   Hartman — Attorneys at Law · Modern Editorial
   Palette: deep harbor navy + warm bone + one brass accent
   Type: Fraunces (serif display, used with restraint) / Inter
   ============================================================ */

:root{
  --ink:#0E1A24;        /* deep harbor navy-black */
  --hull:#13283A;       /* lifted navy panel      */
  --hull-2:#1B3A52;     /* deepest panel          */
  --paper:#F6F3EC;      /* warm bone (cooled)     */
  --paper-2:#EFEBE0;    /* recessed bone          */
  --brass:#B08A3E;      /* the one accent         */
  --brass-bright:#CDA75A;
  --slate:#5A6B78;      /* muted blue-grey meta   */
  --slate-on-dark:#9FB2BF;
  --line:rgba(14,26,36,.13);
  --line-dark:rgba(255,255,255,.14);

  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;

  --wrap:1180px;
  --pad:clamp(1.25rem,5vw,4rem);
  --section-y:clamp(4.5rem,9vw,8rem);
  --r:4px;
}

*{box-sizing:border-box;margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:clamp(1rem,.96rem + .2vw,1.075rem);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}

/* ---------- type ---------- */
.eyebrow{
  font:600 .72rem/1 var(--sans);
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);
  display:flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor;flex:none}
.eyebrow--center{justify-content:center}
.eyebrow--center::before{display:none}
.eyebrow--hero{color:var(--brass-bright)}

.band__title{
  font:500 clamp(1.7rem,1.2rem + 2.4vw,3rem)/1.08 var(--serif);
  letter-spacing:-.015em;
  margin-top:.75rem;
  max-width:18ch;
}
.band__sub{
  margin-top:1rem;color:var(--slate);max-width:50ch;font-size:1.05rem;
}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--ink);--fg:var(--paper);--bd:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font:600 .92rem/1 var(--sans);letter-spacing:.01em;
  padding:.95em 1.5em;border:1px solid var(--bd);border-radius:var(--r);
  background:var(--bg);color:var(--fg);cursor:pointer;
  text-decoration:none;transition:transform .18s ease,background .2s ease,color .2s ease,border-color .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--brass{--bg:var(--brass);--fg:#1a1306;--bd:var(--brass)}
.btn--brass:hover{--bg:var(--brass-bright)}
.btn--outline{--bg:transparent;--fg:var(--paper);--bd:rgba(255,255,255,.4)}
.btn--outline:hover{--bd:var(--brass-bright);--fg:var(--brass-bright)}
.btn--block{width:100%}
.btn--ghost-sm{
  --bg:transparent;--fg:var(--ink);--bd:var(--line);
  padding:.6em 1em;font-size:.82rem;
}
.btn--ghost-sm:hover{--bd:var(--brass);--fg:var(--brass);transform:none}
:focus-visible{outline:2px solid var(--brass);outline-offset:3px;border-radius:2px}

.skip{
  position:absolute;left:-999px;top:0;z-index:100;
  background:var(--ink);color:var(--paper);padding:.7em 1em;border-radius:0 0 var(--r) 0;
}
.skip:focus{left:0}

/* ============ MASTHEAD ============ */
.masthead{
  position:sticky;top:0;z-index:40;
  background:rgba(246,243,236,.86);backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.masthead__row{display:flex;align-items:center;gap:1.5rem;height:72px}
/* Brand lockup — typographic, built from the site's own type + palette so it
   sits in the design instead of clashing (replaces the royal-blue + red raster logo). */
.brand{display:flex;align-items:center;gap:.65rem;text-decoration:none;font-weight:600}
.brand__mark{
  width:40px;height:40px;flex:none;display:grid;place-items:center;
  font:500 1.4rem/1 var(--serif);color:var(--paper);background:var(--ink);
  border-radius:var(--r);box-shadow:inset 0 0 0 1px var(--brass); /* brass keyline */
}
.brand__name{display:flex;flex-direction:column;font:500 1.3rem/1 var(--serif);letter-spacing:-.01em;color:var(--ink)}
.brand__sub{font:600 .56rem/1 var(--sans);letter-spacing:.24em;text-transform:uppercase;color:var(--brass);margin-top:.34em}
.brand__mark,.brand__name{transition:color .2s,background .2s,box-shadow .2s}
.brand:hover .brand__name{color:var(--brass)}
.brand:hover .brand__mark{box-shadow:inset 0 0 0 1px var(--brass-bright)}
/* dark surfaces (footer): brass seal on navy, cream wordmark */
.brand--invert .brand__name{color:var(--paper)}
.brand--invert .brand__mark{background:var(--brass);color:var(--ink);box-shadow:inset 0 0 0 1px rgba(246,243,236,.3)}
.brand--invert:hover .brand__name{color:var(--brass-bright)}
.nav{display:flex;gap:1.6rem;margin-left:auto}
.nav a{
  text-decoration:none;font:500 .9rem/1 var(--sans);color:var(--ink);
  padding-bottom:.25em;border-bottom:1px solid transparent;transition:border-color .2s,color .2s;
}
.nav a:hover{border-color:var(--brass);color:var(--brass)}
.masthead__cta{display:flex;align-items:center;gap:1rem}
.lede-phone{font:600 .9rem/1 var(--sans);text-decoration:none;color:var(--ink)}
.lede-phone:hover{color:var(--brass)}

.navtoggle{display:none;background:none;border:0;width:40px;height:40px;cursor:pointer;margin-left:auto;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.navtoggle span{width:22px;height:2px;background:var(--ink);transition:.25s}
.navtoggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.navtoggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.navtoggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.m-nav{display:none;flex-direction:column;border-top:1px solid var(--line);padding:.5rem var(--pad) 1.25rem}
.m-nav a{padding:.85rem 0;text-decoration:none;font:500 1rem/1 var(--sans);border-bottom:1px solid var(--line)}
.m-nav a:last-child{border-bottom:0;color:var(--brass);font-weight:600}

/* ============ HERO ============ */
.hero{position:relative;overflow:hidden;background:var(--ink);color:var(--paper);isolation:isolate}
.hero__bg{position:absolute;inset:0;z-index:-1}
.hero__horizon{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 80% at 78% -10%, rgba(176,138,62,.16), transparent 55%),
    linear-gradient(180deg, var(--ink) 0%, var(--hull) 62%, var(--hull-2) 100%);
}
.hero__horizon::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:34%;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.28));
  -webkit-mask:repeating-linear-gradient(180deg,#000 0 1px,transparent 1px 7px);
          mask:repeating-linear-gradient(180deg,#000 0 1px,transparent 1px 7px);
  opacity:.5;
}
.hero__rose{
  position:absolute;right:-6vw;top:50%;transform:translateY(-50%);
  width:min(46vw,560px);height:auto;color:var(--brass);opacity:.16;
}
.hero__inner{position:relative;padding-block:clamp(4rem,10vw,7.5rem) clamp(3rem,7vw,5.5rem)}
.hero__title{
  font:500 clamp(2.6rem,1.4rem + 6.2vw,5.6rem)/1.02 var(--serif);
  letter-spacing:-.02em;margin-top:1.5rem;
}
.hero__title em{font-style:italic;color:var(--brass-bright);font-weight:400}
.hero__lede{margin-top:1.75rem;max-width:46ch;font-size:clamp(1.05rem,1rem + .3vw,1.2rem);color:var(--slate-on-dark)}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.25rem}
.hero__facts{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  margin-top:3.5rem;border:1px solid var(--line-dark);background:var(--line-dark);
  border-radius:var(--r);overflow:hidden;
}
.hero__facts>div{background:linear-gradient(180deg,rgba(255,255,255,.025),transparent);padding:1.1rem 1.25rem}
.hero__facts dt{font:600 .64rem/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--slate-on-dark)}
.hero__facts dd{font:500 1.5rem/1 var(--serif);margin-top:.5rem;color:var(--paper)}

/* ============ shared band ============ */
.band{padding-block:var(--section-y)}
.band__head{margin-bottom:clamp(2rem,4vw,3.25rem)}

/* ---- WHY ---- */
.band--why{background:var(--paper-2);border-block:1px solid var(--line)}
.why__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.why__copy{margin-top:1.5rem;color:var(--slate);max-width:46ch;font-size:1.08rem}
.why__points{list-style:none;display:grid;gap:1.5rem;padding-top:.5rem}
.why__points li{display:grid;grid-template-columns:auto 1fr;gap:1.25rem;align-items:baseline;padding-bottom:1.5rem;border-bottom:1px solid var(--line)}
.why__points li:last-child{border-bottom:0;padding-bottom:0}
.why__pt-num{font:400 clamp(2rem,1.4rem + 1.6vw,2.9rem)/1 var(--serif);color:var(--brass)}
.why__points p{color:var(--ink);font-size:1.02rem}

/* ---- PRACTICE ---- */
.practice__grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
}
.pa{
  background:var(--paper);padding:1.9rem 1.75rem 1.75rem;
  display:flex;flex-direction:column;min-height:230px;
  text-decoration:none;color:inherit;position:relative;transition:background .25s ease;
}
.pa:hover{background:#fff}
.pa__no{font:600 .7rem/1 var(--sans);letter-spacing:.16em;color:var(--brass)}
.pa__name{font:500 1.35rem/1.15 var(--serif);margin-top:1rem;letter-spacing:-.01em}
.pa__sum{margin-top:.75rem;color:var(--slate);font-size:.96rem;flex:1}
.pa__go{margin-top:1.25rem;font:600 .82rem/1 var(--sans);color:var(--ink);display:inline-flex;gap:.4em;align-items:center;transition:gap .2s,color .2s}
.pa__go::after{content:"→";color:var(--brass)}
.pa:hover .pa__go{gap:.75em;color:var(--brass)}

.load-fallback{padding:1.5rem 1.25rem;font-size:1rem;color:var(--slate);grid-column:1/-1}
.load-fallback a{color:var(--brass);text-decoration:none;font-weight:600}
.band--attorneys .load-fallback{color:var(--slate-on-dark)}

/* ---- ATTORNEYS ---- */
.band--attorneys{background:var(--ink);color:var(--paper)}
.band--attorneys .band__sub{color:var(--slate-on-dark)}
.roster{display:grid;gap:1px;background:var(--line-dark);border:1px solid var(--line-dark);border-radius:var(--r);overflow:hidden}
.atty{
  background:var(--hull);display:grid;grid-template-columns:auto 1fr;gap:1.5rem;
  padding:1.75rem clamp(1.25rem,3vw,2.25rem);align-items:start;
}
.atty__plate{
  width:62px;height:62px;flex:none;display:grid;place-items:center;border-radius:var(--r);
  font:500 1.4rem/1 var(--serif);color:var(--brass-bright);
  background:linear-gradient(160deg,var(--hull-2),var(--ink));border:1px solid var(--line-dark);
}
.atty__head{display:flex;flex-wrap:wrap;align-items:baseline;gap:.6rem 1rem}
.atty__name{font:500 1.3rem/1.1 var(--serif);color:var(--paper)}
.atty__role{font:600 .68rem/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;color:var(--brass)}
.atty__bio{margin-top:.75rem;color:var(--slate-on-dark);font-size:.96rem;max-width:74ch}

/* ---- QUOTES ---- */
.band--quotes{background:var(--paper-2);border-block:1px solid var(--line)}
.quotes__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,2.5rem);align-items:start}
.quotes__grid .eyebrow{grid-column:1/-1;margin-bottom:.75rem}
.quote blockquote{font:400 1.18rem/1.5 var(--serif);font-style:italic;color:var(--ink);position:relative;padding-top:1.75rem}
.quote blockquote::before{content:"";position:absolute;top:0;left:0;width:34px;height:2px;background:var(--brass)}
.quote figcaption{margin-top:1rem;font:600 .74rem/1.3 var(--sans);letter-spacing:.06em;text-transform:uppercase;color:var(--slate)}

/* ---- GUIDES ---- */
.band--guides{background:var(--hull-2);color:var(--paper)}
.band--guides .band__sub{color:var(--slate-on-dark)}
.guides__inner{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.guides__copy .btn{margin-top:1.75rem}
.guides__doc{
  text-decoration:none;color:var(--ink);background:var(--paper);
  aspect-ratio:1/1.3;max-width:300px;width:100%;margin-inline:auto;border-radius:var(--r);
  padding:2rem 1.75rem;display:flex;flex-direction:column;position:relative;
  box-shadow:0 30px 60px -30px rgba(0,0,0,.6);border:1px solid rgba(0,0,0,.1);
  transition:transform .3s ease,box-shadow .3s ease;
}
.guides__doc:hover{transform:translateY(-6px) rotate(-1deg);box-shadow:0 40px 70px -28px rgba(0,0,0,.7)}
.guides__doc-tab{position:absolute;top:1.5rem;right:1.75rem;font:600 .62rem/1 var(--sans);letter-spacing:.18em;color:#fff;background:var(--brass);padding:.45em .7em;border-radius:3px}
.guides__doc-no{font:600 .7rem/1 var(--sans);letter-spacing:.16em;color:var(--brass)}
.guides__doc-title{font:500 1.85rem/1.1 var(--serif);margin-top:auto;letter-spacing:-.01em}
.guides__doc-foot{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--line);font:600 .66rem/1.3 var(--sans);letter-spacing:.1em;text-transform:uppercase;color:var(--slate)}

/* ---- CONTACT ---- */
.band--contact{background:var(--paper)}
.contact__grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.contact__details{list-style:none;margin-top:2.25rem;display:grid;gap:1.4rem}
.contact__details li{display:grid;gap:.3rem;padding-bottom:1.4rem;border-bottom:1px solid var(--line)}
.contact__details li:last-child{border-bottom:0;padding-bottom:0}
.contact__k{font:600 .68rem/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--brass)}
.contact__v{color:var(--ink);font-size:1.02rem}
.contact__v a{text-decoration:none}
.contact__v a:hover{color:var(--brass)}

.form{background:#fff;border:1px solid var(--line);border-radius:6px;padding:clamp(1.5rem,3vw,2.25rem);box-shadow:0 20px 50px -35px rgba(14,26,36,.5)}
.field{margin-bottom:1.25rem}
.field label{display:block;font:600 .78rem/1 var(--sans);letter-spacing:.04em;color:var(--ink);margin-bottom:.55rem}
.field input,.field textarea{
  width:100%;font:400 1rem/1.5 var(--sans);color:var(--ink);
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:.85em 1em;transition:border-color .2s,box-shadow .2s;resize:vertical;
}
.field input::placeholder,.field textarea::placeholder{color:#9aa6ad}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(176,138,62,.18)}
.field input[aria-invalid="true"],.field textarea[aria-invalid="true"]{border-color:#a4423a;box-shadow:0 0 0 3px rgba(164,66,58,.15)}
.form__status{margin-top:1rem;padding:.85em 1em;border-radius:var(--r);font:500 .92rem/1.45 var(--sans)}
.form__status.is-ok{background:rgba(40,90,60,.12);color:#1f5135;border:1px solid rgba(40,90,60,.3)}
.form__status.is-err{background:rgba(164,66,58,.1);color:#8c322b;border:1px solid rgba(164,66,58,.3)}
.form__fine{margin-top:1.1rem;font-size:.82rem;color:var(--slate);line-height:1.5}
.form__fine a{color:var(--brass)}

/* ============ FOOTER ============ */
.foot{background:var(--ink);color:var(--slate-on-dark);padding-top:clamp(3rem,6vw,4.5rem)}
.foot__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem 2rem}
.foot__brand{display:flex;gap:1rem;align-items:center}
.foot__name{font:500 1.15rem/1.2 var(--serif);color:var(--paper)}
.foot__tag{font:600 .64rem/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;color:var(--brass);margin-top:.4rem}
.foot__h{font:600 .68rem/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--brass);margin-bottom:1rem}
.foot__col a{display:block;text-decoration:none;color:var(--slate-on-dark);padding:.25rem 0;transition:color .2s}
.foot__col a:hover{color:var(--brass-bright)}
.foot__col p{line-height:1.7}
.foot__col p a{display:inline}
.foot__fine{font-size:.8rem;margin-top:.75rem;color:var(--slate)}
.foot__rule{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-top:clamp(2.5rem,5vw,3.5rem);padding-top:1.5rem;padding-bottom:2rem;border-top:1px solid var(--line-dark);font:500 .78rem/1 var(--sans);letter-spacing:.06em;color:var(--slate)}

/* ============ scroll reveal ============ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .btn:hover,.guides__doc:hover{transform:none}
}

/* ============ responsive ============ */
@media (max-width:980px){
  .nav,.masthead__cta{display:none}
  .navtoggle{display:flex}
  .m-nav.is-open{display:flex}
  .why__grid,.guides__inner,.contact__grid{grid-template-columns:1fr;gap:2.5rem}
  .practice__grid{grid-template-columns:repeat(2,1fr)}
  .quotes__grid{grid-template-columns:1fr}
  .quote{padding-bottom:1.5rem;border-bottom:1px solid var(--line)}
  .quote:last-child{border-bottom:0}
  .foot__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  .hero__facts{grid-template-columns:repeat(2,1fr)}
  .practice__grid{grid-template-columns:1fr}
  .atty{grid-template-columns:1fr;gap:1rem}
  .foot__grid{grid-template-columns:1fr}
  .hero__rose{opacity:.1}
}

/* ============================================================
   CONCIERGE WIDGET
   Palette inherits site tokens: --ink, --hull, --hull-2,
   --paper, --brass, --brass-bright, --slate, --slate-on-dark.
   Type: Fraunces for panel header, Inter for body.
   Signature: compass-rose hairline watermark behind messages.
   ============================================================ */

/* ---- floating bubble ---- */
.c-bubble{
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:9000;
  display:inline-flex;align-items:center;gap:.55em;
  font:600 .82rem/1 var(--sans);
  background:var(--ink);color:var(--paper);
  border:1px solid var(--brass);border-radius:100px;
  padding:.72em 1.2em .72em .9em;
  box-shadow:0 8px 28px -6px rgba(0,0,0,.55),0 0 0 0 rgba(176,138,62,.6);
  cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
}
.c-bubble:hover{
  background:var(--hull);transform:translateY(-3px);
  box-shadow:0 14px 36px -8px rgba(0,0,0,.65),0 0 0 4px rgba(176,138,62,.18);
}
.c-bubble.is-open{
  background:var(--hull);
  box-shadow:0 6px 18px -6px rgba(0,0,0,.5);
}
.c-bubble svg{flex:none;color:var(--brass-bright)}
.c-bubble span{white-space:nowrap}
@media (max-width:480px){
  .c-bubble span{display:none}
  .c-bubble{padding:.85em}
}

/* ---- panel ---- */
.c-panel{
  position:fixed;bottom:4.5rem;right:1.5rem;z-index:8999;
  width:min(420px, calc(100vw - 3rem));
  max-height:min(600px, calc(100svh - 6rem));
  display:flex;flex-direction:column;
  background:var(--ink);color:var(--paper);
  border:1px solid rgba(176,138,62,.3);border-radius:8px;
  box-shadow:0 32px 80px -24px rgba(0,0,0,.8),0 0 0 1px rgba(255,255,255,.04);
  overflow:hidden;
  /* slide in from bottom */
  transform-origin:bottom right;
  animation:c-slide-in .22s cubic-bezier(.2,.85,.3,1) both;
}
.c-panel[hidden]{display:none}
@keyframes c-slide-in{
  from{opacity:0;transform:translateY(12px) scale(.97)}
  to{opacity:1;transform:none}
}
@media (prefers-reduced-motion:reduce){
  .c-panel{animation:none}
}
/* mobile: full-width sheet */
@media (max-width:480px){
  .c-panel{
    right:0;left:0;bottom:0;width:100%;border-radius:12px 12px 0 0;
    max-height:80svh;
  }
  .c-bubble{bottom:1rem;right:1rem}
}

/* ---- panel header ---- */
.c-head{
  display:flex;align-items:center;gap:.8rem;
  padding:.9rem 1rem .9rem 1rem;
  background:var(--hull-2);border-bottom:1px solid rgba(176,138,62,.22);
  flex:none;
}
.c-head__mark{
  width:32px;height:32px;flex:none;display:grid;place-items:center;
  font:600 1rem/1 var(--serif);color:var(--paper);
  background:var(--ink);border:1px solid var(--brass);border-radius:4px;
}
.c-head__text{display:flex;flex-direction:column;gap:.2em}
.c-head__title{font:500 1rem/1 var(--serif);color:var(--paper);letter-spacing:-.01em}
.c-head__sub{font:600 .6rem/1 var(--sans);letter-spacing:.2em;text-transform:uppercase;color:var(--brass)}
.c-close{
  margin-left:auto;background:none;border:0;cursor:pointer;
  color:var(--slate-on-dark);padding:.4em;border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  transition:color .15s,background .15s;
}
.c-close:hover{color:var(--paper);background:rgba(255,255,255,.08)}

/* ---- message list ---- */
.c-messages{
  flex:1;overflow-y:auto;padding:1rem;
  display:flex;flex-direction:column;gap:.65rem;
  /* Compass-rose emblem behind the conversation. Readability is safe now that the
     assistant bubbles are opaque light cards — the emblem only shows in the gaps,
     never behind text. */
  background:#16242f url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'%3E%3Cg stroke='%23B08A3E' stroke-opacity='.55' fill='none' stroke-width='1'%3E%3Ccircle cx='100' cy='100' r='92'/%3E%3Ccircle cx='100' cy='100' r='70'/%3E%3Cline x1='100' y1='2' x2='100' y2='198'/%3E%3Cline x1='2' y1='100' x2='198' y2='100'/%3E%3Cline x1='29' y1='29' x2='171' y2='171'/%3E%3Cline x1='171' y1='29' x2='29' y2='171'/%3E%3C/g%3E%3Cpolygon points='100,12 110,100 100,118 90,100' fill='%23B08A3E' fill-opacity='.55'/%3E%3Cpolygon points='100,188 90,100 100,82 110,100' fill='%23B08A3E' fill-opacity='.2'/%3E%3C/svg%3E") no-repeat center 34% / 188px 188px;
}

/* ---- message bubbles ---- */
.msg{
  position:relative;z-index:1;
  max-width:88%;padding:.78em 1.05em;border-radius:8px;
  font:400 .94rem/1.6 var(--sans);word-break:break-word;
}
.msg.user{
  align-self:flex-end;
  background:var(--hull-2);color:var(--paper);
  border:1px solid rgba(176,138,62,.2);border-bottom-right-radius:2px;
}
.msg.assistant{
  align-self:flex-start;
  /* Light bubble, dark ink text — maximum contrast / readability against the
     dark panel (the received-message pattern). */
  background:var(--paper);color:var(--ink);
  border:1px solid rgba(0,0,0,.05);border-bottom-left-radius:2px;
  box-shadow:0 1px 3px rgba(0,0,0,.25);
}
/* typing indicator */
.msg--typing{
  display:flex;align-items:center;gap:.38em;
  padding:.75em 1.1em;min-width:3.5em;
}
.msg--typing span{
  width:6px;height:6px;border-radius:50%;background:var(--brass);
  animation:c-blink 1.2s infinite;
}
.msg--typing span:nth-child(2){animation-delay:.2s}
.msg--typing span:nth-child(3){animation-delay:.4s}
@keyframes c-blink{
  0%,80%,100%{opacity:.25;transform:scale(.85)}
  40%{opacity:1;transform:scale(1)}
}

/* ---- CTA / suggestion chips ---- */
.c-cta-row{
  display:flex;flex-wrap:wrap;gap:.45rem;
  padding:.5rem 1rem .6rem;flex:none;
}
.c-chip{
  font:600 .78rem/1 var(--sans);letter-spacing:.015em;
  color:var(--brass-bright);background:rgba(176,138,62,.1);
  border:1px solid rgba(176,138,62,.35);border-radius:100px;
  padding:.55em .95em;cursor:pointer;
  transition:background .18s,border-color .18s,color .18s;
}
.c-chip:hover{background:rgba(176,138,62,.2);border-color:var(--brass-bright)}
.c-chip--suggest{font-weight:500;color:#dce3e7;border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.08)}
.c-chip--suggest:hover{color:var(--paper);border-color:rgba(176,138,62,.6);background:rgba(255,255,255,.13)}
.c-chip--primary{
  color:#1a1306;background:var(--brass);border-color:var(--brass);
}
.c-chip--primary:hover{background:var(--brass-bright);border-color:var(--brass-bright)}
.c-chip--ghost{
  color:#dce3e7;background:transparent;border-color:rgba(255,255,255,.22);
}
.c-chip--ghost:hover{color:var(--paper);border-color:rgba(255,255,255,.4)}

/* ---- input area ---- */
.c-input-area{flex:none;border-top:1px solid rgba(255,255,255,.08);padding:.75rem 1rem}
.c-form{display:flex;gap:.5rem;align-items:center}
.c-input{
  flex:1;background:rgba(255,255,255,.06);color:var(--paper);
  border:1px solid rgba(255,255,255,.15);border-radius:6px;
  font:400 .9rem/1 var(--sans);padding:.78em .95em;
  transition:border-color .2s,box-shadow .2s;
}
.c-input::placeholder{color:#9fb2bf}
.c-input:focus{
  outline:none;
  border-color:var(--brass);
  box-shadow:0 0 0 3px rgba(176,138,62,.2);
}
.c-input[aria-invalid="true"]{border-color:#a4423a;box-shadow:0 0 0 3px rgba(164,66,58,.2)}
.c-send{
  width:38px;height:38px;flex:none;display:grid;place-items:center;
  background:var(--brass);color:var(--ink);border:0;border-radius:6px;cursor:pointer;
  transition:background .18s,transform .15s;
}
.c-send:hover:not(:disabled){background:var(--brass-bright);transform:translateX(2px)}
.c-send:disabled{opacity:.4;cursor:not-allowed}

/* ---- lead mini-form ---- */
.c-lead-form{display:flex;flex-direction:column;gap:.6rem}
.c-lead-label{font:500 .82rem/1.4 var(--sans);color:var(--slate-on-dark);margin-bottom:.2rem}
.c-lead-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.3rem}
.c-lead-status{
  font:500 .82rem/1.45 var(--sans);padding:.7em .9em;border-radius:4px;margin-top:.2rem;
}
.c-lead-status--err{background:rgba(164,66,58,.15);color:#f5a49e;border:1px solid rgba(164,66,58,.3)}
.c-lead-confirm-wrap{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:.4em 0}
.c-lead-confirm{
  font:500 .9rem/1.5 var(--sans);color:var(--brass-bright);
  padding:.45em 0;text-align:center;letter-spacing:.01em;
}

/* ---- disclaimer footer ---- */
.c-disclaimer{
  flex:none;
  padding:.65rem 1rem;
  background:rgba(0,0,0,.25);border-top:1px solid rgba(255,255,255,.06);
  font:400 .72rem/1.5 var(--sans);color:#aebac2;
  text-align:center;
}
.c-disclaimer a{color:var(--brass);text-decoration:none;font-weight:500}
.c-disclaimer a:hover{color:var(--brass-bright);text-decoration:underline}

/* ============================================================
   GENERATED PAGE TEMPLATES — shared classes for all ~278 pages
   produced by the static generator (build/templates.mjs).
   Palette: inherits all tokens from :root above.
   ============================================================ */

/* ---- Breadcrumb ---- */
.bc{padding-block:.75rem 0}
.bc__list{
  list-style:none;display:flex;flex-wrap:wrap;gap:.3em;
  font:500 .78rem/1 var(--sans);color:var(--slate);
}
.bc__item{display:flex;align-items:center;gap:.3em}
.bc__item+.bc__item::before{content:"›";color:var(--line);margin-right:.15em}
.bc__link{text-decoration:none;color:var(--slate);transition:color .18s}
.bc__link:hover{color:var(--brass)}
.bc__item--current{color:var(--ink)}

/* ---- Page hero (inner pages) ---- */
.page-hero{
  background:var(--ink);color:var(--paper);
  padding-block:clamp(3rem,7vw,5.5rem) clamp(2.5rem,5vw,4rem);
  position:relative;overflow:hidden;
}
.page-hero::after{
  /* subtle brass horizon echo */
  content:"";position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--brass),transparent);
  opacity:.4;
}
.page-hero__inner{position:relative;z-index:1}
.page-hero__title{
  font:500 clamp(2rem,1.2rem + 4vw,3.8rem)/1.06 var(--serif);
  letter-spacing:-.02em;margin-top:.9rem;max-width:22ch;
}
.page-hero__lede{
  margin-top:1.25rem;max-width:48ch;
  font-size:clamp(1rem,.98rem + .25vw,1.15rem);
  color:var(--slate-on-dark);
}
/* blog article hero: slightly narrower */
.page-hero--article .page-hero__title{max-width:30ch}

/* ---- Article meta (date + category, on blog articles) ---- */
.page-article__meta{
  display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;
  margin-bottom:.75rem;
}
.page-article__category{
  font:600 .72rem/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass);background:rgba(176,138,62,.14);
  padding:.4em .75em;border-radius:100px;border:1px solid rgba(176,138,62,.3);
}
.page-article__date{
  font:500 .82rem/1 var(--sans);color:var(--slate-on-dark);
}

/* ---- Article body ---- */
.page-article{
  padding-block:clamp(2.5rem,5vw,4rem);
  display:grid;
  grid-template-columns:min(68ch,100%) 1fr;
  gap:clamp(2rem,4vw,3.5rem);
  align-items:start;
}
.page-article__body{grid-column:1}
.page-article__back{grid-column:1;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--line)}

/* prose within article body */
.page-h2{
  font:500 clamp(1.35rem,1rem + 1.6vw,2rem)/1.12 var(--serif);
  letter-spacing:-.015em;
  margin-top:2.25rem;margin-bottom:.6rem;
  padding-top:.25rem;
}
.page-h2:first-child{margin-top:0}
.page-h3{
  font:500 clamp(1.1rem,.95rem + .8vw,1.45rem)/1.2 var(--serif);
  letter-spacing:-.01em;
  margin-top:1.75rem;margin-bottom:.5rem;
}
.page-p{
  color:var(--ink);line-height:1.72;max-width:68ch;
  margin-bottom:1rem;
}
.page-ul{
  list-style:none;margin-bottom:1.25rem;display:grid;gap:.55rem;
  padding-left:0;
}
.page-ul li{
  padding-left:1.6em;position:relative;
  color:var(--ink);line-height:1.65;
}
.page-ul li::before{
  content:"";position:absolute;left:0;top:.62em;
  width:8px;height:1px;background:var(--brass);
}

/* back link */
.page-back-link{
  display:inline-flex;align-items:center;gap:.4em;
  font:600 .88rem/1 var(--sans);text-decoration:none;
  color:var(--ink);transition:color .18s,gap .18s;
}
.page-back-link:hover{color:var(--brass);gap:.65em}

/* empty state */
.page-empty{
  padding:2.5rem 0;color:var(--slate);font-size:1.02rem;grid-column:1/-1;
}

/* ---- Consult CTA band ---- */
.page-cta-band{
  background:var(--hull-2);color:var(--paper);
  padding-block:clamp(3rem,6vw,5rem);
  border-top:1px solid var(--line-dark);
}
.page-cta-band__inner{
  display:grid;
  grid-template-columns:1fr auto;
  gap:clamp(1.5rem,4vw,3rem);
  align-items:center;
}
.page-cta-band .band__sub{color:var(--slate-on-dark)}
.page-cta-band__actions{
  display:flex;flex-direction:column;gap:.75rem;align-items:flex-end;
}

/* ---- Index card grid (blog + practice) ---- */
.idx-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(320px,100%),1fr));
  gap:1px;background:var(--line);border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;
  margin-block:clamp(2rem,4vw,3rem);
}
.idx-card{background:var(--paper)}
.idx-card:hover{background:#fff}
.idx-card__link{
  display:flex;flex-direction:column;padding:1.75rem 1.75rem 1.6rem;
  text-decoration:none;color:inherit;min-height:200px;
  transition:background .2s ease;
}
.idx-card__cat{
  font:600 .68rem/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass);margin-bottom:.6rem;
}
.idx-card__title{
  font:500 1.25rem/1.2 var(--serif);letter-spacing:-.01em;
  color:var(--ink);
}
.idx-card__date{
  font:500 .78rem/1 var(--sans);color:var(--slate);margin-top:.5rem;
}
.idx-card__sum{
  margin-top:.65rem;flex:1;color:var(--slate);font-size:.94rem;line-height:1.6;
}
.idx-card__go{
  margin-top:1rem;font:600 .82rem/1 var(--sans);color:var(--brass);
  transition:letter-spacing .18s;display:inline-block;
}
.idx-card:hover .idx-card__go{letter-spacing:.04em}

/* ---- Responsive overrides for page templates ---- */
@media (max-width:980px){
  .page-article{grid-template-columns:1fr}
  .page-cta-band__inner{grid-template-columns:1fr}
  .page-cta-band__actions{align-items:flex-start}
}
@media (max-width:620px){
  .idx-grid{grid-template-columns:1fr}
  .page-hero__title{max-width:none}
}

/* ============================================================
   REAL IMAGERY — Task 9
   Logo, headshots, blog images, hero photo overlay
   ============================================================ */

/* ---- Brand logo img (replaces the H monogram plate) ---- */
.brand__logo{
  height:38px;width:auto;display:block;object-fit:contain;
}
/* Keep the brand anchor tidy — no longer needs the mark+name flex */
.masthead .brand{padding:0}

/* ---- Footer logo ---- */
.foot__logo{
  height:32px;width:auto;display:block;object-fit:contain;
  margin-bottom:.75rem;/* space before the name text */
  /* logo-light on dark footer background */
}
/* Footer brand now: logo stacked above name + tag */
.foot__brand{flex-direction:column;align-items:flex-start}

/* ---- Hero photo overlay ---- */
.hero__photo{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:.28;/* very subtle — text legibility first */
  z-index:0;
}
.hero__photo-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,26,36,.55) 0%,rgba(14,26,36,.72) 100%);
  z-index:0;
}
/* Make horizon + rose render above the photo */
.hero__horizon,.hero__rose{z-index:1;position:relative}

/* ---- Attorney profile — portrait hero layout ---- */
.page-hero--attorney{padding-block:0}
.atty-profile__hero{
  display:grid;grid-template-columns:320px 1fr;gap:clamp(2rem,5vw,4rem);
  align-items:end;padding-block:clamp(3rem,7vw,5.5rem);
}
.atty-profile__portrait{
  flex:none;border-radius:var(--r);overflow:hidden;
  box-shadow:0 8px 40px rgba(14,26,36,.4);
  border:1px solid rgba(176,138,62,.25);/* thin brass border */
  align-self:stretch;max-height:440px;
}
.atty-profile__img{
  width:100%;height:100%;object-fit:cover;object-position:top center;
  display:block;
}
.atty-profile__intro{padding-bottom:clamp(2rem,4vw,3.5rem)}
@media (max-width:760px){
  .atty-profile__hero{grid-template-columns:1fr;padding-top:2.5rem}
  .atty-profile__portrait{max-height:280px;max-width:240px}
}

/* ---- Attorney photo in homepage roster ---- */
.atty__photo{
  width:62px;height:62px;object-fit:cover;object-position:top center;
  border-radius:var(--r);display:block;
  border:1px solid var(--line-dark);
}
.atty__portrait-link{display:block;flex:none}

/* ---- Attorney index grid ---- */
.atty-index__grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:clamp(1.5rem,3vw,2.5rem);padding-block:clamp(2.5rem,5vw,4rem);
}
.atty-card{
  display:flex;flex-direction:column;text-decoration:none;color:inherit;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;transition:box-shadow .25s,border-color .25s;
}
.atty-card:hover{box-shadow:0 6px 28px rgba(14,26,36,.1);border-color:var(--brass)}
.atty-card__portrait{
  width:100%;aspect-ratio:4/5;overflow:hidden;background:var(--hull);
}
.atty-card__img{
  width:100%;height:100%;object-fit:cover;object-position:top center;
  display:block;transition:transform .4s ease;
}
.atty-card:hover .atty-card__img{transform:scale(1.03)}
.atty-card__portrait--fallback{
  background:linear-gradient(160deg,var(--hull-2),var(--hull));
  display:grid;place-items:center;
}
.atty-card__body{
  padding:1.25rem 1.4rem 1.5rem;display:flex;flex-direction:column;flex:1;
}
.atty-card__name{
  font:500 1.15rem/1.2 var(--serif);letter-spacing:-.01em;margin-bottom:.4rem;
}
.atty-card__sum{font-size:.9rem;color:var(--slate);line-height:1.5;flex:1}
.atty-card__go{
  display:block;margin-top:1rem;font:600 .75rem/1 var(--sans);
  letter-spacing:.1em;text-transform:uppercase;color:var(--brass);
}
.atty-card:hover .atty-card__go{color:var(--brass-bright)}

/* ---- Blog featured image (below article hero) ---- */
.blog-featured-img{
  padding-top:0;margin-top:-1rem;margin-bottom:clamp(1.5rem,3vw,2.5rem);
}
.blog-featured-img__img{
  width:100%;max-height:420px;object-fit:cover;border-radius:var(--r);
  display:block;
}

/* ---- Blog index card — optional thumbnail ---- */
.idx-card--has-img .idx-card__link{display:flex;flex-direction:column;padding:0}
.idx-card__img-wrap{
  width:100%;aspect-ratio:16/7;overflow:hidden;background:var(--hull);border-radius:var(--r) var(--r) 0 0;
}
.idx-card__img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .4s ease;
}
.idx-card:hover .idx-card__img{transform:scale(1.03)}
.idx-card__text{padding:clamp(.9rem,2vw,1.4rem) clamp(.9rem,2vw,1.4rem) 1.1rem;display:flex;flex-direction:column;flex:1}
/* When no image, .idx-card__text padding not needed (backward compat) */
.idx-card:not(.idx-card--has-img) .idx-card__link{padding:clamp(.9rem,2vw,1.4rem)}
.idx-card:not(.idx-card--has-img) .idx-card__text{padding:0}

@media (max-width:620px){
  .atty-index__grid{grid-template-columns:1fr}
  .atty-profile__portrait{max-width:100%}
}

/* ============================================================
   PREMIUM UPGRADE — editorial insights, rich firm, practice index
   (additive; inherits all :root tokens. No new fonts/accents.)
   ============================================================ */

/* ---- shared tinted shadow + radius tokens ---- */
:root{
  --r-card:10px;
  --shadow-card:0 1px 2px rgba(14,26,36,.04), 0 14px 30px -22px rgba(14,26,36,.45);
  --shadow-card-hover:0 2px 4px rgba(14,26,36,.06), 0 26px 48px -26px rgba(14,26,36,.55);
}

/* ============================================================
   INSIGHTS / GUIDES INDEX — editorial cards, no repeated image
   ============================================================ */
.ins{padding-block:clamp(2.5rem,5vw,4rem) clamp(2rem,4vw,3rem)}

/* ---- filter chip row ---- */
.ins-filters{
  display:flex;flex-wrap:wrap;gap:.6rem;
  margin-bottom:clamp(2rem,4vw,2.75rem);
}
.ins-note{
  font:500 .95rem/1.5 var(--sans);color:var(--slate);margin-bottom:1.25rem;
}
.ins-chip{
  --cat-accent:var(--slate);
  display:inline-flex;align-items:center;gap:.5em;
  font:600 .82rem/1 var(--sans);letter-spacing:.01em;
  color:var(--ink);background:var(--paper);
  border:1px solid var(--line);border-radius:100px;
  padding:.6em 1.05em;cursor:pointer;
  transition:color .22s ease,background .22s ease,border-color .22s ease,box-shadow .22s ease;
}
.ins-chip:hover{border-color:var(--cat-accent);color:var(--cat-accent)}
.ins-chip.is-active{
  color:#fff;background:var(--cat-accent);border-color:var(--cat-accent);
  box-shadow:0 6px 16px -8px color-mix(in srgb, var(--cat-accent) 60%, transparent);
}
.ins-chip__n{
  font:600 .7rem/1 var(--sans);opacity:.62;
  font-variant-numeric:tabular-nums;
}
.ins-chip.is-active .ins-chip__n{opacity:.8}

.ins-empty{padding:2rem 0;color:var(--slate);font-size:1.02rem}

/* ---- featured (lead) cards ---- */
.ins-feature-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(1rem,2vw,1.5rem);margin-bottom:clamp(1rem,2vw,1.5rem);
}
/* ---- the tighter grid for the rest ---- */
.ins-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(1rem,2vw,1.5rem);
}

/* shared card shell */
.ins-card{
  --cat-accent:var(--slate);
  position:relative;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--r-card);
  overflow:hidden;isolation:isolate;
  transition:transform .25s cubic-bezier(.2,.7,.3,1),box-shadow .25s ease,border-color .25s ease;
  box-shadow:var(--shadow-card);
}
/* accent rail down the left edge */
.ins-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--cat-accent);opacity:.85;z-index:2;
}
.ins-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-card-hover);
  border-color:color-mix(in srgb, var(--cat-accent) 45%, var(--line));
}
.ins-card.is-hidden{display:none}

.ins-card__link{
  display:flex;flex-direction:column;height:100%;
  padding:1.5rem 1.6rem 1.4rem;text-decoration:none;color:inherit;
  position:relative;z-index:1;
}
/* faded Fraunces category initial as texture */
.ins-card__motif{
  position:absolute;top:-.35em;right:.15em;z-index:0;pointer-events:none;
  font:500 7rem/1 var(--serif);color:var(--cat-accent);
  opacity:.06;letter-spacing:-.02em;user-select:none;
}
.ins-card__cat{
  position:relative;z-index:1;align-self:flex-start;
  font:600 .64rem/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;
  color:var(--cat-accent);
  background:color-mix(in srgb, var(--cat-accent) 10%, transparent);
  border:1px solid color-mix(in srgb, var(--cat-accent) 28%, transparent);
  padding:.42em .7em;border-radius:100px;margin-bottom:1rem;
}
.ins-card__title{
  position:relative;z-index:1;
  font:500 1.2rem/1.22 var(--serif);letter-spacing:-.012em;color:var(--ink);
  transition:color .2s ease;
}
.ins-card:hover .ins-card__title{color:var(--cat-accent)}
.ins-card__sum{
  position:relative;z-index:1;
  margin-top:.6rem;color:var(--slate);font-size:.92rem;line-height:1.58;flex:1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.ins-card__foot{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  margin-top:1.1rem;padding-top:.9rem;border-top:1px solid var(--line);
}
.ins-card__date{font:500 .76rem/1 var(--sans);color:var(--slate);font-variant-numeric:tabular-nums}
.ins-card__go{
  font:600 .78rem/1 var(--sans);color:var(--cat-accent);
  display:inline-flex;align-items:center;gap:.4em;transition:gap .2s ease;
}
.ins-card__go::after{content:"→"}
.ins-card:hover .ins-card__go{gap:.7em}

/* feature card: bigger title, span 1.5 visual weight via larger type + min-height */
.ins-card--feature .ins-card__title{font-size:clamp(1.35rem,1.1rem + .9vw,1.7rem);line-height:1.16}
.ins-card--feature .ins-card__sum{-webkit-line-clamp:3;font-size:.98rem}
.ins-card--feature .ins-card__motif{font-size:9rem;opacity:.07}
.ins-card--feature .ins-card__link{padding:1.9rem 1.9rem 1.6rem;min-height:280px}

/* show-all control */
.ins-more{display:flex;justify-content:center;margin-top:clamp(2rem,4vw,2.75rem)}
.ins-more__btn{padding:.85em 1.6em;font-size:.86rem}

@media (max-width:900px){
  .ins-feature-grid,.ins-grid{grid-template-columns:repeat(2,1fr)}
  .ins-card--feature .ins-card__link{min-height:0}
}
@media (max-width:560px){
  .ins-feature-grid,.ins-grid{grid-template-columns:1fr}
}

/* ============================================================
   FIRM / ABOUT — heritage story, stats band, roster
   ============================================================ */
.firm-section__head{margin-bottom:clamp(1.75rem,3.5vw,2.75rem);max-width:42ch}
.firm-section__title{
  font:500 clamp(1.6rem,1.2rem + 1.8vw,2.5rem)/1.1 var(--serif);
  letter-spacing:-.018em;margin-top:.7rem;
}
.firm-section__sub{margin-top:.9rem;color:var(--slate);font-size:1.05rem;max-width:48ch}

/* ---- stats / credentials band ---- */
.firm-stats{background:var(--paper-2);border-block:1px solid var(--line)}
.firm-stats__row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(1rem,3vw,2.5rem);
  padding-block:clamp(2rem,4vw,3rem);
}
.firm-stat dt{
  font:600 .66rem/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;
  color:var(--brass);
}
.firm-stat dd{
  font:500 clamp(1.15rem,1rem + .6vw,1.5rem)/1.15 var(--serif);
  letter-spacing:-.01em;color:var(--ink);margin-top:.55rem;
}
@media (max-width:720px){
  .firm-stats__row{grid-template-columns:repeat(2,1fr);gap:1.5rem 1.5rem}
}

/* ---- heritage story ---- */
.firm-story{padding-block:clamp(3rem,6vw,5rem)}
.firm-story__inner{
  display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);
  gap:clamp(2rem,5vw,4.5rem);align-items:start;
}
.firm-story__inner--single{display:block;max-width:60ch}
.firm-story__lead{position:sticky;top:96px}
.firm-story__standfirst{
  margin-top:1.1rem;color:var(--slate);font-size:1.08rem;line-height:1.65;max-width:40ch;
}
.firm-story__body{max-width:68ch}
.firm-story__body .page-h2,
.firm-story__body .page-h3{
  font:500 clamp(1.1rem,.95rem + .7vw,1.35rem)/1.2 var(--serif);
  letter-spacing:-.01em;margin-top:2rem;margin-bottom:.5rem;color:var(--brass);
}
.firm-story__body .page-h2:first-child,
.firm-story__body .page-h3:first-child{margin-top:0}
.firm-story__body .page-p{color:var(--ink);line-height:1.72;max-width:68ch;margin-bottom:1rem}
@media (max-width:880px){
  .firm-story__inner{grid-template-columns:1fr;gap:2rem}
  .firm-story__lead{position:static}
}

/* ---- empty firm fallback ---- */
.firm-empty{padding-block:clamp(2.5rem,5vw,4rem)}
.firm-empty__lede{font:400 clamp(1.15rem,1rem + .7vw,1.5rem)/1.5 var(--serif);color:var(--ink);max-width:46ch}

/* ---- firm roster (portrait cards, reuses atty-card styling) ---- */
.firm-roster{padding-block:clamp(2.5rem,5vw,4rem) clamp(3rem,6vw,5rem);background:var(--paper-2);border-top:1px solid var(--line)}
.firm-roster__grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:clamp(1.25rem,2.5vw,2rem);
}

/* article framing inside firm pages */
.page-article--firm{display:block}
.page-article--firm .page-article__body{max-width:68ch}

/* ============================================================
   PRACTICE-AREAS INDEX — featured area cards + grouped specialties
   ============================================================ */
.pa-index{padding-block:clamp(2.5rem,5vw,4rem) clamp(3rem,6vw,5rem)}
.pa-index__grid{
  /* Masonry via CSS columns: cards size to their own content instead of
     stretching to a row-partner's height — this removes the big empty gap that
     sat under thin areas (Admiralty, Firearms) next to tall ones (Estate Planning). */
  columns:2;
  column-gap:clamp(1.25rem,2.5vw,2rem);
}
.pa-index__grid .pa-feature{break-inside:avoid;margin-bottom:clamp(1.25rem,2.5vw,2rem)}
.pa-feature__insights .pa-feature__specs a{color:var(--cat-accent)}
.pa-feature{
  --cat-accent:var(--slate);
  position:relative;display:flex;flex-direction:column;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-card);
  overflow:hidden;box-shadow:var(--shadow-card);
  transition:transform .25s cubic-bezier(.2,.7,.3,1),box-shadow .25s ease,border-color .25s ease;
}
.pa-feature::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--cat-accent);opacity:.85;
}
.pa-feature:hover{
  transform:translateY(-4px);box-shadow:var(--shadow-card-hover);
  border-color:color-mix(in srgb, var(--cat-accent) 45%, var(--line));
}
.pa-feature__head{
  display:block;text-decoration:none;color:inherit;
  padding:1.8rem 1.9rem 1.5rem;position:relative;
}
.pa-feature__no{
  font:600 .7rem/1 var(--sans);letter-spacing:.16em;color:var(--cat-accent);
}
.pa-feature__name{
  font:500 clamp(1.35rem,1.1rem + .8vw,1.7rem)/1.12 var(--serif);
  letter-spacing:-.015em;margin-top:.8rem;color:var(--ink);transition:color .2s ease;
}
.pa-feature:hover .pa-feature__name{color:var(--cat-accent)}
.pa-feature__sum{margin-top:.65rem;color:var(--slate);font-size:.98rem;line-height:1.55;max-width:42ch}
.pa-feature__go{
  margin-top:1.1rem;font:600 .8rem/1 var(--sans);color:var(--cat-accent);
  display:inline-flex;align-items:center;gap:.4em;transition:gap .2s ease;
}
.pa-feature__go::after{content:"→"}
.pa-feature:hover .pa-feature__go{gap:.7em}

.pa-feature__specs-wrap{
  margin-top:auto;padding:1.1rem 1.9rem 1.6rem;
  border-top:1px solid var(--line);background:color-mix(in srgb, var(--cat-accent) 4%, transparent);
}
.pa-feature__specs-label{
  font:600 .6rem/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;
  color:var(--slate);margin-bottom:.7rem;
}
.pa-feature__specs{list-style:none;display:grid;gap:.4rem;padding:0;margin:0}
.pa-feature__specs li{line-height:1.4}
.pa-feature__specs a{
  text-decoration:none;color:var(--ink);font:500 .9rem/1.4 var(--sans);
  border-bottom:1px solid transparent;transition:color .18s ease,border-color .18s ease;
}
.pa-feature__specs a:hover{color:var(--cat-accent);border-color:var(--cat-accent)}

@media (max-width:760px){
  .pa-index__grid{columns:1}
}

/* ============================================================
   GLOBAL POLISH — links, body measure, card radius (propagates)
   ============================================================ */
.page-p,.page-ul li{max-width:70ch}
.page-back-link,.bc__link,.foot__col a,.contact__v a{transition:color .22s ease,gap .22s ease}

/* Concierge "Read more" source links (deep-knowledge answers) */
.c-sources{display:flex;flex-wrap:wrap;align-items:baseline;gap:.4rem .6rem;margin:.1rem 0 .5rem;padding:0 .2rem;}
.c-sources__label{font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--brass,#b08847);font-weight:600;opacity:.85;}
.c-source{font-size:.78rem;color:var(--ink-on-dark,#e9edf2);text-decoration:none;border-bottom:1px solid rgba(176,136,71,.5);padding-bottom:1px;transition:border-color .15s,color .15s;}
.c-source:hover{color:var(--brass,#b08847);border-bottom-color:var(--brass,#b08847);}
