:root {
  --navy: #0e1a22;
  --display-navy: #102637;
  --ivory: #f3efe6;
  --ink: #151515;
  --brass: #967242;
  --umber: #3a281c;
  --slate: #46515a;
  --stone: #c8bdae;
}

* {
  box-sizing: border-box;
}

html {
  background: var(--navy);
}

body {
  margin: 0;
  color: var(--ivory);
  background: var(--navy);
  font-family: Inter, "Aktiv Grotesk", "Helvetica Neue", Arial, sans-serif;
}

body.page-light {
  color: var(--ink);
  background: var(--ivory);
}

a {
  color: inherit;
  text-decoration: none;
}

.site-shell {
  min-height: 100vh;
  overflow: hidden;
}

.hero {
  position: relative;
  min-height: 100vh;
  padding: 42px 6vw 64px;
  display: grid;
  grid-template-rows: auto 1fr;
  isolation: isolate;
}

.hero-ivory {
  color: var(--display-navy);
  background:
    linear-gradient(rgba(243, 239, 230, 0.94), rgba(243, 239, 230, 0.94)),
    var(--ivory);
}

.hero-video,
.hero-overlay {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.hero-ivory .hero-video {
  display: block;
  inset: 0;
  width: 100%;
  object-fit: cover;
  object-position: 66% 58%;
  filter: saturate(0.72) contrast(1.06) brightness(0.9);
  opacity: 0.68;
}

.hero-ivory .hero-overlay {
  display: block;
  background:
    radial-gradient(circle at 72% 48%, rgba(243, 239, 230, 0.02) 0%, rgba(243, 239, 230, 0.24) 34%, rgba(243, 239, 230, 0.58) 62%, rgba(243, 239, 230, 0.78) 100%),
    linear-gradient(90deg, rgba(243, 239, 230, 0.94) 0%, rgba(243, 239, 230, 0.68) 44%, rgba(243, 239, 230, 0.28) 100%);
}

.hero-video {
  object-fit: cover;
  filter: saturate(0.72) contrast(0.9) brightness(0.82);
  z-index: -3;
}

.hero-overlay {
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(10, 32, 48, 0.84) 0%, rgba(10, 32, 48, 0.66) 45%, rgba(10, 32, 48, 0.48) 100%),
    linear-gradient(0deg, rgba(14, 26, 34, 0.34), rgba(14, 26, 34, 0.18)),
    radial-gradient(circle at 20% 20%, rgba(166, 124, 61, 0.08), transparent 32%);
}

.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.11;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 3px 3px, 5px 5px;
  mix-blend-mode: soft-light;
}

.nav {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}

.logo-mark {
  width: 244px;
  height: 48px;
  display: block;
}

.logo-mark img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
}

.wordmark-logo {
  display: inline-block;
  color: var(--display-navy);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 34px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.005em;
}

.wordmark-logo-reverse {
  color: var(--ivory);
}

.nav-ivory .logo-mark img {
  opacity: 1;
  filter: none;
  mix-blend-mode: normal;
}

.nav-links {
  display: flex;
  gap: 34px;
  align-items: center;
  font-size: 10px;
  line-height: 1;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.nav-links a {
  color: rgba(243, 239, 230, 0.82);
}

.nav-ivory .nav-links a {
  color: rgba(16, 38, 55, 0.94);
  font-weight: 500;
}

.hero-content {
  align-self: center;
  max-width: 650px;
  padding-top: 74px;
}

.eyebrow,
.section-label {
  margin: 0 0 24px;
  color: var(--brass);
  font-size: 13px;
  line-height: 1.2;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

h1,
h2 {
  margin: 0;
  font-family: Canela, "Cormorant Garamond", Georgia, serif;
  font-weight: 400;
  letter-spacing: 0;
}

h1 {
  max-width: 650px;
  font-size: clamp(42px, 5.4vw, 72px);
  line-height: 1.02;
}

.hero-content p {
  max-width: 410px;
  margin: 30px 0 0;
  color: rgba(243, 239, 230, 0.78);
  font-family: "Tiempos Text", Georgia, serif;
  font-size: 17px;
  line-height: 1.58;
}

.hero-ivory .hero-content {
  max-width: 700px;
  padding-top: 42px;
}

.hero-ivory h1 {
  color: var(--display-navy);
}

.hero-v3-ivory {
  color: var(--display-navy);
  background: var(--ivory);
}

.hero-v3-ivory .hero-video {
  display: block;
  inset: 0;
  width: 100%;
  object-fit: cover;
  object-position: 66% 58%;
  filter: saturate(0.7) contrast(1.04) brightness(0.92);
  opacity: 0.62;
}

.hero-v3-ivory .hero-overlay {
  display: block;
  background:
    radial-gradient(circle at 72% 48%, rgba(243, 239, 230, 0.04) 0%, rgba(243, 239, 230, 0.28) 34%, rgba(243, 239, 230, 0.6) 62%, rgba(243, 239, 230, 0.82) 100%),
    linear-gradient(90deg, rgba(243, 239, 230, 0.95) 0%, rgba(243, 239, 230, 0.72) 44%, rgba(243, 239, 230, 0.34) 100%);
}

.hero-v4-navy {
  color: var(--ivory);
  background: var(--display-navy);
}

.hero-v4-navy .hero-video {
  display: block;
  inset: 0;
  width: 100%;
  object-fit: cover;
  object-position: 66% 56%;
  filter: saturate(0.72) contrast(1.08) brightness(0.88);
  opacity: 1;
}

.hero-v4-navy .hero-overlay {
  display: block;
  background:
    radial-gradient(circle at 70% 52%, rgba(16, 38, 55, 0.04) 0%, rgba(16, 38, 55, 0.22) 38%, rgba(16, 38, 55, 0.58) 100%),
    linear-gradient(90deg, rgba(16, 38, 55, 0.92) 0%, rgba(16, 38, 55, 0.62) 48%, rgba(16, 38, 55, 0.2) 100%);
}

.nav-v3 .nav-links a {
  color: rgba(16, 38, 55, 0.92);
  font-weight: 500;
}

.nav-v4 .nav-links a {
  color: rgba(243, 239, 230, 0.86);
  font-weight: 500;
}

.hero-content-v3,
.hero-content-v4 {
  max-width: 700px;
  padding-top: 38px;
}

.hero-content-v3 .eyebrow {
  color: var(--slate);
}

.hero-content-v4 .eyebrow {
  color: rgba(200, 189, 174, 0.86);
}

.hero-content-v3 h1,
.hero-content-v4 h1 {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 400;
  max-width: 700px;
  font-size: clamp(42px, 5.4vw, 72px);
  line-height: 1.03;
}

.hero-content-v3 h1 {
  color: var(--display-navy);
}

.hero-content-v4 h1 {
  color: var(--ivory);
}

.version-cta {
  margin-top: 30px;
  color: var(--brass);
  font-family: Inter, "Aktiv Grotesk", "Helvetica Neue", Arial, sans-serif;
  letter-spacing: 0.18em;
}

.line-cta {
  display: inline-flex;
  align-items: center;
  gap: 15px;
  margin-top: 34px;
  color: var(--brass);
  font-size: 11px;
  line-height: 1;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.line-cta span {
  width: 84px;
  height: 1px;
  display: inline-block;
  background: var(--brass);
}

.approach p,
.portfolio-list {
  margin: 0;
  font-family: "Tiempos Text", Georgia, serif;
  font-size: 16px;
  line-height: 1.48;
}

.approach {
  display: grid;
  grid-template-columns: minmax(280px, 0.8fr) minmax(320px, 1fr);
  gap: 9vw;
  padding: 94px 6vw;
  color: var(--ink);
  background: var(--ivory);
  border-top: 1px solid rgba(21, 21, 21, 0.08);
}

.approach h2,
.portfolio h2 {
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1.08;
}

.approach p:not(.section-label) {
  max-width: 490px;
  align-self: end;
  font-size: 20px;
}

.portfolio {
  display: grid;
  grid-template-columns: minmax(290px, 0.72fr) 1.28fr;
  gap: 7vw;
  padding: 88px 6vw;
  color: var(--ivory);
  background: var(--navy);
  border-top: 1px solid rgba(166, 124, 61, 0.42);
}

.interior-shell {
  min-height: 100vh;
  background: var(--ivory);
}

.interior-shell.dark {
  background: var(--navy);
}

.interior-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  padding: 42px 6vw;
}

.interior-nav.dark {
  color: var(--ivory);
}

.interior-logo img {
  width: 265px;
  height: auto;
  display: block;
}

.interior-links {
  display: flex;
  gap: 34px;
  align-items: center;
  color: var(--ink);
  font-size: 10px;
  line-height: 1;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.page-section {
  min-height: calc(100vh - 126px);
}

.page-section h1 {
  font-size: clamp(44px, 5.2vw, 76px);
  line-height: 1.04;
}

.portfolio.page-section {
  border-top: 0;
}

.portfolio-intro {
  max-width: 430px;
}

.portfolio-list {
  border-top: 1px solid rgba(166, 124, 61, 0.56);
}

.portfolio-list div {
  display: grid;
  grid-template-columns: 1fr 0.7fr 80px;
  gap: 28px;
  padding: 22px 0;
  border-bottom: 1px solid rgba(243, 239, 230, 0.14);
}

.portfolio-list strong {
  font-family: "Aktiv Grotesk", "Helvetica Neue", Arial, sans-serif;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.portfolio-list span {
  color: rgba(243, 239, 230, 0.68);
}

.line-cta.small {
  margin-top: 28px;
}

.footer {
  padding: 54px 6vw 64px;
  color: rgba(243, 239, 230, 0.72);
  background: #0b141a;
  text-align: center;
}

.footer-line {
  width: 138px;
  height: 1px;
  margin: 0 auto 22px;
  background: var(--brass);
}

.footer p {
  margin: 0;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

@media (max-width: 860px) {
  .hero {
    min-height: 100vh;
    padding: 32px 26px 48px;
  }

  .nav {
    align-items: flex-start;
  }

  .logo-mark {
    width: 196px;
    height: 40px;
  }

  .nav-links {
    display: none;
  }

  .nav-ivory .nav-links {
    display: flex;
    gap: 18px;
    font-size: 9px;
  }

  .hero-content {
    padding-top: 110px;
  }

  .hero-content p {
    font-size: 16px;
  }

  .approach,
  .portfolio {
    grid-template-columns: 1fr;
  }

  .approach,
  .portfolio {
    padding: 66px 26px;
  }

  .portfolio-list div {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .interior-nav {
    padding: 32px 26px;
  }

  .interior-logo img {
    width: 205px;
  }

  .interior-links {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-video {
    display: none;
  }

  .hero-ivory {
    background: var(--ivory);
  }

  .hero:not(.hero-ivory) {
    background: var(--navy);
  }
}

/* ---- Investor login (login.html) ---- */
.login-page {
  background: var(--ivory);
}

.login-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 48px 26px;
}

.login-card {
  width: 100%;
  max-width: 380px;
  text-align: center;
}

.login-logo {
  display: inline-block;
  width: 230px;
  height: auto;
  margin: 0 auto 40px;
}

.login-logo img {
  width: 100%;
  height: auto;
  display: block;
}

.login-heading {
  margin: 0 0 8px;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 500;
  font-size: 30px;
  line-height: 1.05;
  color: var(--display-navy);
}

.login-intro {
  margin: 0 0 30px;
  font-family: "Tiempos Text", Georgia, serif;
  font-size: 14px;
  line-height: 1.5;
  color: var(--slate);
}

.login-form {
  display: grid;
  gap: 16px;
  text-align: left;
}

.login-field {
  display: grid;
  gap: 7px;
}

.login-field span {
  font-family: Inter, "Aktiv Grotesk", "Helvetica Neue", Arial, sans-serif;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--slate);
}

.login-field input {
  width: 100%;
  padding: 12px 14px;
  font-family: Inter, "Helvetica Neue", Arial, sans-serif;
  font-size: 15px;
  color: var(--ink);
  background: #fbf9f3;
  border: 1px solid rgba(16, 38, 55, 0.18);
  border-radius: 2px;
  outline: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.login-field input:focus {
  border-color: var(--brass);
  box-shadow: 0 0 0 2px rgba(150, 114, 66, 0.25);
}

.login-button {
  margin-top: 6px;
  padding: 13px 18px;
  font-family: Inter, "Helvetica Neue", Arial, sans-serif;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ivory);
  background: var(--brass);
  border: 0;
  border-radius: 2px;
  cursor: pointer;
  transition: background-color 0.15s ease;
}

.login-button:hover,
.login-button:focus-visible {
  background: #7f5f36;
  outline: none;
}

.login-error {
  margin-top: 6px;
  padding: 14px 16px;
  font-family: "Tiempos Text", Georgia, serif;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--umber);
  background: rgba(150, 114, 66, 0.08);
  border: 1px solid rgba(150, 114, 66, 0.3);
  border-radius: 2px;
  outline: none;
}

.login-error a {
  color: var(--brass);
  text-decoration: underline;
  text-underline-offset: 2px;
}
