:root{
  --navy:#0e1f3a;
  --navy-2:#16294a;
  --navy-3:#0a1730;
  --gold:#c9a227;
  --gold2:#e3c86a;
  --paper:#f4f2ec;
  --paper-2:#efe9dd;
  --ink:#1c2430;
  --muted:#6a7280;
  --muted-light:#9aa3b2;
  --line:#e5ddcd;
  --line-dark:rgba(255,255,255,.12);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:120px}
body{font-family:'Jost',sans-serif;color:var(--ink);background:var(--paper);line-height:1.7;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:600;line-height:1.14;color:var(--navy)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 32px}

.eyebrow{display:inline-block;font-size:12.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
.btn{display:inline-block;padding:14px 30px;font-size:13.5px;letter-spacing:.08em;text-transform:uppercase;font-weight:500;transition:.25s;border:1px solid transparent;cursor:pointer;font-family:'Jost',sans-serif}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold2);transform:translateY(-2px)}
.btn-outline{border-color:rgba(255,255,255,.45);color:#fff;background:transparent}
.btn-outline:hover{background:#fff;color:var(--navy)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-2);transform:translateY(-2px)}
.btn-block{width:100%;text-align:center}

/* ---------- top bar ---------- */
.topbar{background:var(--navy-3);color:#c3ccdb;font-size:13px}
.topbar-in{display:flex;align-items:center;justify-content:space-between;padding:9px 0}
.topbar strong{color:var(--gold2);font-weight:500}
.topbar-right a{color:#c3ccdb}
.topbar-right a:hover{color:#fff}
.topbar .sep{margin:0 10px;opacity:.4}

/* ---------- nav ---------- */
#nav{position:sticky;top:0;z-index:50;background:var(--navy);transition:.3s}
#nav.scrolled{box-shadow:0 10px 34px rgba(10,23,48,.28)}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding:16px 0}
.brand img{height:42px}
.menu{display:flex;gap:34px}
.menu a{color:#dce3ef;font-size:14.5px;letter-spacing:.03em;position:relative;padding:4px 0}
.menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--gold);transition:.25s}
.menu a:hover{color:#fff}
.menu a:hover::after{width:100%}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:26px;height:2px;background:#fff;transition:.25s}
.mobile-menu{display:none}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:
  linear-gradient(rgba(10,23,48,.86),rgba(10,23,48,.92)),
  url('https://images.unsplash.com/photo-1589829545856-d10d557cf95f?q=80&w=1600&auto=format&fit=crop') center/cover;
}
.hero-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(700px 420px at 82% 20%,rgba(201,162,39,.16),transparent 65%)}
.hero-in{position:relative;z-index:2;max-width:820px;padding-top:112px;padding-bottom:112px}
.rule{width:64px;height:2px;background:var(--gold);margin-bottom:26px}
.hero h1{color:#fff;font-size:clamp(46px,6.6vw,84px);margin-bottom:24px;letter-spacing:.5px}
.hero h1 em{font-style:italic;color:var(--gold2);font-weight:500}
.hero p{font-size:19px;color:#cfd7e4;max-width:600px;margin-bottom:38px;font-weight:300}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:56px}
.hero-trust{display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.hero-trust b{font-family:'Cormorant Garamond',serif;color:var(--gold2);font-size:40px;line-height:1;display:block}
.hero-trust span{font-size:12.5px;letter-spacing:.13em;text-transform:uppercase;color:#9fb0c9}
.hero-trust .dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.28)}

/* ---------- section base ---------- */
.section{padding:104px 0}
.sec-head{text-align:center;max-width:660px;margin:0 auto 62px}
.sec-head h2{font-size:clamp(36px,4.4vw,54px);margin-bottom:14px}
.sec-head p{color:var(--muted)}

/* ---------- practice ---------- */
.practice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.pcard{background:var(--paper);padding:44px 36px;transition:.3s;position:relative}
.pcard:hover{background:#fff;box-shadow:0 24px 60px rgba(14,31,58,.12);z-index:2}
.pnum{font-family:'Cormorant Garamond',serif;font-size:15px;font-weight:700;color:var(--gold);letter-spacing:.1em;margin-bottom:16px}
.pcard h3{font-size:26px;margin-bottom:10px}
.pcard p{color:var(--muted);font-size:15px}
.pcard::before{content:"";position:absolute;left:0;top:0;width:0;height:3px;background:var(--gold);transition:.3s}
.pcard:hover::before{width:100%}

/* ---------- firm ---------- */
.firm{background:#fff}
.firm-in{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.firm-media{position:relative}
.firm-media img{width:100%;border-radius:3px;box-shadow:0 26px 64px rgba(14,31,58,.2)}
.firm-badge{position:absolute;right:-22px;bottom:-22px;background:var(--navy);color:#fff;padding:18px 24px;display:flex;align-items:center;gap:14px;border-radius:3px;box-shadow:0 16px 40px rgba(10,23,48,.3)}
.firm-badge img{width:44px}
.firm-badge b{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--gold2);display:block;line-height:1}
.firm-badge span{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:#9fb0c9}
.firm-copy h2{font-size:clamp(34px,4.2vw,50px);margin:6px 0 20px}
.firm-copy p{color:var(--muted);margin-bottom:8px}
.checks{list-style:none;margin:26px 0 32px}
.checks li{padding:12px 0;border-bottom:1px solid var(--line);display:flex;gap:14px;align-items:flex-start;font-size:15.5px}
.checks li::before{content:"§";color:var(--gold);font-family:'Cormorant Garamond',serif;font-size:24px;line-height:1;flex:none}

/* ---------- approach ---------- */
.approach{background:var(--paper-2)}
.steps{display:flex;align-items:flex-start;justify-content:center;gap:0;max-width:960px;margin:0 auto}
.step{flex:1;text-align:center;padding:0 22px}
.step-no{width:74px;height:74px;border:1.5px solid var(--gold);border-radius:50%;display:grid;place-items:center;margin:0 auto 22px;font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:700;color:var(--navy);background:#fff}
.step h3{font-size:26px;margin-bottom:10px}
.step p{color:var(--muted);font-size:15px}
.step-line{flex:0 0 60px;height:1.5px;background:var(--gold);opacity:.5;margin-top:37px}

/* ---------- counsel ---------- */
.counsel{background:var(--navy);color:#fff}
.counsel-in{display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:center}
.counsel h2{color:#fff;font-size:clamp(34px,4.2vw,52px);margin:6px 0 20px}
.counsel-copy>p{color:#c3ccdb;font-weight:300;margin-bottom:26px}
.counsel-meta{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:30px}
.counsel-meta b{color:var(--gold2);font-family:'Jost';font-weight:600;font-size:13px;letter-spacing:.06em;text-transform:uppercase;display:block;margin-bottom:4px}
.counsel-meta span{color:#c3ccdb;font-size:15px}
.quote{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:24px;line-height:1.5;color:#eef2f8;border-left:2px solid var(--gold);padding:6px 0 6px 26px}
.quote cite{display:block;font-style:normal;font-family:'Jost';font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold2);margin-top:16px}
.counsel-media img{width:100%;border-radius:3px;filter:grayscale(.15);border:1px solid var(--line-dark);box-shadow:0 26px 64px rgba(0,0,0,.35)}

/* ---------- contact ---------- */
.contact{background:var(--navy-3);color:#fff}
.contact-in{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:start}
.contact h2{color:#fff;font-size:clamp(34px,4.2vw,52px);margin:6px 0 18px}
.contact-copy>p{color:#c3ccdb;font-weight:300;margin-bottom:34px;max-width:440px}
.contact-list{list-style:none;display:grid;gap:22px}
.contact-list li{display:flex;gap:16px;align-items:center}
.ci{flex:none;width:48px;height:48px;border:1px solid var(--line-dark);border-radius:50%;display:grid;place-items:center;color:var(--gold2);font-size:19px}
.contact-list b{display:block;font-family:'Jost';font-weight:600;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:#9fb0c9;margin-bottom:2px}
.contact-list a,.contact-list div>span{color:#eef2f8;font-size:17px}
.contact-list a:hover{color:var(--gold2)}

.contact-form{background:#fff;border-radius:4px;padding:38px;box-shadow:0 30px 70px rgba(0,0,0,.3)}
.contact-form label{display:block;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:18px}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;margin-top:8px;padding:13px 15px;border:1px solid var(--line);border-radius:3px;font-family:'Jost',sans-serif;font-size:15px;color:var(--ink);background:var(--paper);text-transform:none;letter-spacing:0}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:var(--gold);background:#fff}
.contact-form .two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-form textarea{resize:vertical}
.fineprint{font-size:11.5px;color:var(--muted-light);letter-spacing:0;text-transform:none;margin-top:14px;line-height:1.5;font-weight:400}
.sent{display:none;background:#eaf6ee;border:1px solid #bfe3ca;color:#1c6b39;padding:12px 16px;border-radius:3px;font-size:14px;letter-spacing:0;text-transform:none;margin-bottom:20px}

/* ---------- footer ---------- */
footer{background:var(--navy);color:#9fb0c9;padding:66px 0 30px;font-size:14.5px}
.foot-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1.2fr;gap:44px;padding-bottom:46px;border-bottom:1px solid var(--line-dark)}
.foot-brand img{height:44px;margin-bottom:18px}
.foot-brand p{max-width:320px;color:#9fb0c9}
.foot-col h4{color:#fff;font-family:'Jost';font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:16px;font-weight:600}
.foot-col a{display:block;padding:6px 0;color:#9fb0c9}
.foot-col a:hover{color:var(--gold2)}
.foot-bottom{display:flex;justify-content:space-between;gap:30px;padding-top:26px;font-size:12.5px;color:var(--muted-light)}
.foot-bottom span:last-child{max-width:560px;text-align:right}

/* ---------- back to top ---------- */
.totop{position:fixed;right:26px;bottom:26px;width:46px;height:46px;background:var(--gold);color:var(--navy);border-radius:50%;display:grid;place-items:center;font-size:20px;box-shadow:0 10px 26px rgba(14,31,58,.28);z-index:40;transition:.25s}
.totop:hover{background:var(--gold2);transform:translateY(-3px)}

/* ---------- responsive ---------- */
@media(max-width:940px){
  .practice-grid{grid-template-columns:1fr 1fr}
  .firm-in,.counsel-in,.contact-in{grid-template-columns:1fr;gap:44px}
  .counsel-media{order:-1}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-bottom{flex-direction:column;gap:10px}
  .foot-bottom span:last-child{text-align:left;max-width:none}
}
@media(max-width:720px){
  .wrap{padding:0 22px}
  .menu,.btn-gold.book,.nav-in>.btn-gold{display:none}
  .burger{display:flex}
  .mobile-menu{display:flex;flex-direction:column;background:var(--navy-2);max-height:0;overflow:hidden;transition:max-height .3s}
  body.nav-open .mobile-menu{max-height:340px}
  .mobile-menu a{color:#dce3ef;padding:15px 22px;border-top:1px solid var(--line-dark)}
  .topbar-in{flex-direction:column;gap:4px;text-align:center;font-size:12px}
  .practice-grid{grid-template-columns:1fr}
  .steps{flex-direction:column;gap:36px}
  .step-line{display:none}
  .firm-badge{right:16px;bottom:-18px}
  .contact-form{padding:26px 20px}
  .contact-form .two{grid-template-columns:1fr}
  .section{padding:64px 0}
  .sec-head{margin-bottom:44px}

  /* full-screen hero on phones */
  .hero{display:flex;align-items:center;min-height:100vh;min-height:100svh}
  .hero-in{padding-top:72px;padding-bottom:64px;width:100%}
  .hero h1{font-size:clamp(40px,11.5vw,54px);margin-bottom:20px}
  .hero p{font-size:16.5px;margin-bottom:30px}
  .hero-actions{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:44px;max-width:340px}
  .hero-actions .btn{text-align:center}
  .hero-trust{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
  .hero-trust .dot{display:none}
  .hero-trust b{font-size:30px}
  .hero-trust span{font-size:10.5px;letter-spacing:.1em}

  .pcard{padding:32px 26px}
  .firm-copy h2,.counsel h2,.contact h2{font-size:clamp(30px,8.5vw,40px)}
  .quote{font-size:20px;padding-left:20px}
  .counsel-meta{grid-template-columns:1fr;gap:14px}
  .foot-grid{grid-template-columns:1fr;gap:30px}
  .totop{right:16px;bottom:16px;width:42px;height:42px}
}
