:root {
  --ink: #07111f;
  --ink-2: #0b1729;
  --ink-3: #10233e;
  --paper: #f8f4e8;
  --paper-2: #fffaf0;
  --muted: #9aa8b4;
  --muted-2: #6f7b84;
  --gold: #d6b15e;
  --gold-2: #f1d68d;
  --greenstone: #9eb7aa;
  --line: rgba(214, 177, 94, .22);
  --line-soft: rgba(248, 244, 232, .12);
  --shadow: 0 24px 80px rgba(0, 0, 0, .32);
  --radius-xl: 28px;
  --radius-lg: 20px;
  --radius-md: 14px;
  --max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--paper);
  line-height: 1.6;
  text-rendering: optimizeLegibility;
}
body.no-scroll { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img, svg { max-width: 100%; display: block; }
button, input, textarea, select { font: inherit; }
::selection { background: rgba(214, 177, 94, .35); }

.skip-link {
  position: absolute;
  left: -999px;
  top: 12px;
  z-index: 999;
  background: var(--paper);
  color: var(--ink);
  padding: 10px 14px;
  border-radius: 10px;
}
.skip-link:focus { left: 12px; }

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: 18px 0;
  transition: background .25s ease, border-color .25s ease, padding .25s ease, backdrop-filter .25s ease;
  border-bottom: 1px solid transparent;
}
.site-header.is-scrolled {
  padding: 10px 0;
  background: rgba(7, 17, 31, .86);
  backdrop-filter: blur(18px);
  border-bottom-color: rgba(248, 244, 232, .12);
}
.header-inner {
  width: min(calc(100% - 40px), var(--max));
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.logo-link { width: 254px; flex: 0 0 auto; }
.nav-links {
  display: flex;
  align-items: center;
  gap: 26px;
  color: rgba(248, 244, 232, .82);
  font-size: 14px;
  letter-spacing: .01em;
}
.nav-links a { position: relative; }
.nav-links a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -8px;
  height: 1px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .22s ease;
}
.nav-links a:hover::after, .nav-links a:focus-visible::after { transform: scaleX(1); }
.header-cta {
  color: var(--ink);
  background: var(--gold-2);
  border: 1px solid rgba(241, 214, 141, .4);
  padding: 11px 16px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  box-shadow: 0 10px 28px rgba(214,177,94,.18);
}
.menu-button {
  display: none;
  color: var(--paper);
  background: rgba(248, 244, 232, .08);
  border: 1px solid rgba(248,244,232,.18);
  border-radius: 999px;
  padding: 10px 13px;
}

.hero {
  position: relative;
  min-height: 100vh;
  color: var(--paper);
  background:
    radial-gradient(circle at 70% 20%, rgba(214,177,94,.20), transparent 34%),
    radial-gradient(circle at 22% 60%, rgba(158,183,170,.20), transparent 34%),
    linear-gradient(130deg, #06111f 0%, #0b1729 52%, #06111f 100%);
  overflow: hidden;
  padding: 150px 0 80px;
}
.hero::before {
  content: "";
  position: absolute;
  inset: -80px -120px 0 auto;
  width: 820px;
  background: url("contour.svg") center / contain no-repeat;
  opacity: .78;
  pointer-events: none;
}
.hero::after {
  content: "";
  position: absolute;
  left: -12%;
  bottom: -32%;
  width: 56vw;
  height: 56vw;
  background: radial-gradient(circle, rgba(214,177,94,.12), transparent 58%);
  pointer-events: none;
}
.hero-inner {
  position: relative;
  z-index: 2;
  width: min(calc(100% - 40px), var(--max));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(330px, .72fr);
  align-items: end;
  gap: 70px;
}
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--gold-2);
  font-size: 12px;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-weight: 700;
}
.eyebrow::before {
  content: "";
  width: 36px;
  height: 1px;
  background: var(--gold);
}
h1, h2, h3, .display {
  font-family: Georgia, "Times New Roman", serif;
  line-height: .98;
  letter-spacing: -.055em;
  font-weight: 500;
}
h1 {
  margin: 24px 0 24px;
  max-width: 850px;
  font-size: clamp(54px, 8vw, 108px);
}
.hero-lede {
  max-width: 660px;
  color: rgba(248,244,232,.78);
  font-size: clamp(18px, 2vw, 22px);
  line-height: 1.55;
  margin: 0 0 34px;
}
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: 999px;
  min-height: 48px;
  padding: 13px 19px;
  font-weight: 750;
  transition: transform .22s ease, background .22s ease, border-color .22s ease, color .22s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: var(--gold-2); color: var(--ink); border: 1px solid rgba(241,214,141,.42); }
.btn-secondary { color: var(--paper); border: 1px solid rgba(248,244,232,.22); background: rgba(248,244,232,.06); }
.btn-dark { background: var(--ink); color: var(--paper); border: 1px solid rgba(7,17,31,.1); }
.btn-outline { border: 1px solid rgba(7,17,31,.18); color: var(--ink); }

.hero-panel {
  position: relative;
  border: 1px solid rgba(248,244,232,.14);
  background: linear-gradient(150deg, rgba(248,244,232,.10), rgba(248,244,232,.035));
  border-radius: var(--radius-xl);
  padding: 28px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(20px);
  overflow: hidden;
}
.hero-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 75% 12%, rgba(214,177,94,.22), transparent 34%);
  pointer-events: none;
}
.panel-top { position: relative; display: flex; justify-content: space-between; gap: 20px; align-items: flex-start; }
.panel-kicker { color: var(--gold-2); font-size: 12px; text-transform: uppercase; letter-spacing: .18em; font-weight: 800; }
.panel-title { position: relative; margin: 18px 0 24px; font-size: 34px; max-width: 380px; color: var(--paper); }
.panel-list { position: relative; display: grid; gap: 12px; }
.panel-item {
  padding: 15px 0;
  border-top: 1px solid rgba(248,244,232,.14);
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 14px;
}
.panel-number { color: var(--gold-2); font-family: Georgia, serif; font-size: 22px; }
.panel-item strong { display: block; color: var(--paper); margin-bottom: 4px; }
.panel-item span { color: rgba(248,244,232,.66); font-size: 14px; }
.panel-note {
  position: relative;
  margin: 22px 0 0;
  padding: 16px;
  border-radius: var(--radius-md);
  background: rgba(7,17,31,.42);
  color: rgba(248,244,232,.72);
  border: 1px solid rgba(248,244,232,.12);
  font-size: 13px;
}

.section { padding: 110px 0; }
.section.compact { padding: 70px 0; }
.container { width: min(calc(100% - 40px), var(--max)); margin: 0 auto; }
.section-header {
  display: grid;
  grid-template-columns: 160px minmax(0, 1fr) minmax(240px, .42fr);
  gap: 34px;
  align-items: start;
  margin-bottom: 52px;
}
.section-number { color: var(--gold); font-family: Georgia, serif; font-size: 32px; line-height: 1; }
.section-header h2 { font-size: clamp(38px, 5vw, 70px); margin: 0; }
.section-header p { margin: 8px 0 0; color: var(--muted-2); font-size: 17px; }
.dark .section-header p, .dark p { color: rgba(248,244,232,.70); }
.dark { color: var(--paper); background: var(--ink); }
.dark-soft {
  color: var(--paper);
  background:
    radial-gradient(circle at 78% 0%, rgba(214,177,94,.16), transparent 34%),
    linear-gradient(150deg, #07111f, #0b1729 70%, #091522);
}

.intro-grid {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(330px, .58fr);
  gap: 52px;
  align-items: center;
}
.intro-copy .display { font-size: clamp(42px, 5.4vw, 76px); margin: 0 0 26px; }
.intro-copy p { font-size: 19px; color: #47525c; max-width: 740px; }
.intro-card {
  border: 1px solid rgba(7,17,31,.11);
  border-radius: var(--radius-xl);
  padding: 34px;
  background: var(--paper-2);
  box-shadow: 0 20px 60px rgba(7,17,31,.08);
}
.intro-card h3 { margin: 0 0 20px; font-size: 32px; }
.check-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 14px; }
.check-list li { display: grid; grid-template-columns: 22px 1fr; gap: 12px; color: #314050; }
.check-list li::before {
  content: "";
  width: 9px;
  height: 9px;
  margin-top: 8px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 0 5px rgba(214,177,94,.14);
}

.card-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.focus-card, .service-card, .principle-card {
  position: relative;
  border: 1px solid rgba(7,17,31,.11);
  background: rgba(255,250,240,.78);
  border-radius: var(--radius-lg);
  padding: 28px;
  min-height: 250px;
  overflow: hidden;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.focus-card:hover, .service-card:hover, .principle-card:hover { transform: translateY(-4px); box-shadow: 0 22px 64px rgba(7,17,31,.10); border-color: rgba(214,177,94,.45); }
.focus-card::after, .service-card::after {
  content: "";
  position: absolute;
  right: -30px;
  top: -30px;
  width: 120px;
  height: 120px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(214,177,94,.14), transparent 66%);
}
.card-label { color: var(--gold); font-family: Georgia, serif; font-size: 28px; }
.focus-card h3, .service-card h3, .principle-card h3 { margin: 20px 0 12px; font-size: 30px; letter-spacing: -.035em; }
.focus-card p, .service-card p, .principle-card p { color: #50606d; margin: 0; }

.split-band {
  border-radius: 36px;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .68fr);
  background: var(--ink);
  color: var(--paper);
  box-shadow: var(--shadow);
}
.split-copy { padding: clamp(34px, 5vw, 62px); }
.split-copy .eyebrow { margin-bottom: 18px; }
.split-copy h2 { margin: 0 0 22px; font-size: clamp(42px, 5vw, 76px); }
.split-copy p { color: rgba(248,244,232,.72); max-width: 660px; font-size: 18px; }
.split-visual {
  position: relative;
  min-height: 440px;
  background:
    linear-gradient(rgba(7,17,31,.12), rgba(7,17,31,.12)),
    url("contour.svg") center / 130% no-repeat,
    radial-gradient(circle at 70% 26%, rgba(214,177,94,.24), transparent 30%),
    linear-gradient(140deg, #0d2138, #07111f);
}
.thesis-list { margin-top: 32px; display: grid; gap: 15px; }
.thesis-row { display: grid; grid-template-columns: 125px 1fr; gap: 18px; padding-top: 15px; border-top: 1px solid rgba(248,244,232,.14); }
.thesis-row span:first-child { color: var(--gold-2); font-size: 13px; letter-spacing: .12em; text-transform: uppercase; font-weight: 800; }
.thesis-row span:last-child { color: rgba(248,244,232,.78); }

.process {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  border: 1px solid rgba(7,17,31,.12);
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--paper-2);
}
.process-step { padding: 34px 26px; min-height: 310px; border-right: 1px solid rgba(7,17,31,.10); }
.process-step:last-child { border-right: 0; }
.process-step .step-number { color: var(--gold); font-family: Georgia, serif; font-size: 40px; }
.process-step h3 { margin: 54px 0 14px; font-size: 30px; }
.process-step p { color: #50606d; margin: 0; }

.pathway-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.pathway {
  border: 1px solid rgba(248,244,232,.14);
  border-radius: var(--radius-xl);
  padding: clamp(30px, 4vw, 48px);
  background: rgba(248,244,232,.055);
}
.pathway h3 { font-size: clamp(34px, 4vw, 56px); margin: 0 0 18px; color: var(--paper); }
.pathway p { margin-bottom: 28px; }
.pathway ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 12px; color: rgba(248,244,232,.78); }
.pathway li { padding-top: 12px; border-top: 1px solid rgba(248,244,232,.12); }

.criteria {
  display: grid;
  grid-template-columns: minmax(320px, .55fr) minmax(0, 1fr);
  gap: 48px;
  align-items: start;
}
.criteria-intro h2 { margin: 0 0 18px; font-size: clamp(42px, 5vw, 72px); }
.criteria-intro p { color: #50606d; font-size: 18px; }
.criteria-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.criteria-item {
  border: 1px solid rgba(7,17,31,.10);
  background: var(--paper-2);
  border-radius: var(--radius-md);
  padding: 20px;
}
.criteria-item strong { display: block; margin-bottom: 8px; }
.criteria-item span { color: #596977; font-size: 14px; }

.principle-card { background: rgba(248,244,232,.06); border-color: rgba(248,244,232,.12); min-height: 230px; }
.principle-card h3 { color: var(--paper); }
.principle-card p { color: rgba(248,244,232,.68); }
.principle-card .card-label { color: var(--gold-2); }

.contact-shell {
  display: grid;
  grid-template-columns: minmax(0, .72fr) minmax(380px, .86fr);
  gap: 40px;
  align-items: start;
  padding: clamp(32px, 5vw, 58px);
  border-radius: 36px;
  background:
    radial-gradient(circle at 0% 0%, rgba(214,177,94,.17), transparent 32%),
    linear-gradient(135deg, #07111f, #10233e);
  color: var(--paper);
  box-shadow: var(--shadow);
}
.contact-copy h2 { font-size: clamp(44px, 5vw, 78px); margin: 18px 0 20px; }
.contact-copy p { color: rgba(248,244,232,.72); font-size: 18px; }
.contact-details { margin-top: 34px; display: grid; gap: 18px; }
.detail { padding-top: 18px; border-top: 1px solid rgba(248,244,232,.14); }
.detail span { color: var(--gold-2); display: block; font-size: 12px; text-transform: uppercase; letter-spacing: .16em; font-weight: 800; margin-bottom: 6px; }
.detail strong { font-size: 18px; }
.contact-form {
  background: rgba(248,244,232,.92);
  color: var(--ink);
  border-radius: var(--radius-xl);
  padding: 26px;
  border: 1px solid rgba(248,244,232,.22);
}
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.form-field { display: grid; gap: 7px; }
.form-field.full { grid-column: 1 / -1; }
label { font-size: 13px; font-weight: 800; color: #253447; }
input, select, textarea {
  width: 100%;
  border: 1px solid rgba(7,17,31,.14);
  border-radius: 13px;
  padding: 13px 14px;
  background: #fffdf8;
  color: var(--ink);
  outline: none;
  transition: border .2s ease, box-shadow .2s ease;
}
textarea { min-height: 130px; resize: vertical; }
input:focus, select:focus, textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 4px rgba(214,177,94,.18); }
.form-note { color: #657281; font-size: 13px; margin: 14px 0 0; }
.form-message { display: none; margin-top: 14px; padding: 13px 14px; border-radius: 13px; background: rgba(158,183,170,.18); color: #24352f; }
.form-message.is-visible { display: block; }

.legal-hero {
  padding: 150px 0 60px;
  color: var(--paper);
  background: linear-gradient(145deg, #07111f, #10233e);
}
.legal-hero h1 { font-size: clamp(48px, 7vw, 88px); margin-bottom: 18px; }
.legal-hero p { max-width: 780px; color: rgba(248,244,232,.72); font-size: 18px; }
.legal-content { padding: 72px 0; }
.legal-card { max-width: 900px; background: var(--paper-2); border: 1px solid rgba(7,17,31,.10); border-radius: var(--radius-xl); padding: clamp(28px, 5vw, 58px); }
.legal-card h2 { font-size: 32px; margin: 36px 0 12px; letter-spacing: -.035em; }
.legal-card h2:first-child { margin-top: 0; }
.legal-card p, .legal-card li { color: #4c5a66; }
.legal-card a { color: #163a63; text-decoration: underline; text-underline-offset: 4px; }

.site-footer {
  background: #050b14;
  color: rgba(248,244,232,.74);
  padding: 54px 0 28px;
}
.footer-grid {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(260px, .6fr) minmax(260px, .6fr);
  gap: 42px;
  align-items: start;
}
.footer-logo { width: 250px; margin-bottom: 18px; }
.footer-grid p { margin: 0; max-width: 560px; }
.footer-title { color: var(--paper); font-weight: 800; margin-bottom: 14px; }
.footer-links { display: grid; gap: 10px; }
.footer-links a { color: rgba(248,244,232,.74); }
.footer-disclaimer {
  margin-top: 38px;
  padding-top: 22px;
  border-top: 1px solid rgba(248,244,232,.12);
  font-size: 13px;
  color: rgba(248,244,232,.58);
}
.footer-bottom {
  margin-top: 22px;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  font-size: 13px;
  color: rgba(248,244,232,.48);
}

.reveal { opacity: 0; transform: translateY(22px); transition: opacity .75s ease, transform .75s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; }
}
@media (max-width: 1000px) {
  .hero-inner, .intro-grid, .split-band, .criteria, .contact-shell { grid-template-columns: 1fr; }
  .hero { min-height: auto; }
  .hero-panel { max-width: 600px; }
  .section-header { grid-template-columns: 1fr; gap: 14px; }
  .section-number { font-size: 24px; }
  .card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .process { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .process-step:nth-child(2) { border-right: 0; }
  .process-step:nth-child(-n+2) { border-bottom: 1px solid rgba(7,17,31,.10); }
  .footer-grid { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .header-inner { width: min(calc(100% - 28px), var(--max)); }
  .logo-link { width: 215px; }
  .menu-button { display: inline-flex; }
  .nav-links {
    position: fixed;
    inset: 74px 14px auto 14px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 14px;
    border-radius: 22px;
    background: rgba(7, 17, 31, .97);
    border: 1px solid rgba(248,244,232,.14);
    box-shadow: var(--shadow);
  }
  .nav-links.is-open { display: flex; }
  .nav-links a { padding: 14px; border-bottom: 1px solid rgba(248,244,232,.10); }
  .nav-links a:last-child { border-bottom: 0; }
  .header-cta { display: none; }
  .hero { padding: 124px 0 62px; }
  .hero::before { width: 640px; opacity: .46; right: -260px; }
  h1 { font-size: clamp(48px, 15vw, 74px); }
  .hero-lede { font-size: 17px; }
  .hero-actions .btn { width: 100%; }
  .panel-title { font-size: 30px; }
  .section { padding: 76px 0; }
  .section.compact { padding: 52px 0; }
  .container { width: min(calc(100% - 28px), var(--max)); }
  .card-grid, .process, .pathway-grid, .criteria-list, .form-grid { grid-template-columns: 1fr; }
  .focus-card, .service-card, .principle-card { min-height: auto; }
  .split-band { border-radius: 24px; }
  .split-visual { min-height: 280px; }
  .thesis-row { grid-template-columns: 1fr; gap: 6px; }
  .process-step, .process-step:nth-child(2) { border-right: 0; border-bottom: 1px solid rgba(7,17,31,.10); }
  .process-step:last-child { border-bottom: 0; }
  .process-step h3 { margin-top: 34px; }
  .contact-shell { padding: 24px; border-radius: 26px; }
  .contact-form { padding: 18px; }
  .footer-bottom { flex-direction: column; }
}
