/* COUNSEL — law & professional-services starter.
   Serious editorial luxury: deep navy ink on warm ivory paper, bronze accent,
   Cormorant Garamond display / Public Sans body. Tokens feed the CMS block library. */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,500;0,600;0,700;1,500&family=Public+Sans:wght@400;500;600;700&display=swap');

:root {
  --t-bg: #faf7f0;
  --t-bg-alt: #f1ebdd;
  --t-fg: #16233a;
  --t-muted: #5b6377;
  --t-brand: #16233a;
  --t-brand-fg: #faf7f0;
  --t-accent: #a87f3d;
  --t-dark-bg: #101a2c;
  --t-dark-fg: #f3eee2;
  --t-border: #ddd4c0;
  --t-radius: 4px;
  --t-font-display: "Cormorant Garamond", "Times New Roman", serif;
  --t-font-body: "Public Sans", system-ui, sans-serif;
  --t-maxw: 1140px;
  --t-shadow: 0 2px 20px rgba(22, 35, 58, .08);
  --t-display-weight: 600;
  --t-display-tracking: -0.015em;
}

* { box-sizing: border-box; }
body { margin: 0; font-family: var(--t-font-body); color: var(--t-fg); background: var(--t-bg); }

/* ── header ── */
.site-header {
  position: sticky; top: 0; z-index: 40;
  background: rgba(250, 247, 240, .94);
  backdrop-filter: blur(8px);
  border-top: 3px solid var(--t-accent);
  border-bottom: 1px solid var(--t-border);
}
.site-header .bar {
  max-width: var(--t-maxw); margin: 0 auto; padding: 16px 28px;
  display: flex; align-items: center; gap: 30px;
}
.logo {
  font-family: var(--t-font-display); font-weight: 700; font-size: 26px;
  color: var(--t-fg); text-decoration: none; letter-spacing: .01em; line-height: 1;
}
.logo .amp { color: var(--t-accent); font-style: italic; font-weight: 500; }
.logo small {
  display: block; font-family: var(--t-font-body); font-weight: 600; font-size: 9px;
  letter-spacing: .32em; text-transform: uppercase; color: var(--t-accent); margin-top: 3px;
}
.site-nav { display: flex; gap: 28px; margin-left: auto; }
.site-nav a {
  color: var(--t-muted); text-decoration: none; font-weight: 600; font-size: 13px;
  letter-spacing: .14em; text-transform: uppercase; padding-bottom: 3px;
  border-bottom: 1px solid transparent; transition: color .15s, border-color .15s;
}
.site-nav a:hover { color: var(--t-fg); border-bottom-color: var(--t-accent); }
.header-cta {
  background: var(--t-brand); color: var(--t-brand-fg);
  font-weight: 600; font-size: 13px; letter-spacing: .08em; text-transform: uppercase;
  padding: 12px 24px; border-radius: var(--t-radius); text-decoration: none;
  border: 1px solid var(--t-brand); transition: background .15s, color .15s;
}
.header-cta:hover { background: var(--t-accent); border-color: var(--t-accent); color: #fff; }
@media (max-width: 780px) { .site-nav { display: none; } }

/* ── footer ── */
.site-footer { background: var(--t-dark-bg); color: var(--t-dark-fg); border-top: 3px solid var(--t-accent); }
.site-footer .inner {
  max-width: var(--t-maxw); margin: 0 auto; padding: 52px 28px;
  display: flex; flex-wrap: wrap; gap: 20px; align-items: baseline; justify-content: space-between;
}
.site-footer .foot-logo {
  font-family: var(--t-font-display); font-weight: 700; font-size: 24px; color: var(--t-dark-fg);
}
.site-footer .foot-logo .amp { color: var(--t-accent); font-style: italic; font-weight: 500; }
.site-footer p { margin: 0; color: #9aa3b8; font-size: 13.5px; line-height: 1.6; }
.site-footer a { color: var(--t-dark-fg); text-decoration: none; border-bottom: 1px solid var(--t-accent); }
.site-footer a:hover { color: #fff; }
