/* Veil Consulting — Sharp Modern Editorial Consulting
   Palette: graphite ink + warm cream paper + oxblood accent.
   Type: Source Serif 4 display + Cormorant body + JetBrains Mono.
   The vibe: McKinsey blog meets a thoughtful Substack. Credible, not corporate. */

:root {
  --bg: #f5ecd9;
  --bg-elev: #ebe0c6;
  --bg-paper: #faf3e0;
  --bg-deep: #ddcfa4;
  --ink: #1d2027;
  --ink-soft: #353844;
  --ink-muted: #6b6d76;
  --ink-dim: #a9a6a0;
  --ink-paper: #2a2731;
  --oxblood: #7e2231;
  --oxblood-bright: #9a2b3a;
  --oxblood-deep: #5e1721;
  --rule: rgba(29, 32, 39, 0.12);
  --rule-strong: rgba(29, 32, 39, 0.25);
  --font-display: "Source Serif 4", "Source Serif Pro", "Georgia", serif;
  --font-body: "Cormorant Garamond", "Garamond", "Georgia", serif;
  --font-mono: "JetBrains Mono", "SF Mono", "Menlo", monospace;
  --maxw: 1100px;
  --pad-x: clamp(1.25rem, 5vw, 4rem);
  --transition: 280ms cubic-bezier(0.2, 0.7, 0.2, 1);
}

*, *::before, *::after { box-sizing: border-box; }
html { background: var(--bg); color: var(--ink); font-family: var(--font-body); font-size: 19px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
body {
  margin: 0; min-height: 100dvh; line-height: 1.7;
  background:
    radial-gradient(ellipse 60% 30% at 20% 0%, rgba(126, 34, 49, 0.04), transparent 70%),
    var(--bg);
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--oxblood); }
a:focus-visible { outline: 1px solid var(--oxblood); outline-offset: 4px; }

.mono { font-family: var(--font-mono); font-size: 0.84em; letter-spacing: 0.02em; }
.display { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.012em; line-height: 1.08; color: var(--ink); margin: 0; }
.display em { font-family: var(--font-display); font-style: italic; font-weight: 500; color: var(--oxblood); }
.eyebrow { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--oxblood-deep); margin: 0 0 1.5rem; }

/* ---- nav ---- */
.nav { position: sticky; top: 0; z-index: 50; display: flex; align-items: center; justify-content: space-between; padding: 1.1rem var(--pad-x); background: rgba(245, 236, 217, 0.92); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-bottom: 1px solid var(--rule); gap: 1.5rem; }
.nav__brand { display: inline-flex; align-items: center; gap: 0.75rem; color: var(--ink); }
.nav__mark { width: 28px; height: 28px; color: var(--oxblood); flex-shrink: 0; }
.nav__wordmark { font-family: var(--font-display); font-size: 1.1rem; font-weight: 600; letter-spacing: 0.04em; }
.nav__links { display: flex; gap: 1.75rem; list-style: none; margin: 0; padding: 0; font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.16em; text-transform: uppercase; align-items: center; }
.nav__links a { color: var(--ink-muted); font-weight: 500; }
.nav__links a:hover { color: var(--oxblood); }
.nav__links .nav__cta { color: var(--ink); padding: 0.55rem 0.95rem; border: 1px solid var(--ink); transition: all var(--transition); }
.nav__links .nav__cta:hover { background: var(--ink); color: var(--bg); border-color: var(--ink); }
@media (max-width: 760px) { .nav__links { gap: 0.9rem; font-size: 0.6rem; letter-spacing: 0.1em; } .nav__links .nav__cta { padding: 0.4rem 0.6rem; } .nav__wordmark { font-size: 0.9rem; } }

/* ---- hero ---- */
.hero { padding: 7rem var(--pad-x) 6rem; max-width: var(--maxw); margin: 0 auto; }
.hero__inner { max-width: 760px; }
.hero__title { font-size: clamp(3.2rem, 8.5vw, 6.5rem); margin: 0 0 1.75rem; font-weight: 700; }
.hero__lede { font-size: clamp(1.2rem, 1.8vw, 1.4rem); color: var(--ink-soft); margin: 0 0 2.25rem; line-height: 1.55; max-width: 60ch; }
.hero__lede em { color: var(--oxblood); font-style: italic; }
.hero__cta { display: flex; gap: 0.85rem; flex-wrap: wrap; margin-bottom: 3rem; }
.hero__credentials { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 1.25rem 2.5rem; padding-top: 2.25rem; border-top: 1px solid var(--rule); }
.hero__credentials li { color: var(--ink-muted); font-size: 0.78rem; }
.hero__credentials li span { color: var(--ink); font-weight: 500; }

/* ---- buttons ---- */
.btn { display: inline-flex; align-items: center; padding: 0.9rem 1.7rem; font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.16em; text-transform: uppercase; border: 1px solid transparent; background: transparent; font-weight: 500; transition: all var(--transition); cursor: pointer; }
.btn--primary { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.btn--primary:hover { background: var(--oxblood); border-color: var(--oxblood); transform: translateY(-1px); }
.btn--ghost { border-color: var(--ink); color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--bg); }

/* ---- sections ---- */
.section { padding: 7rem var(--pad-x); max-width: var(--maxw); margin: 0 auto; }
.section--paper { background: var(--bg-paper); max-width: none; margin: 0; padding: 7rem var(--pad-x); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.section--paper > * { max-width: var(--maxw); margin-left: auto; margin-right: auto; }
.section--ink { background: var(--ink); color: #d6d4c8; max-width: none; margin: 0; padding: 7rem var(--pad-x); border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); }
.section--ink > * { max-width: var(--maxw); margin-left: auto; margin-right: auto; }
.section--ink .eyebrow { color: #c89a4a; }
.section--ink .section__title { color: #f5ecd9; }
.section--ink .section__title em { color: #d8a86a; }
.section--ink .section__lede { color: #b8b4a6; }

.section__header { margin-bottom: 4.5rem; max-width: 800px; }
.section__title { font-size: clamp(2.2rem, 4.2vw, 3.2rem); margin: 0 0 1.5rem; }
.section__lede { color: var(--ink-soft); font-size: 1.1rem; line-height: 1.65; max-width: 60ch; margin: 0; font-style: italic; }
.section__lede em { color: var(--oxblood); }

/* ---- approach ---- */
.approach { max-width: 740px; }
.approach__lede { font-family: var(--font-display); font-size: clamp(1.4rem, 2.4vw, 1.7rem); font-weight: 500; color: var(--ink); line-height: 1.4; margin: 0 0 2rem; }
.approach__body { font-size: 1.08rem; color: var(--ink-soft); line-height: 1.75; margin: 0 0 2.5rem; }
.approach__body em { color: var(--oxblood); font-style: italic; }
.approach__motto { font-family: var(--font-display); font-style: italic; font-size: 1.25rem; color: var(--oxblood); margin: 0; padding-left: 1.5rem; border-left: 2px solid var(--oxblood); }
.approach__motto em { font-style: italic; }

/* ---- services ---- */
.services { display: grid; gap: 2.5rem; }
.service { padding: 3rem 0; border-top: 1px solid var(--rule); display: grid; grid-template-columns: 5.5rem 1fr; gap: 2.5rem; align-items: start; }
.service:first-child { border-top-color: var(--rule-strong); }
.service:last-child { border-bottom: 1px solid var(--rule-strong); }
@media (max-width: 760px) { .service { grid-template-columns: 1fr; gap: 1.25rem; padding: 2.25rem 0; } }
.service__num { color: var(--oxblood); font-size: 0.78rem; letter-spacing: 0.18em; margin: 0; padding-top: 0.6rem; }
.service__body { display: block; max-width: 68ch; }
.service__name { font-family: var(--font-display); font-size: clamp(1.5rem, 2.6vw, 1.95rem); font-weight: 600; margin: 0 0 1.25rem; color: var(--ink); line-height: 1.2; }
.service__desc { color: var(--ink-soft); font-size: 1.04rem; line-height: 1.75; margin: 0 0 2.25rem; }
.service__desc em { color: var(--oxblood); font-style: italic; }
.service__items-label { color: var(--ink-muted); font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase; margin: 0 0 1.25rem; padding-top: 1.5rem; border-top: 1px dashed var(--rule); }
.service__items { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.1rem 2rem; }
.service__items li { padding-left: 1.5rem; position: relative; color: var(--ink-soft); font-size: 1rem; line-height: 1.55; }
.service__items li::before { content: "—"; position: absolute; left: 0; color: var(--oxblood); top: 0; }

/* ---- principal ---- */
.principal { display: grid; grid-template-columns: 1.3fr 1fr; gap: 4rem; align-items: start; }
@media (max-width: 820px) { .principal { grid-template-columns: 1fr; gap: 2.5rem; } }
.principal__bio { display: grid; gap: 1.5rem; }
.principal__bio p { color: #b8b4a6; font-size: 1.08rem; line-height: 1.75; margin: 0; }
.principal__bio p em { color: #d8a86a; font-style: italic; }
.principal__bio p strong { color: #f5ecd9; font-weight: 600; }
.principal__chips { display: grid; gap: 2rem; padding: 1.75rem 1.85rem; background: rgba(255, 255, 255, 0.03); border: 1px solid rgba(200, 154, 74, 0.2); }
.chip-block__label { color: #c89a4a; font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; margin: 0 0 0.85rem; }
.chips { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 0.5rem; }
.chips li { font-family: var(--font-mono); font-size: 0.72rem; padding: 0.35rem 0.7rem; background: rgba(245, 236, 217, 0.06); border: 1px solid rgba(200, 154, 74, 0.25); color: #d6d4c8; }
.chips--accent li { color: #d8a86a; border-color: rgba(216, 168, 106, 0.4); }

/* ---- how-list ---- */
.how-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 3.5rem; max-width: 880px; }
.how-list li { display: grid; grid-template-columns: 4rem 1fr; gap: 2.5rem; align-items: start; }
@media (max-width: 700px) { .how-list li { grid-template-columns: 1fr; gap: 1rem; } }
.how__num { font-size: 0.78rem; letter-spacing: 0.16em; color: var(--oxblood); padding-top: 0.5rem; border-top: 2px solid var(--oxblood); margin: 0; }
.how__name { font-family: var(--font-display); font-size: clamp(1.5rem, 2.6vw, 1.85rem); font-weight: 600; margin: 0 0 1rem; color: var(--ink); }
.how__desc { color: var(--ink-soft); font-size: 1.04rem; line-height: 1.75; margin: 0; max-width: 60ch; }

/* ---- contact ---- */
.contact { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.5rem; margin-bottom: 3rem; }
.contact__card { padding: 1.85rem 1.75rem; background: var(--bg); border: 1px solid var(--rule); }
.contact__label { color: var(--oxblood); font-size: 0.74rem; letter-spacing: 0.06em; margin: 0 0 1rem; }
.contact__addr { font-size: 1rem; line-height: 1.7; color: var(--ink-soft); margin: 0; }
.contact__addr a { font-family: var(--font-mono); color: var(--ink); border-bottom: 1px solid var(--ink-muted); font-size: 0.92em; }
.contact__addr a:hover { color: var(--oxblood); border-bottom-color: var(--oxblood); }
.contact__note { display: block; margin-top: 0.65rem; color: var(--ink-muted); font-size: 0.78rem; }
.section--paper > .contact__epilogue { text-align: center; color: var(--ink-muted); font-style: italic; max-width: 70ch; margin: 0 auto; }

/* ---- footer ---- */
.footer { border-top: 1px solid var(--rule-strong); background: var(--bg-elev); padding: 3rem var(--pad-x) 2.5rem; }
.footer__inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1fr 1.4fr; gap: 2.5rem; align-items: start; }
@media (max-width: 720px) { .footer__inner { grid-template-columns: 1fr; gap: 1.5rem; } }
.footer__brand { display: flex; gap: 0.85rem; align-items: center; color: var(--ink); }
.footer__mark { width: 32px; height: 32px; color: var(--oxblood); flex-shrink: 0; }
.footer__name { font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; color: var(--ink); margin: 0 0 0.3rem; }
.footer__sub { color: var(--ink-muted); font-size: 0.78rem; margin: 0; }
.footer__meta { text-align: right; }
.footer__meta p { margin: 0 0 0.65rem; color: var(--ink-muted); font-size: 0.78rem; line-height: 1.6; }
.footer__meta a { color: var(--ink); border-bottom: 1px solid var(--ink-muted); }
.footer__meta a:hover { color: var(--oxblood); border-bottom-color: var(--oxblood); }
.footer__motto { color: var(--oxblood-deep) !important; font-style: italic; letter-spacing: 0.06em; }
@media (max-width: 720px) { .footer__meta { text-align: left; } }
