/* =============================================================
   McMAHON LAW OFFICES — "VERDICT" THEME
   Dark obsidian / brass / ivory · editorial-legal luxury
   ============================================================= */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..900;1,9..144,300..700&family=Hanken+Grotesk:wght@300..800&family=Space+Mono:wght@400;700&display=swap');

/* ---------- Tokens ---------- */
:root{
  --ink:        #0a0c0d;
  --ink-1:      #0e1113;
  --ink-2:      #14181b;
  --ink-3:      #1b2023;
  --brass:      #c8a558;
  --brass-2:    #e3c585;
  --brass-deep: #9c7d3c;
  --ivory:      #f3efe4;
  --ivory-dim:  #b6b1a3;
  --slate:      #757b80;
  --line:       rgba(243,239,228,.12);
  --line-2:     rgba(243,239,228,.06);
  --glow:       rgba(200,165,88,.16);

  --serif: "Fraunces", Georgia, serif;
  --sans:  "Hanken Grotesk", system-ui, sans-serif;
  --mono:  "Space Mono", ui-monospace, monospace;

  --pad: clamp(1.25rem, 5vw, 7rem);
  --ease: cubic-bezier(.16,1,.3,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0 }
html{ -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; scroll-behavior:auto }
body{
  background:var(--ink); color:var(--ivory);
  font-family:var(--sans); font-weight:330; line-height:1.6;
  font-size:clamp(1rem,.55vw + .9rem,1.15rem);
  overflow-x:hidden; cursor:none;
}
@media (max-width:900px){ body{ cursor:auto } }
img{ max-width:100%; display:block }
a{ color:inherit; text-decoration:none }
button{ font:inherit; color:inherit; background:none; border:none; cursor:none }
::selection{ background:var(--brass); color:var(--ink) }

/* ---------- Grain + vignette overlays ----------
   Static grain (no per-frame repaint) keeps scrolling smooth. */
.grain{
  position:fixed; inset:0; z-index:9998; pointer-events:none;
  opacity:.045; mix-blend-mode:overlay; will-change:auto;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.vignette{ position:fixed; inset:0; z-index:9997; pointer-events:none;
  box-shadow:inset 0 0 18vw rgba(0,0,0,.7); }

/* ---------- Custom cursor ---------- */
.cursor{ position:fixed; top:0; left:0; width:8px; height:8px; border-radius:50%;
  background:var(--brass); z-index:10000; pointer-events:none; transform:translate(-50%,-50%);
  transition:width .3s var(--ease),height .3s var(--ease),background .3s,opacity .3s }
.cursor-ring{ position:fixed; top:0; left:0; width:38px; height:38px; border:1px solid rgba(200,165,88,.5);
  border-radius:50%; z-index:10000; pointer-events:none; transform:translate(-50%,-50%);
  transition:width .35s var(--ease),height .35s var(--ease),border-color .35s,opacity .3s }
body.cursor-hover .cursor{ width:0; height:0 }
body.cursor-hover .cursor-ring{ width:64px; height:64px; border-color:var(--brass) }
@media (max-width:900px){ .cursor,.cursor-ring{ display:none } }

/* ---------- Progress bar ---------- */
.progress{ position:fixed; top:0; left:0; height:2px; width:0%; z-index:9999;
  background:linear-gradient(90deg,var(--brass-deep),var(--brass-2)); }

/* ---------- Nav ---------- */
.nav{ position:fixed; inset:0 0 auto 0; z-index:9000; display:flex; align-items:center;
  justify-content:space-between; padding:1.5rem var(--pad);
  transition:padding .5s var(--ease),background .5s,backdrop-filter .5s,border-color .5s;
  border-bottom:1px solid transparent }
.nav.shrunk{ padding:.85rem var(--pad); background:rgba(10,12,13,.72);
  backdrop-filter:blur(18px) saturate(1.2); border-bottom:1px solid var(--line) }
.brand{ display:flex; align-items:center; gap:.85rem; z-index:2 }
.brand-mark{ width:38px; height:38px; flex:none }
.brand-mark svg{ width:100%; height:100% }
.brand-txt{ line-height:1 }
.brand-txt b{ font-family:var(--serif); font-weight:500; font-size:1.18rem; letter-spacing:.01em;
  font-optical-sizing:auto; display:block }
.brand-txt span{ font-family:var(--mono); font-size:.56rem; letter-spacing:.42em;
  text-transform:uppercase; color:var(--brass); }
.nav-links{ display:flex; gap:2.2rem; align-items:center }
.nav-links a{ font-size:.82rem; letter-spacing:.02em; position:relative; padding:.2rem 0;
  color:var(--ivory-dim); transition:color .3s }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px;
  background:var(--brass); transition:width .4s var(--ease) }
.nav-links a:hover,.nav-links a.active{ color:var(--ivory) }
.nav-links a:hover::after,.nav-links a.active::after{ width:100% }
.nav-cta{ display:inline-flex; align-items:center; gap:.55rem; border:1px solid var(--line);
  padding:.65rem 1.2rem; border-radius:50px; font-family:var(--mono); font-size:.72rem;
  letter-spacing:.08em; transition:border-color .4s,color .4s,background .4s }
.nav-cta:hover{ border-color:var(--brass); color:var(--brass) }
.nav-cta b{ color:var(--brass) }
.nav-burger{ display:none; flex-direction:column; gap:5px; z-index:2 }
.nav-burger span{ width:26px; height:1.5px; background:var(--ivory); transition:.4s var(--ease) }
.nav.open .nav-burger span:nth-child(1){ transform:translateY(6.5px) rotate(45deg) }
.nav.open .nav-burger span:nth-child(2){ opacity:0 }
.nav.open .nav-burger span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg) }

@media (max-width:1040px){
  .nav-burger{ display:flex }
  .nav-links{ position:fixed; inset:0; flex-direction:column; justify-content:center; gap:1.5rem;
    background:rgba(10,12,13,.97); backdrop-filter:blur(20px); transform:translateX(100%);
    transition:transform .6s var(--ease); padding:0 }
  .nav.open .nav-links{ transform:translateX(0) }
  .nav-links a{ font-family:var(--serif); font-size:1.8rem; color:var(--ivory) }
  .nav-links .nav-cta{ font-family:var(--mono); font-size:.9rem }
}

/* ---------- Layout helpers ---------- */
.section{ position:relative; padding:clamp(5rem,12vh,11rem) var(--pad) }
.eyebrow{ font-family:var(--mono); font-size:.72rem; letter-spacing:.34em; text-transform:uppercase;
  color:var(--brass); display:inline-flex; align-items:center; gap:.8rem; margin-bottom:1.6rem }
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--brass); opacity:.6 }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:380; line-height:1.04; letter-spacing:-.01em;
  font-optical-sizing:auto }
.h-display{ font-size:clamp(2.6rem,8vw,7.5rem) }
.h-xl{ font-size:clamp(2.2rem,5.5vw,4.6rem); line-height:1.05 }
.h-lg{ font-size:clamp(1.8rem,3.5vw,3rem) }
.lede{ font-size:clamp(1.15rem,1.5vw,1.5rem); color:var(--ivory-dim); font-weight:320;
  line-height:1.55; max-width:60ch }
.muted{ color:var(--ivory-dim) }
em.it{ font-style:italic; color:var(--brass-2); font-family:var(--serif) }

/* ---------- Reveal primitives ---------- */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1s var(--ease),transform 1s var(--ease) }
.reveal.in{ opacity:1; transform:none }
.line-mask{ overflow:hidden; display:block }
.line-mask > *{ display:block; transform:translateY(110%); transition:transform 1.1s var(--ease) }
.line-mask.in > *{ transform:none }

/* ---------- Buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:.8rem; padding:1rem 1.9rem; border-radius:50px;
  font-family:var(--mono); font-size:.78rem; letter-spacing:.08em; text-transform:uppercase;
  position:relative; overflow:hidden; transition:color .4s,transform .3s var(--ease) }
.btn .dot{ width:7px; height:7px; border-radius:50%; background:currentColor }
.btn-fill{ background:var(--brass); color:var(--ink); font-weight:700 }
.btn-fill::before{ content:""; position:absolute; inset:0; background:var(--brass-2);
  transform:translateY(101%); transition:transform .5s var(--ease); z-index:0 }
.btn-fill:hover::before{ transform:translateY(0) }
.btn-fill span,.btn-fill .dot{ position:relative; z-index:1 }
.btn-ghost{ border:1px solid var(--line); color:var(--ivory) }
.btn-ghost:hover{ border-color:var(--brass); color:var(--brass) }

/* =============================================================
   HERO
   ============================================================= */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end;
  padding:0 var(--pad) clamp(3rem,8vh,7rem); overflow:hidden }
.hero-bg{ position:absolute; inset:0; z-index:0 }
.hero-glow{ position:absolute; width:90vw; height:90vw; max-width:1100px; max-height:1100px;
  top:-30%; left:50%; transform:translateX(-50%);
  background:radial-gradient(circle, var(--glow), transparent 60%); filter:blur(20px) }
.hero-grid{ position:absolute; inset:0; opacity:.4;
  background-image:linear-gradient(var(--line-2) 1px,transparent 1px),
                   linear-gradient(90deg,var(--line-2) 1px,transparent 1px);
  background-size:clamp(60px,7vw,120px) clamp(60px,7vw,120px);
  mask-image:radial-gradient(ellipse at 50% 30%,#000,transparent 75%) }
/* monogram / scales linework */
.hero-emblem{ position:absolute; top:50%; left:50%; width:min(80vh,80vw); height:min(80vh,80vw);
  transform:translate(-50%,-58%); opacity:.16; z-index:0; pointer-events:none }
.hero-emblem svg{ width:100%; height:100%; stroke:var(--brass); fill:none }
.hero-inner{ position:relative; z-index:2; width:100%; max-width:1500px; margin:0 auto }
.hero-top{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ivory-dim); border-top:1px solid var(--line); padding-top:1.2rem; margin-bottom:clamp(2rem,6vh,5rem) }
.hero-top span{ color:var(--brass) }
.hero h1{ font-size:clamp(3rem,12.5vw,13rem); line-height:.92; letter-spacing:-.02em; font-weight:340 }
.hero h1 .ln{ display:block; overflow:hidden }
.hero h1 .ln > span{ display:block }
.hero h1 .accent{ font-style:italic; font-weight:340; color:var(--brass-2) }
.hero-sub{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between;
  gap:2rem; margin-top:clamp(1.5rem,4vh,3rem) }
.hero-sub .lede{ max-width:46ch }
.scroll-cue{ display:flex; align-items:center; gap:.8rem; font-family:var(--mono);
  font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ivory-dim) }
.scroll-cue .bar{ width:1px; height:48px; background:var(--line); position:relative; overflow:hidden }
.scroll-cue .bar::after{ content:""; position:absolute; top:0; left:0; width:100%; height:40%;
  background:var(--brass); animation:cue 2.2s var(--ease) infinite }
@keyframes cue{ 0%{transform:translateY(-100%)} 60%,100%{transform:translateY(250%)} }

/* =============================================================
   MARQUEE
   ============================================================= */
.marquee{ border-block:1px solid var(--line); padding:1.3rem 0; overflow:hidden;
  display:flex; gap:0; white-space:nowrap; background:var(--ink-1) }
.marquee-track{ display:flex; gap:3.5rem; padding-right:3.5rem; animation:scroll 38s linear infinite;
  font-family:var(--serif); font-size:clamp(1.3rem,2.4vw,2.1rem); font-style:italic; color:var(--ivory) }
.marquee-track span{ display:inline-flex; align-items:center; gap:3.5rem; color:var(--ivory) }
.marquee-track span::after{ content:"§"; color:var(--brass); font-style:normal }
@keyframes scroll{ to{ transform:translateX(-50%) } }

/* =============================================================
   INTRO / STATEMENT
   ============================================================= */
.statement{ display:grid; grid-template-columns:1fr; gap:clamp(2rem,5vw,5rem); align-items:start }
.statement .big{ font-family:var(--serif); font-size:clamp(1.7rem,3.4vw,3.1rem); line-height:1.22;
  font-weight:360; max-width:24ch }
.statement .big b{ font-weight:360; color:var(--brass-2); font-style:italic }
.statement-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(2rem,4vw,4rem) }
@media (max-width:760px){ .statement-grid{ grid-template-columns:1fr } }

/* giant decorative numeral */
.numeral{ position:absolute; font-family:var(--serif); font-weight:300; font-style:italic;
  font-size:clamp(14rem,40vw,40rem); line-height:.7; color:rgba(243,239,228,.025);
  pointer-events:none; user-select:none; z-index:0 }

/* =============================================================
   STATS
   ============================================================= */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line) }
.stat{ background:var(--ink); padding:clamp(2rem,3vw,3.2rem) clamp(1.5rem,2.5vw,2.5rem) }
.stat .n{ font-family:var(--serif); font-size:clamp(2.6rem,5vw,4.6rem); line-height:1;
  color:var(--brass-2); font-weight:380 }
.stat .l{ font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ivory-dim); margin-top:.9rem; line-height:1.5 }
@media (max-width:860px){ .stats{ grid-template-columns:repeat(2,1fr) } }

/* =============================================================
   PRACTICE AREAS — list reveal
   ============================================================= */
.practice-list{ border-top:1px solid var(--line) }
.pr{ display:grid; grid-template-columns:auto 1fr auto; gap:2rem; align-items:center;
  padding:clamp(1.5rem,3.2vw,2.8rem) 0; border-bottom:1px solid var(--line);
  position:relative; transition:padding .4s var(--ease) }
.pr-no{ font-family:var(--mono); font-size:.8rem; color:var(--brass); letter-spacing:.1em }
.pr-name{ font-family:var(--serif); font-size:clamp(1.7rem,4.2vw,3.4rem); font-weight:360;
  transition:color .4s,transform .5s var(--ease); line-height:1 }
.pr-meta{ font-family:var(--mono); font-size:.72rem; color:var(--ivory-dim); letter-spacing:.08em;
  text-transform:uppercase; text-align:right; transition:color .4s }
.pr::before{ content:""; position:absolute; inset:0; background:
   linear-gradient(90deg, rgba(200,165,88,.08), transparent); opacity:0; transition:opacity .5s }
.pr:hover::before{ opacity:1 }
.pr:hover .pr-name{ color:var(--brass-2); transform:translateX(1.2rem) }
.pr:hover .pr-meta{ color:var(--brass) }
.pr-arrow{ width:30px; height:30px; opacity:0; transform:translateX(-12px);
  transition:opacity .4s,transform .5s var(--ease); color:var(--brass) }
.pr:hover .pr-arrow{ opacity:1; transform:none }
@media (max-width:680px){
  .pr{ grid-template-columns:auto 1fr; gap:1rem }
  .pr-meta{ display:none }
}

/* practice detail cards (practice page) */
.pcard{ position:relative; padding:clamp(2rem,4vw,4rem); border:1px solid var(--line);
  background:linear-gradient(160deg,var(--ink-1),var(--ink)); overflow:hidden }
.pcard .gn{ position:absolute; top:-2rem; right:-.5rem; font-family:var(--serif); font-style:italic;
  font-size:9rem; color:rgba(243,239,228,.03); line-height:1 }
.pcard h3{ font-size:clamp(1.6rem,2.6vw,2.4rem); margin-bottom:1rem }
.pcard p{ color:var(--ivory-dim); max-width:52ch }
.pcard .tag{ font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--brass); margin-bottom:1.4rem; display:block }
.pgrid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line) }
@media (max-width:780px){ .pgrid{ grid-template-columns:1fr } }

/* =============================================================
   FEATURE / IMAGE PARALLAX BLOCK
   ============================================================= */
.feature{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,6rem); align-items:center }
@media (max-width:900px){ .feature{ grid-template-columns:1fr } }
.feature-media{ position:relative; aspect-ratio:4/5; overflow:hidden; border:1px solid var(--line) }
.feature-media .layer{ position:absolute; inset:-12% 0; background-size:cover; background-position:center }
.feature-media .frame{ position:absolute; inset:1rem; border:1px solid rgba(243,239,228,.25); z-index:2; pointer-events:none }
.feature-media .cap{ position:absolute; left:1.5rem; bottom:1.5rem; z-index:2;
  font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ivory); background:rgba(10,12,13,.6); backdrop-filter:blur(6px);
  padding:.5rem .8rem; border:1px solid var(--line) }
.feature ul{ list-style:none; margin-top:2rem; border-top:1px solid var(--line) }
.feature li{ padding:1.1rem 0; border-bottom:1px solid var(--line); display:flex; gap:1rem; align-items:baseline }
.feature li b{ font-family:var(--mono); font-size:.72rem; color:var(--brass); letter-spacing:.1em }
.feature li span{ color:var(--ivory-dim) }

/* =============================================================
   VALUES / DOSSIER CARDS
   ============================================================= */
.dossier{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2vw,1.6rem) }
@media (max-width:880px){ .dossier{ grid-template-columns:1fr } }
.doc{ border:1px solid var(--line); padding:clamp(1.8rem,2.5vw,2.6rem); background:var(--ink-1);
  position:relative; transition:transform .5s var(--ease),border-color .5s,background .5s }
.doc:hover{ transform:translateY(-8px); border-color:rgba(200,165,88,.4); background:var(--ink-2) }
.doc .ix{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; color:var(--brass);
  display:flex; justify-content:space-between; margin-bottom:2.4rem }
.doc h3{ font-size:clamp(1.4rem,2vw,1.9rem); margin-bottom:.9rem }
.doc p{ color:var(--ivory-dim); font-size:.98rem }

/* =============================================================
   LOCATIONS
   ============================================================= */
.loc-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line) }
@media (max-width:820px){ .loc-grid{ grid-template-columns:1fr } }
.loc{ background:var(--ink-1); padding:clamp(2rem,4vw,3.6rem); position:relative; overflow:hidden;
  transition:background .5s }
.loc:hover{ background:var(--ink-2) }
.loc .pin{ font-family:var(--mono); font-size:.68rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--brass); margin-bottom:1.5rem }
.loc h3{ font-size:clamp(1.8rem,3vw,2.6rem); margin-bottom:1.4rem }
.loc address{ font-style:normal; color:var(--ivory-dim); line-height:1.9; font-size:1.02rem }
.loc address a{ color:var(--ivory); border-bottom:1px solid var(--line); transition:border-color .3s,color .3s }
.loc address a:hover{ color:var(--brass); border-color:var(--brass) }
.loc-map{ aspect-ratio:16/8; margin-top:1.8rem; border:1px solid var(--line); overflow:hidden;
  filter:grayscale(1) contrast(1.05) brightness(.7) sepia(.25) }
.loc-map iframe{ width:100%; height:100%; border:0 }

/* =============================================================
   CONTACT FORM
   ============================================================= */
.contact-wrap{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,5vw,5rem) }
@media (max-width:900px){ .contact-wrap{ grid-template-columns:1fr } }
.field{ position:relative; margin-bottom:1.6rem }
.field label{ font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ivory-dim); display:block; margin-bottom:.6rem }
.field input,.field textarea,.field select{ width:100%; background:var(--ink-1); border:1px solid var(--line);
  color:var(--ivory); padding:.95rem 1.1rem; font-family:var(--sans); font-size:1rem;
  transition:border-color .4s,background .4s; cursor:none }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--brass);
  background:var(--ink-2) }
.field textarea{ resize:vertical; min-height:130px }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem }
@media (max-width:560px){ .form-row{ grid-template-columns:1fr } }
.form-note{ font-family:var(--mono); font-size:.66rem; color:var(--slate); letter-spacing:.06em; margin-top:1rem }

/* =============================================================
   CTA BAND
   ============================================================= */
.cta{ text-align:center; position:relative; overflow:hidden }
.cta h2{ font-size:clamp(2.4rem,7vw,6rem); line-height:1; margin-bottom:2rem }
.cta .phone{ font-family:var(--serif); font-style:italic; color:var(--brass-2);
  font-size:clamp(1.6rem,3vw,2.4rem); display:inline-block; margin-top:1.5rem;
  border-bottom:1px solid var(--line); transition:border-color .4s }
.cta .phone:hover{ border-color:var(--brass) }

/* =============================================================
   FOOTER
   ============================================================= */
.footer{ border-top:1px solid var(--line); padding:clamp(3rem,7vh,6rem) var(--pad) 2.5rem;
  background:var(--ink-1) }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2.5rem; margin-bottom:4rem }
@media (max-width:880px){ .footer-top{ grid-template-columns:1fr 1fr } }
@media (max-width:520px){ .footer-top{ grid-template-columns:1fr } }
.footer h4{ font-family:var(--mono); font-size:.68rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--brass); margin-bottom:1.5rem; font-weight:400 }
.footer ul{ list-style:none }
.footer li{ margin-bottom:.8rem }
.footer li a{ color:var(--ivory-dim); transition:color .3s; font-size:.95rem }
.footer li a:hover{ color:var(--ivory) }
.footer-brand .brand-txt b{ font-size:1.5rem }
.footer-brand p{ color:var(--ivory-dim); margin-top:1.2rem; max-width:34ch; font-size:.95rem }
.footer-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem;
  border-top:1px solid var(--line); padding-top:2rem; font-family:var(--mono);
  font-size:.68rem; letter-spacing:.08em; color:var(--slate); text-transform:uppercase }

/* =============================================================
   PAGE HERO (interior pages)
   ============================================================= */
.page-hero{ position:relative; padding:clamp(9rem,18vh,14rem) var(--pad) clamp(3rem,8vh,6rem);
  overflow:hidden; border-bottom:1px solid var(--line) }
.page-hero h1{ font-size:clamp(2.8rem,9vw,8rem); line-height:.95 }
.page-hero .lede{ margin-top:2rem }
.page-hero .crumbs{ font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ivory-dim); margin-bottom:2rem }
.page-hero .crumbs span{ color:var(--brass) }

/* prose */
.prose p{ margin-bottom:1.4rem; color:var(--ivory-dim); max-width:64ch }
.prose p:first-child::first-letter{ font-family:var(--serif); font-size:4.2rem; float:left;
  line-height:.8; padding:.1em .12em 0 0; color:var(--brass-2); font-style:italic }

/* affiliations */
.affil-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line) }
@media (max-width:760px){ .affil-grid{ grid-template-columns:1fr } }
.affil{ background:var(--ink-1); padding:clamp(2rem,3vw,3rem); min-height:200px; display:flex;
  flex-direction:column; justify-content:space-between; transition:background .4s }
.affil:hover{ background:var(--ink-2) }
.affil .n{ font-family:var(--mono); font-size:.7rem; color:var(--brass); letter-spacing:.14em }
.affil h3{ font-size:1.5rem }
.affil p{ color:var(--ivory-dim); font-size:.9rem }

/* resources */
.res{ display:grid; grid-template-columns:auto 1fr auto; gap:2rem; align-items:center;
  padding:1.8rem 0; border-bottom:1px solid var(--line); transition:padding .4s var(--ease) }
.res:hover{ padding-left:1rem }
.res .rno{ font-family:var(--mono); color:var(--brass); font-size:.8rem }
.res h3{ font-size:clamp(1.3rem,2.4vw,2rem) }
.res p{ color:var(--ivory-dim); font-size:.92rem; margin-top:.3rem }
.res .go{ font-family:var(--mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--brass); white-space:nowrap }

/* attorneys */
.atty-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line) }
@media (max-width:760px){ .atty-grid{ grid-template-columns:1fr } }
.atty{ background:var(--ink-1); padding:clamp(2rem,3.5vw,3.4rem); transition:background .4s }
.atty:hover{ background:var(--ink-2) }
.atty .av{ width:80px; height:80px; border-radius:50%; border:1px solid var(--brass);
  display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-style:italic;
  font-size:1.8rem; color:var(--brass-2); margin-bottom:1.6rem }
.atty h3{ font-size:1.8rem }
.atty .role{ font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--brass); margin:.5rem 0 1.2rem }
.atty p{ color:var(--ivory-dim); font-size:.95rem }

/* placeholder flag */
.ph{ outline:1px dashed rgba(200,165,88,.45); outline-offset:3px }
.ph-tag{ display:inline-block; font-family:var(--mono); font-size:.58rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink); background:var(--brass); padding:.15rem .45rem;
  border-radius:3px; margin-left:.5rem; vertical-align:middle }

/* utility */
.center{ text-align:center }
.mt-s{ margin-top:1.5rem } .mt-m{ margin-top:3rem } .mt-l{ margin-top:5rem }
.maxw{ max-width:1500px; margin-inline:auto }
.split-head{ display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:1.5rem }
hr.rule{ border:none; border-top:1px solid var(--line); margin:0 }

/* =============================================================
   PHOTOGRAPHY — treatments, photo media, full-bleed band
   ============================================================= */
/* real photo inside the feature-media block */
.feature-media .photo{ position:absolute; inset:-8% 0; width:100%; height:116%;
  object-fit:cover; will-change:transform; }
.feature-media.warm .photo{ filter:contrast(1.05) brightness(.86) saturate(.95); }
/* heavy obsidian/brass treatment for bright source images */
.feature-media.treat .photo{ filter:grayscale(.55) sepia(.28) contrast(1.04) brightness(.62)
  saturate(.85) hue-rotate(-8deg); }
.feature-media .scrim{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg,rgba(10,12,13,.15),rgba(10,12,13,.6)),
             radial-gradient(120% 80% at 70% 20%,transparent,rgba(10,12,13,.55)); }

/* hero — visible full-bleed cinematic backdrop */
.hero-photo{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.hero-photo img{ width:100%; height:118%; object-fit:cover; object-position:60% center;
  will-change:transform;
  filter:grayscale(.22) sepia(.16) brightness(.72) contrast(1.06) saturate(.92) hue-rotate(-6deg); }
.hero-photo::after{ content:""; position:absolute; inset:0; pointer-events:none;
  background:
    linear-gradient(180deg, rgba(10,12,13,.55) 0%, rgba(10,12,13,.22) 32%, rgba(10,12,13,.5) 68%, rgba(10,12,13,.97) 100%),
    linear-gradient(90deg, rgba(10,12,13,.94) 0%, rgba(10,12,13,.55) 40%, rgba(10,12,13,.06) 78%, rgba(10,12,13,0) 100%); }
/* when a photo is present, calm the line-grid + emblem so they don't clutter it */
.hero.has-photo .hero-grid{ opacity:.12; }
.hero.has-photo .hero-emblem{ opacity:.07; }
.hero.has-photo .hero-glow{ opacity:.6; }
@media (max-width:760px){
  .hero-photo img{ object-position:74% center; }
  .hero-photo::after{ background:
    linear-gradient(180deg, rgba(10,12,13,.62) 0%, rgba(10,12,13,.34) 24%, rgba(10,12,13,.72) 58%, rgba(10,12,13,.98) 100%); }
}

/* full-bleed cinematic image band */
.band{ position:relative; min-height:78vh; display:flex; align-items:center;
  padding:clamp(4rem,10vh,9rem) var(--pad); overflow:hidden; border-block:1px solid var(--line); }
.band-bg{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.band-bg img{ width:100%; height:128%; object-fit:cover; will-change:transform;
  filter:grayscale(.4) sepia(.22) brightness(.5) contrast(1.05) saturate(.9) hue-rotate(-8deg); }
.band-bg::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(90deg,rgba(10,12,13,.92) 0%,rgba(10,12,13,.72) 38%,rgba(10,12,13,.35) 100%); }
.band-inner{ position:relative; z-index:2; max-width:1500px; margin-inline:auto; width:100%; }
.band .q{ font-family:var(--serif); font-style:italic; font-weight:340;
  font-size:clamp(1.9rem,4.2vw,4rem); line-height:1.16; max-width:20ch; }
.band .q b{ color:var(--brass-2); font-weight:340; font-style:italic; }
.band .by{ font-family:var(--mono); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ivory-dim); margin-top:2rem; display:flex; align-items:center; gap:.9rem; }
.band .by::before{ content:""; width:34px; height:1px; background:var(--brass); }

/* attorney profile (real, single attorney) */
.attorney{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(2rem,5vw,5rem); align-items:start; }
@media (max-width:880px){ .attorney{ grid-template-columns:1fr } }
.attorney-media{ position:relative; aspect-ratio:3/4; overflow:hidden; border:1px solid var(--line);
  background:linear-gradient(160deg,var(--ink-2),var(--ink)); }
.attorney-media .photo{ position:absolute; inset:-6% 0; width:100%; height:112%; object-fit:cover;
  will-change:transform; filter:grayscale(.45) sepia(.2) brightness(.7) contrast(1.04); }
.attorney-media .frame{ position:absolute; inset:1rem; border:1px solid rgba(243,239,228,.22); z-index:2; }
.attorney-media .mono{ position:absolute; left:1.5rem; bottom:1.4rem; z-index:3; font-family:var(--serif);
  font-style:italic; font-size:2.4rem; color:var(--brass-2); }
.attorney h2{ font-size:clamp(2rem,4vw,3.2rem); }
.attorney .role{ font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--brass); margin:.7rem 0 2rem; }
.attorney .bio p{ color:var(--ivory-dim); margin-bottom:1.2rem; max-width:62ch; }
.attorney .creds{ list-style:none; margin-top:2rem; border-top:1px solid var(--line); }
.attorney .creds li{ padding:1rem 0; border-bottom:1px solid var(--line); display:grid;
  grid-template-columns:9rem 1fr; gap:1.2rem; align-items:baseline; }
.attorney .creds b{ font-family:var(--mono); font-size:.68rem; letter-spacing:.12em; color:var(--brass);
  text-transform:uppercase; }
.attorney .creds span{ color:var(--ivory-dim); }
@media (max-width:520px){ .attorney .creds li{ grid-template-columns:1fr; gap:.2rem } }

/* GPU hints — keep transforms on their own layer for smooth scrubbing */
.hero-emblem,.numeral,.feature-media .layer,[data-par]{ will-change:transform; }
.nav.shrunk{ backdrop-filter:blur(14px) saturate(1.15); }

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition-duration:.01ms !important }
  .reveal{ opacity:1; transform:none } .line-mask > *{ transform:none }
  .hero-photo img,.band-bg img,.feature-media .photo{ filter:brightness(.5) grayscale(.5) }
}
