/* ============================================================
   Lockhart & Yip — Direction A · "East–West Meridian"
   Single source of style for all pages. Tokens per docs/design-system.md.
   Reference markup: site/index.html (home).
   ============================================================ */
/* Self-hosted fonts (latin subsets, font-display: swap) — no external font CDN. */
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:500;font-display:swap;src:url('/assets/fonts/cormorant-garamond-italic-500-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/cormorant-garamond-normal-500-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/cormorant-garamond-normal-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/inter-normal-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/inter-normal-500-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/inter-normal-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}

:root{
  --bg:#F6F3EC;          /* ivory */
  --bg-alt:#EFEBE0;      /* ivory dark */
  --ink:#13211E;         /* night jade */
  --ink-soft:#3C4B47;
  --accent:#1F4A40;      /* deep jade */
  --brass:#9C7C3C;       /* brass */
  --rule:#CFC7B4;
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.55}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
h1,h2,h3,.serif{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600}
.eyebrow{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--brass);font-weight:600}

/* accessibility / quality floor */
a:focus-visible,button:focus-visible,.btn:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{transition:none!important;animation:none!important}
}

/* top bar */
.topbar{border-bottom:1px solid var(--rule);font-size:11.5px;color:var(--ink-soft);letter-spacing:.04em}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px;text-transform:uppercase}
.topbar .r span{margin-left:18px}

/* masthead */
.mast{border-bottom:2px solid var(--ink)}
.mast .wrap{display:flex;justify-content:space-between;align-items:center;padding:26px 28px}
.logo{font-family:'Cormorant Garamond',Georgia,serif;font-size:30px;font-weight:600;letter-spacing:.02em}
.logo b{font-weight:600}
.logo .amp{color:var(--brass);margin:0 4px}
.logo small{display:block;font-family:'Inter';font-size:9.5px;font-weight:500;letter-spacing:.34em;color:var(--ink-soft);text-transform:uppercase;margin-top:5px}
.mast-cta{font-size:12.5px;font-weight:500;border:1px solid var(--ink);padding:11px 20px;transition:.2s}
.mast-cta:hover{background:var(--ink);color:var(--bg)}

/* nav */
nav{border-bottom:1px solid var(--rule);background:var(--bg)}
nav .wrap{display:flex;gap:30px;height:50px;align-items:center;font-size:13px;font-weight:500}
nav a{padding:4px 0;border-bottom:2px solid transparent;transition:.2s}
nav a:hover,nav a[aria-current="page"]{border-bottom-color:var(--brass)}

/* hero (home) */
.hero{padding:64px 0 56px}
.hero .wrap{display:grid;grid-template-columns:1.55fr .9fr;gap:54px;align-items:start}
.hero .eyebrow{margin-bottom:20px}
.hero h1{font-size:60px;line-height:1.04;letter-spacing:-.01em}
.hero h1 i{font-style:italic;color:var(--accent)}
.hero p.lede{font-family:'Cormorant Garamond',Georgia,serif;font-size:23px;line-height:1.42;color:var(--ink-soft);margin-top:26px;max-width:34em}
.hero .actions{margin-top:34px;display:flex;gap:14px;align-items:center}
.btn{display:inline-block;font-family:'Inter';font-size:13.5px;font-weight:600;padding:14px 26px;border:1px solid var(--ink);transition:.2s;cursor:pointer}
.btn.primary{background:var(--ink);color:var(--bg)}
.btn.primary:hover{background:var(--accent);border-color:var(--accent)}
.btn.ghost:hover{background:var(--bg-alt)}

/* metrics */
.metrics{border-left:1px solid var(--rule);padding-left:30px}
.metric{padding:18px 0;border-bottom:1px solid var(--rule)}
.metric:first-child{padding-top:0}
.metric .n{font-family:'Cormorant Garamond',Georgia,serif;font-size:42px;font-weight:600;line-height:1;color:var(--accent)}
.metric .l{font-size:12px;color:var(--ink-soft);margin-top:7px;letter-spacing:.02em}

/* disclaimer strip */
.strip{background:var(--ink);color:var(--bg)}
.strip .wrap{padding:16px 28px;font-size:12.5px;letter-spacing:.02em;display:flex;gap:14px;align-items:center}
.strip .eyebrow{color:var(--brass);white-space:nowrap}

/* sections */
.sec{padding:64px 0}
.sec-head{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--ink);padding-bottom:14px;margin-bottom:36px}
.sec-head h2{font-size:34px;letter-spacing:-.01em}
.sec-head .eyebrow{align-self:flex-end}

/* card grid (practices / sub-services) */
.pg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
.pg.cols2{grid-template-columns:repeat(2,1fr)}
.pc{display:block;background:var(--bg);padding:30px 26px 34px;transition:.2s}
a.pc{cursor:pointer}
.pc:hover{background:var(--bg-alt)}
.pc .no{font-size:11px;letter-spacing:.2em;color:var(--brass);font-weight:600;text-transform:uppercase}
.pc h3{font-size:23px;margin:12px 0 10px;line-height:1.15}
.pc p{font-size:13.5px;color:var(--ink-soft);line-height:1.5}
.pc .note{font-size:11.5px;color:var(--ink-soft);margin-top:12px;padding-top:10px;border-top:1px solid var(--rule)}

/* split / value */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--rule)}
.split>div{padding:46px 42px}
.split .a{background:var(--accent);color:var(--bg)}
.split .a .eyebrow{color:var(--brass)}
.split .a h2{color:var(--bg);font-size:32px;margin:16px 0 18px;line-height:1.1}
.split .a p{font-size:15px;line-height:1.6;opacity:.92}
.split .b{background:var(--bg-alt)}
.split .b ul{list-style:none;margin-top:18px}
.split .b li{padding:15px 0;border-bottom:1px solid var(--rule);font-size:14.5px;display:flex;gap:14px}
.split .b li:last-child{border:0}
.split .b li b{font-family:'Cormorant Garamond',Georgia,serif;font-size:20px;color:var(--accent);min-width:30px}

/* insights cards */
.ig{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.ia{display:block;border-top:2px solid var(--ink);padding-top:16px}
a.ia{cursor:pointer}
a.ia:hover h3{color:var(--accent)}
.ia .k{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);font-weight:600}
.ia h3{font-size:21px;margin:10px 0 9px;line-height:1.2;transition:.2s}
.ia p{font-size:13px;color:var(--ink-soft)}
.ia .by{font-size:11.5px;color:var(--ink-soft);margin-top:13px;letter-spacing:.02em}

/* footer */
footer{background:var(--ink);color:var(--bg);margin-top:30px}
footer .wrap{padding:54px 28px 30px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
footer .logo{color:var(--bg)}
footer .logo small{color:#8a948f}
footer h4{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);margin-bottom:16px;font-weight:600}
footer a,footer p{display:block;font-size:13px;color:#c3ccc7;margin-bottom:10px}
footer a:hover{color:var(--bg)}
.fbar{border-top:1px solid #2a3733;margin-top:20px}
.fbar .wrap{padding:18px 28px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:11.5px;color:#8a948f;grid-template-columns:none}
.fbar a{display:inline;font-size:11.5px;color:#8a948f;margin:0 0 0 10px}
.fbar a:hover{color:var(--bg)}

/* ============================================================
   Inner-page components
   ============================================================ */

/* breadcrumbs */
.crumbs{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);padding:22px 0 0}
.crumbs a:hover{color:var(--accent)}
.crumbs span.sep{margin:0 8px;color:var(--rule)}

/* page hero (inner pages) */
.phero{padding:44px 0 52px}
.phero .wrap{display:grid;grid-template-columns:1.55fr .9fr;gap:54px;align-items:start}
.phero.single .wrap{grid-template-columns:1fr}
.phero .eyebrow{margin-bottom:18px}
.phero h1{font-size:48px;line-height:1.06;letter-spacing:-.01em;max-width:18em}
.phero h1 i{font-style:italic;color:var(--accent)}
.phero p.lede{font-family:'Cormorant Garamond',Georgia,serif;font-size:22px;line-height:1.42;color:var(--ink-soft);margin-top:22px;max-width:36em}
.phero .actions{margin-top:30px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}

/* prose (legal pages, long text) */
.prose{max-width:760px}
.prose h2{font-size:28px;margin:38px 0 14px}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:21px;margin:26px 0 10px}
.prose p{font-size:14.5px;color:var(--ink-soft);margin-bottom:14px;line-height:1.65}
.prose ul,.prose ol{margin:0 0 14px 20px}
.prose li{font-size:14.5px;color:var(--ink-soft);margin-bottom:8px;line-height:1.6}
.prose strong{color:var(--ink)}
.prose a{color:var(--accent);border-bottom:1px solid var(--rule)}
.prose a:hover{border-bottom-color:var(--brass)}

/* FAQ */
.faq{border-top:1px solid var(--ink)}
.faq details{border-bottom:1px solid var(--rule)}
.faq summary{list-style:none;cursor:pointer;padding:18px 0;font-size:15.5px;font-weight:600;display:flex;justify-content:space-between;gap:18px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:'Cormorant Garamond',Georgia,serif;font-size:24px;color:var(--brass);line-height:1}
.faq details[open] summary::after{content:"−"}
.faq .ans{padding:0 0 20px;max-width:46em}
.faq .ans p{font-size:14px;color:var(--ink-soft);line-height:1.65;margin-bottom:10px}

/* team cards */
.tg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
.tg.cols4{grid-template-columns:repeat(4,1fr)}
.tcard{display:block;background:var(--bg);padding:26px 24px 28px;transition:.2s}
.tcard:hover{background:var(--bg-alt)}
.avatar{width:64px;height:64px;background:var(--bg-alt);border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',Georgia,serif;font-size:24px;font-weight:600;color:var(--accent)}
.tcard:hover .avatar{background:var(--bg)}
.avatar.lg{width:120px;height:120px;font-size:44px}
.tcard h3{font-size:21px;margin:16px 0 4px;line-height:1.15}
.tcard .role{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);font-weight:600}
.tcard p{font-size:13px;color:var(--ink-soft);margin-top:10px;line-height:1.5}

/* tags / jurisdiction chips */
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.tag{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--ink-soft);border:1px solid var(--rule);padding:6px 10px}

/* matters */
.matter{border:1px solid var(--rule);border-top:2px solid var(--ink);padding:28px 26px;background:var(--bg);margin-bottom:28px}
.matter h3{font-size:23px;margin:8px 0 16px;line-height:1.2}
.matter dl{display:grid;grid-template-columns:140px 1fr;gap:10px 24px}
.matter dt{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);font-weight:600;padding-top:3px}
.matter dd{font-size:14px;color:var(--ink-soft);line-height:1.6}

/* definition rows (profile facts, fee factors) */
.facts{border-top:1px solid var(--ink)}
.facts .row{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:16px 0;border-bottom:1px solid var(--rule)}
.facts .row .k{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);font-weight:600;padding-top:3px}
.facts .row .v{font-size:14.5px;color:var(--ink-soft);line-height:1.6}

/* forms */
.form{max-width:640px}
.field{margin-bottom:20px}
.field label{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--ink);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;padding:13px 14px;border:1px solid var(--rule);background:#FDFCF8;font-family:'Inter';font-size:14px;color:var(--ink);border-radius:0;-webkit-appearance:none;appearance:none}
.field select{background-image:linear-gradient(45deg,transparent 50%,var(--ink) 50%),linear-gradient(135deg,var(--ink) 50%,transparent 50%);background-position:calc(100% - 20px) 50%,calc(100% - 14px) 50%;background-size:6px 6px;background-repeat:no-repeat}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}
.form .hint{font-size:12px;color:var(--ink-soft);margin-top:14px}
.notice{border:1px solid var(--accent);background:var(--bg-alt);padding:16px 18px;font-size:14px;margin-bottom:28px}
.notice b{color:var(--accent)}

/* final CTA band */
.cta-final{background:var(--accent);color:var(--bg)}
.cta-final .wrap{padding:56px 28px;display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.cta-final h2{color:var(--bg);font-size:32px;line-height:1.15;max-width:18em}
.cta-final .eyebrow{color:var(--brass);margin-bottom:14px}
.cta-final .btn{border-color:var(--bg);color:var(--bg)}
.cta-final .btn:hover{background:var(--bg);color:var(--accent)}

/* stub / placeholder block (insights pending) */
.stub{border:1px dashed var(--rule);padding:34px 30px;text-align:center}
.stub p{font-size:14px;color:var(--ink-soft);max-width:40em;margin:0 auto 16px}

/* cookie notice */
.cookiebar{position:fixed;bottom:0;left:0;right:0;background:var(--ink);color:var(--bg);z-index:50;display:none}
.cookiebar.show{display:block}
.cookiebar .wrap{padding:14px 28px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;font-size:12.5px}
.cookiebar a{color:var(--brass)}
.cookiebar button{background:transparent;border:1px solid var(--bg);color:var(--bg);font-family:'Inter';font-size:12px;font-weight:600;padding:11px 18px;cursor:pointer;transition:.2s;min-height:40px}
.cookiebar button:hover{background:var(--bg);color:var(--ink)}

/* long unbreakable tokens (email, urls) must never force horizontal scroll */
footer a,.metric .n,.prose a,.crumbs{overflow-wrap:anywhere}

/* responsive */
@media(max-width:880px){
  .hero .wrap,.phero .wrap,.split,.pg,.pg.cols2,.ig,.tg,.tg.cols4{grid-template-columns:1fr}
  .hero h1{font-size:42px}
  .phero h1{font-size:38px}
  .metrics{border-left:0;border-top:1px solid var(--rule);padding-left:0;padding-top:20px;margin-top:8px}
  footer .wrap{grid-template-columns:1fr 1fr}
  nav .wrap{gap:18px;overflow-x:auto;font-size:12px;-webkit-overflow-scrolling:touch}
  .matter dl,.facts .row{grid-template-columns:1fr;gap:4px 0}
  .topbar .l{display:none}
  .topbar .wrap{justify-content:flex-end}
}
@media(max-width:560px){
  /* compact masthead so logo and CTA share one row without crowding */
  .mast .wrap{padding:20px 20px}
  .logo{font-size:23px}
  .logo small{font-size:8px;letter-spacing:.22em}
  .mast-cta{font-size:11px;padding:9px 13px;white-space:nowrap;flex-shrink:0}
  .wrap{padding:0 20px}
  .phero h1{font-size:32px}
  .sec-head h2,.cta-final h2,.split .a h2{font-size:26px}
  .sec{padding:48px 0}
  /* single-column footer: 2-up at 375 leaves links too narrow */
  footer .wrap{grid-template-columns:1fr;gap:28px;padding:40px 20px 24px}
  .fbar .wrap{flex-direction:column;gap:8px;align-items:flex-start}
  /* keep both topbar facts on one line, drop the response note if too tight */
  .topbar .r span{margin-left:0;display:block;text-align:right;line-height:1.5}
}
