@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Lora:wght@600;700&display=swap");

:root {
  --navy:#0d1b2a;
  --charcoal:#171d24;
  --gold:#b88a32;
  --gold-soft:#efe2c4;
  --gray:#f4f5f2;
  --white:#ffffff;
  --muted:#53606d;
  --line:#d7dce2;
  --panel:#f7f7f4;
  --paper:#fbfaf5;
  --ink-soft:#26323f;
}

* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif; color:var(--charcoal); background:var(--paper); }
body.nav-open { overflow:hidden; }
a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }
.wrap { width:min(1160px, calc(100% - 40px)); margin:0 auto; }
.skip { position:absolute; left:-999px; top:12px; background:var(--navy); color:white; padding:12px; z-index:100; }
.skip:focus { left:12px; }

.site-header { position:sticky; top:0; z-index:50; background:rgba(251,251,248,.95); border-bottom:1px solid var(--line); backdrop-filter:blur(14px); }
.nav { height:112px; display:flex; align-items:center; justify-content:space-between; gap:22px; }
.brand { display:flex; align-items:center; gap:11px; min-width:max-content; }
.brand-logo { width:auto; height:54px; display:block; object-fit:contain; flex:0 0 auto; }
.brand-icon { width:80px; height:80px; display:block; object-fit:contain; object-position:center; flex:0 0 auto; }
.brand-mark { width:54px; height:54px; display:grid; place-items:center; border:1px solid rgba(200,164,90,.55); color:var(--gold); background:var(--navy); font-family:Lora,Georgia,serif; font-size:2.35rem; line-height:1; border-radius:4px; }
.brand-name { display:grid; justify-items:start; text-align:left; line-height:1; transform:translateY(1px); }
.brand-name strong { font-family:Lora,Georgia,serif; font-size:1.64rem; letter-spacing:0; color:var(--navy); line-height:.96; }
.brand-name span { margin-top:6px; font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif; font-size:.72rem; font-weight:900; text-transform:uppercase; letter-spacing:0; color:#3f4a56; }
.brand-name em { margin-top:5px; font-style:normal; font-size:.84rem; font-weight:700; color:#6b5424; letter-spacing:0; }
.nav-links { display:flex; align-items:center; gap:24px; font-size:1rem; font-weight:700; color:#3f4854; }
.nav-links a:hover, .nav-links a[aria-current="page"] { color:var(--navy); }
.nav-toggle { display:none; width:44px; height:44px; border:1px solid var(--line); background:white; border-radius:6px; }
.nav-toggle span { display:block; width:18px; height:2px; margin:4px auto; background:var(--navy); }

.btn { display:inline-flex; align-items:center; justify-content:center; gap:10px; min-height:48px; padding:14px 20px; border:1px solid var(--navy); border-radius:4px; font-weight:800; line-height:1; transition:transform .18s ease, box-shadow .18s ease, background .18s ease; cursor:pointer; }
.btn:hover { transform:translateY(-2px); box-shadow:0 14px 30px rgba(13,27,42,.14); }
.btn-primary { background:var(--navy); color:white; }
.btn-secondary { background:white; color:var(--navy); }
.btn-gold { background:var(--gold); border-color:var(--gold); color:#16120a; }

.hero { padding:42px 0 40px; background:linear-gradient(180deg,#fbfaf5 0%,#f0eee7 100%); }
.hero-brand { display:flex; flex-direction:column; align-items:center; justify-content:center; margin:0 auto 22px; }
.hero-grid { display:grid; grid-template-columns:minmax(0,.95fr) minmax(430px,1.05fr); gap:56px; align-items:center; }
.eyebrow { font-size:.84rem; font-weight:900; letter-spacing:0; color:var(--gold); text-transform:uppercase; margin-bottom:18px; }
.hero-wordmark { width:min(520px, 78vw); height:auto; display:block; }
.affiliation { display:flex; align-items:baseline; justify-content:center; flex-wrap:wrap; gap:5px; margin-top:-10px; color:#485360; font-size:.95rem; font-weight:600; }
.affiliation strong { color:var(--navy); font-weight:900; }
.affiliation span { margin-left:8px; color:#765b25; font-size:.82rem; font-weight:800; text-decoration:underline; text-underline-offset:3px; }
.firm-link { display:inline-block; margin:0 0 12px; color:#765b25; font-size:.78rem; font-weight:800; text-decoration:underline; text-underline-offset:3px; }
h1, h2, h3 { color:var(--navy); margin:0; }
h1 { font-family:Lora,Georgia,serif; font-size:clamp(2.8rem,5.2vw,5rem); line-height:1.08; letter-spacing:0; font-weight:700; }
h2 { font-family:Lora,Georgia,serif; font-size:clamp(2.1rem,4vw,3.6rem); line-height:1.08; letter-spacing:0; }
h3 { font-size:1.1rem; }
p { font-size:1.1rem; line-height:1.76; color:#384250; }
.lead { font-size:1.22rem; max-width:660px; color:#2f3946; line-height:1.78; }
.hero-actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:28px; }
.hero-note { margin-top:22px; color:#45505d; font-size:1.04rem; }
.personal-panel { position:relative; min-height:580px; border:1px solid rgba(13,27,42,.16); border-radius:10px; background:#fffdf7; box-shadow:0 30px 80px rgba(13,27,42,.14); overflow:hidden; padding:24px; display:grid; grid-template-rows:1fr auto; gap:18px; }
.personal-panel:before { content:""; position:absolute; inset:0; z-index:0; background:linear-gradient(135deg,rgba(184,138,50,.14),transparent 38%), linear-gradient(180deg,transparent 0%,rgba(13,27,42,.04) 100%); pointer-events:none; }
.portrait-card { position:relative; z-index:1; display:grid; grid-template-columns:54% 46%; border:1px solid rgba(13,27,42,.14); background:#f4f0e6; border-radius:8px; overflow:hidden; }
.founder-photo { width:100%; height:100%; min-height:390px; object-fit:cover; object-position:center center; background:#d9dadd; }
.portrait-copy { min-width:0; padding:38px 24px; display:flex; flex-direction:column; justify-content:flex-start; }
.portrait-copy small { display:block; color:var(--gold); font-weight:900; letter-spacing:.13em; text-transform:uppercase; margin-bottom:12px; }
.portrait-copy strong { display:block; font-family:Lora,Georgia,serif; color:var(--navy); font-size:clamp(2.25rem,3.4vw,2.85rem); line-height:.98; margin-bottom:12px; }
.portrait-copy .title { margin:0 0 22px; color:var(--navy); font-weight:900; letter-spacing:0; text-transform:uppercase; font-size:.9rem; }
.portrait-copy p { margin:0; }
.portrait-copy .contact-stack { margin-top:8px; }
.portrait-copy .contact-stack a { display:block; margin:5px 0; color:var(--navy); font-weight:800; font-size:.86rem; overflow-wrap:anywhere; line-height:1.4; }
.portrait-copy .contact-stack a:hover { color:var(--gold); }
.note-card { position:relative; z-index:1; padding:18px 22px; background:var(--navy); color:white; border-radius:8px; box-shadow:0 18px 45px rgba(13,27,42,.18); }
.note-card p { color:#e7edf4; margin:0; font-size:1.08rem; }
.note-card .signature { margin-top:12px; color:var(--gold-soft); font-family:Lora,Georgia,serif; font-size:1.35rem; }
.text-link { display:inline-flex; margin-top:8px; color:var(--navy); font-weight:900; text-decoration:underline; text-decoration-color:var(--gold); text-underline-offset:5px; }
.affiliation-card { border-top:4px solid var(--gold); }

.strip { background:var(--navy); color:white; padding:18px 0; }
.strip .wrap { display:flex; flex-wrap:wrap; gap:18px 34px; justify-content:center; font-weight:800; letter-spacing:0; }
section { padding:82px 0; }
.personal-section { padding:70px 0; background:#fffdf7; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.personal-note { display:grid; grid-template-columns:.75fr 1.25fr; gap:38px; align-items:start; }
.personal-note .label { color:var(--gold); font-weight:900; text-transform:uppercase; letter-spacing:0; font-size:.78rem; }
.personal-note blockquote { margin:0; font-family:Lora,Georgia,serif; font-size:clamp(1.8rem,3vw,3rem); line-height:1.18; color:var(--navy); }
.service-story { display:grid; grid-template-columns:.86fr 1.14fr; gap:34px; align-items:start; }
.service-menu { display:grid; gap:12px; }
.service-line { display:grid; grid-template-columns:auto 1fr; gap:16px; align-items:start; padding:18px 0; border-bottom:1px solid var(--line); }
.service-line span { font-weight:900; color:var(--gold); }
.service-line h3 { margin-bottom:6px; }
.service-line p { margin:0; }
.section-head { display:flex; justify-content:space-between; gap:24px; align-items:end; margin-bottom:34px; }
.section-head p { max-width:520px; margin:0; }
.grid-3 { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; }
.grid-2 { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; }
.card { border:1px solid var(--line); background:#fffffd; border-radius:8px; padding:26px; transition:transform .18s ease, box-shadow .18s ease; }
.card:hover { transform:translateY(-3px); box-shadow:0 18px 46px rgba(13,27,42,.09); }
.card .number { color:var(--gold); font-weight:900; margin-bottom:14px; }
.muted-section { background:#f1f0ea; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.process { counter-reset:step; }
.process .card { position:relative; padding-top:34px; }
.process .card:before { counter-increment:step; content:counter(step); position:absolute; top:-14px; left:24px; width:34px; height:34px; display:grid; place-items:center; background:var(--gold); color:#15110b; border-radius:50%; font-weight:900; }
.audience { display:flex; flex-wrap:wrap; gap:10px; }
.pill { padding:10px 14px; border:1px solid var(--line); background:#fffffd; border-radius:999px; font-weight:800; color:#2f3946; font-size:1.04rem; }
.disclaimer { padding:24px; border-left:4px solid var(--gold); background:#fffaf0; color:#564626; font-size:1rem; line-height:1.72; }
.cta-band { background:var(--navy); color:white; }
.cta-band h2, .cta-band p { color:white; }
.footer { background:#0f1720; color:#eef3f8; padding:48px 0; }
.footer-grid { display:grid; grid-template-columns:1.2fr .8fr .8fr; gap:26px; }
.footer p, .footer a { color:#eef3f8; font-size:1rem; }
.footer a { display:block; margin:8px 0; }
.footer .contact-stack a, .contact-stack a { display:block; margin:2px 0; }
.footer h3, .footer strong { color:#ffffff; }
.footer .brand-name strong { color:#ffffff; }
.footer .brand-name span { color:#c9d3df; }
.footer .brand-mark { background:#172435; border-color:rgba(200,164,90,.8); }
.footer-logo { width:min(390px, 100%); height:auto; display:block; object-fit:contain; background:#fffdf7; border-radius:6px; padding:10px; }
.footer .firm-note { margin-top:8px; color:#cbd5df; font-size:.92rem; }
.footer .firm-note a { display:inline; color:#f0d89f; font-weight:800; text-decoration:underline; text-underline-offset:3px; }
.footer .brand-logo { width:auto; height:118px; background:#fffdf7; border-radius:6px; padding:10px; }

.page-hero { padding:72px 0 54px; background:linear-gradient(180deg,#fbfaf5,#f0eee7); border-bottom:1px solid var(--line); }
.service-detail { display:grid; grid-template-columns:1fr 1.6fr; gap:24px; align-items:start; padding:26px 0; border-bottom:1px solid var(--line); }
.detail-list { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.mini-card { background:var(--panel); border:1px solid var(--line); border-radius:8px; padding:16px; }
.form { display:grid; gap:14px; }
label { display:grid; gap:7px; font-weight:800; color:var(--navy); }
input, select, textarea { width:100%; border:1px solid var(--line); border-radius:6px; padding:13px 14px; font:inherit; color:var(--charcoal); background:white; }
textarea { min-height:150px; resize:vertical; }
.form-message { display:none; padding:14px 16px; background:#edf8ef; border:1px solid #b8dfc0; border-radius:6px; color:#24562f; }
.form-message.visible { display:block; }

[data-animate] { opacity:1; transform:none; }

@media (max-width:900px) {
  .nav-toggle { display:block; }
  .nav-links { position:fixed; inset:112px 0 auto 0; display:none; flex-direction:column; align-items:stretch; gap:0; padding:18px 20px 28px; background:white; border-bottom:1px solid var(--line); box-shadow:0 22px 50px rgba(13,27,42,.12); }
  .nav-links.open { display:flex; }
  .nav-links a { padding:14px 0; }
  .nav-links .btn { margin-top:10px; }
  .hero-grid, .grid-3, .grid-2, .footer-grid, .service-detail, .detail-list, .personal-note, .service-story { grid-template-columns:1fr; }
  .section-head { display:block; }
  .personal-panel { min-height:auto; }
  .portrait-card { grid-template-columns:1fr; height:auto; }
  .founder-photo { min-height:430px; object-fit:cover; object-position:center center; }
}

@media (max-width:560px) {
  .brand { gap:7px; }
  .brand-icon { width:62px; height:62px; }
  .brand-name strong { font-size:1.36rem; }
  .brand-name span { margin-top:5px; font-size:.62rem; letter-spacing:0; }
  .brand-name em { margin-top:4px; font-size:.72rem; }
  .hero-wordmark { width:min(430px, 92vw); }
  .affiliation { margin-top:-5px; padding:0 12px; font-size:.84rem; }
  .affiliation span { width:100%; margin:2px 0 0; text-align:center; }
  .portrait-copy .title { max-width:16rem; }
}

@media (max-width:560px) {
  .wrap { width:min(100% - 28px,1160px); }
  .nav { height:86px; }
  .brand { gap:7px; }
  .brand-logo { height:44px; }
  .brand-icon { width:54px; height:54px; }
  .brand-mark { width:44px; height:44px; font-size:1.9rem; }
  .brand-name strong { font-size:1.18rem; }
  .brand-name span, .brand-name em { display:none; }
  .hero { padding-top:58px; }
  h1 { font-size:3.05rem; }
  .hero-actions .btn, .btn { width:100%; }
  .personal-panel { padding:18px; }
  .portrait-card { display:flex; flex-direction:column; }
  .portrait-copy { order:1; padding:22px 20px; text-align:center; align-items:center; background:#f4f0e6; }
  .portrait-copy strong { font-size:2.25rem; }
  .portrait-copy .contact-stack a { font-size:.86rem; }
  .founder-photo { order:2; width:100%; min-height:0; height:auto; aspect-ratio:1 / 1.08; object-fit:cover; object-position:center 20%; }
}
