:root {
  --bg: #0d0d0b;
  --bg-soft: #151412;
  --line: rgba(202, 186, 164, 0.20);
  --line-soft: rgba(202, 186, 164, 0.11);
  --metal: #c8b6a1;
  --metal-muted: #9e9284;
  --text: #d7cab8;
  --text-soft: rgba(224, 216, 204, 0.72);
  --text-dim: rgba(224, 216, 204, 0.58);
  --shadow: rgba(0,0,0,.72);
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  min-height: 100%;
  background: #080806;
  color: var(--text);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% -10%, rgba(154, 141, 122, .15), transparent 34rem),
    radial-gradient(circle at 50% 73%, rgba(181, 166, 145, .10), transparent 25rem),
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,0) 22%, rgba(255,255,255,.02) 60%, rgba(0,0,0,.45)),
    repeating-radial-gradient(circle at 20% 0%, rgba(255,255,255,.026) 0 1px, transparent 1px 4px);
  opacity: .9;
  mix-blend-mode: screen;
}

.page-shell {
  position: relative;
  min-height: 100svh;
  width: 100%;
  isolation: isolate;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(255,255,255,.018), transparent 20%, transparent 80%, rgba(255,255,255,.014)),
    radial-gradient(circle at 50% 0%, rgba(76,70,62,.30), transparent 28rem),
    radial-gradient(circle at 50% 78%, rgba(92,84,74,.22), transparent 32rem),
    #0d0d0b;
}

.page-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -3;
  opacity: .44;
  background-image:
    linear-gradient(115deg, rgba(255,255,255,.035) 0 1px, transparent 1px 100%),
    radial-gradient(rgba(255,255,255,.065) .65px, transparent .65px);
  background-size: 100% 100%, 5px 5px;
  filter: contrast(1.05);
}

.page-shell::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: radial-gradient(ellipse at center, transparent 44%, rgba(0,0,0,.34) 100%);
  pointer-events: none;
}

.ambient { position:absolute; pointer-events:none; z-index:-1; opacity:.45; }
.ambient-top {
  inset: -18rem 12% auto 12%;
  height: 32rem;
  background: radial-gradient(ellipse at center, rgba(165,150,130,.22), transparent 67%);
  filter: blur(8px);
}
.ambient-bottom {
  left: 20%; right: 20%; bottom: -18rem; height: 35rem;
  background: radial-gradient(ellipse at center, rgba(149,135,117,.18), transparent 62%);
  filter: blur(10px);
}

.site-header {
  position: relative;
  z-index: 3;
  display: flex;
  justify-content: center;
  align-items: center;
  height: clamp(108px, 13svh, 150px);
  border-bottom: 1px solid rgba(217, 203, 182, .075);
  background: linear-gradient(180deg, rgba(7,7,6,.32), rgba(15,14,13,.05));
}

.brand-lockup {
  display: block;
  width: clamp(180px, 25vw, 310px);
  max-width: 62vw;
  line-height: 0;
  mix-blend-mode: screen;
  opacity: .94;
}
.brand-lockup img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

.hero {
  position: relative;
  z-index: 2;
  width: min(100% - 34px, 1040px);
  margin-inline: auto;
  text-align: center;
  padding-top: clamp(26px, 5svh, 55px);
  padding-bottom: clamp(330px, 29svh, 390px);
}

.hero-symbol {
  width: clamp(50px, 10vw, 72px);
  margin: 0 auto clamp(20px, 3.2svh, 30px);
  line-height: 0;
  mix-blend-mode: screen;
  opacity: .82;
  filter: drop-shadow(0 14px 16px rgba(0,0,0,.46));
}
.hero-symbol img { width: 100%; height: auto; display: block; object-fit: contain; }

.ornament {
  width: 31px;
  height: 1px;
  margin: 0 auto clamp(18px, 2.3svh, 26px);
  background: linear-gradient(90deg, transparent, rgba(207,190,168,.75), transparent);
  opacity: .72;
}

h1 {
  margin: 0;
  font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  font-weight: 400;
  line-height: .87;
  letter-spacing: -.035em;
  font-size: clamp(4.6rem, 18vw, 8.7rem);
  color: #cfc2b0;
  text-shadow:
    0 1px 0 rgba(255,255,255,.18),
    0 16px 24px rgba(0,0,0,.52),
    0 0 1px rgba(255,255,255,.18);
}

.intro {
  margin: clamp(28px, 4svh, 46px) auto 0;
  max-width: 740px;
  font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  font-size: clamp(1.55rem, 4.9vw, 2.35rem);
  line-height: 1.12;
  font-weight: 400;
  color: #cbbba6;
  letter-spacing: -.012em;
}

.supporting-copy {
  margin: clamp(18px, 2.1svh, 24px) auto 0;
  max-width: 720px;
  font-size: clamp(.95rem, 2.25vw, 1.2rem);
  line-height: 1.55;
  font-weight: 300;
  color: var(--text-soft);
  letter-spacing: .005em;
}

.contact-card {
  display: grid;
  grid-template-columns: auto 1px 1fr;
  gap: clamp(18px, 4.5vw, 31px);
  align-items: center;
  width: min(100%, 660px);
  margin: clamp(30px, 4svh, 42px) auto 0;
  padding: clamp(18px, 3.6vw, 25px) clamp(24px, 5.5vw, 36px);
  border: 1px solid rgba(214, 197, 176, .34);
  border-radius: 18px;
  color: #c8b8a1;
  text-decoration: none;
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012));
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.2), 0 24px 50px rgba(0,0,0,.28);
  transition: border-color .25s ease, transform .25s ease, background .25s ease;
}
.contact-card:hover {
  border-color: rgba(232, 213, 188, .54);
  transform: translateY(-1px);
  background: linear-gradient(180deg, rgba(255,255,255,.048), rgba(255,255,255,.016));
}
.mail-icon {
  width: clamp(42px, 8.2vw, 58px);
  color: #c9b49c;
  opacity: .88;
  line-height: 0;
}
.mail-icon svg { width: 100%; height: auto; display: block; }
.contact-divider { width: 1px; align-self: stretch; background: var(--line); }
.contact-text { text-align: left; min-width: 0; }
.contact-text .label {
  display: block;
  margin-bottom: 3px;
  font-size: clamp(.78rem, 1.9vw, .95rem);
  color: var(--text-dim);
  letter-spacing: .01em;
  text-transform: none;
}
.contact-text .email {
  display: block;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(1.5rem, 5.2vw, 2.35rem);
  line-height: 1;
  color: #d8cab6;
  letter-spacing: -.018em;
  white-space: nowrap;
}

.features {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  width: min(100%, 840px);
  margin: clamp(42px, 6svh, 62px) auto 0;
  color: #c5b39c;
}
.feature {
  position: relative;
  padding: 0 clamp(12px, 2.2vw, 28px);
  min-width: 0;
}
.feature + .feature { border-left: 1px solid var(--line-soft); }
.feature-icon {
  display: block;
  width: clamp(35px, 7vw, 48px);
  margin: 0 auto clamp(13px, 1.7svh, 19px);
  color: #bfae98;
  opacity: .82;
}
.feature-icon svg { display:block; width:100%; height:auto; }
.feature h2 {
  margin: 0;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 400;
  font-size: clamp(1.05rem, 2.6vw, 1.42rem);
  line-height: 1.04;
  color: #c9b8a2;
  letter-spacing: -.01em;
}

.machine-wrap {
  position: absolute;
  z-index: 1;
  left: 50%;
  bottom: -2px;
  width: min(56vw, 390px);
  transform: translateX(-50%);
  opacity: .54;
  mix-blend-mode: screen;
  filter: saturate(.86) contrast(.92) brightness(.78);
  pointer-events: none;
}
.machine-wrap::before {
  content: "";
  position: absolute;
  left: 3%; right: 3%; top: -2%; height: 18%;
  background: linear-gradient(180deg, rgba(13,13,11,0), rgba(13,13,11,.64));
  z-index: 2;
}
.machine-wrap img { display: block; width: 100%; height: auto; }

@media (min-width: 900px) {
  .page-shell {
    min-height: 100svh;
  }
  .site-header {
    height: 118px;
  }
  .brand-lockup { width: 258px; }
  .hero {
    padding-top: 38px;
    padding-bottom: 255px;
  }
  h1 { font-size: clamp(5.8rem, 9vw, 9.4rem); }
  .intro { font-size: clamp(1.75rem, 2.4vw, 2.45rem); }
  .supporting-copy { font-size: clamp(1rem, 1.12vw, 1.16rem); }
  .contact-card { margin-top: 32px; max-width: 620px; }
  .features { margin-top: 46px; max-width: 860px; }
  .feature h2 { font-size: clamp(1.16rem, 1.28vw, 1.38rem); }
  .machine-wrap { width: min(31vw, 420px); opacity: .48; }
}

@media (max-width: 480px) {
  .site-header { height: 108px; }
  .brand-lockup { width: 205px; }
  .hero {
    width: min(100% - 30px, 520px);
    padding-top: 34px;
    padding-bottom: 316px;
  }
  .hero-symbol { width: 54px; margin-bottom: 22px; }
  h1 { font-size: clamp(4.85rem, 19.6vw, 6.3rem); }
  .intro { margin-top: 30px; font-size: clamp(1.58rem, 6vw, 2rem); }
  .supporting-copy { font-size: .98rem; line-height: 1.52; }
  .contact-card {
    border-radius: 15px;
    padding: 18px 22px;
    gap: 17px;
  }
  .mail-icon { width: 42px; }
  .contact-text .email { font-size: clamp(1.44rem, 7.2vw, 1.9rem); }
  .features { margin-top: 42px; }
  .feature { padding: 0 9px; }
  .feature-icon { width: 35px; margin-bottom: 12px; }
  .feature h2 { font-size: clamp(1rem, 4.2vw, 1.28rem); }
  .machine-wrap { width: min(72vw, 318px); opacity: .48; }
}

@media (max-width: 370px) {
  .site-header { height: 92px; }
  .brand-lockup { width: 176px; }
  .hero { padding-top: 22px; padding-bottom: 265px; width: min(100% - 24px, 520px); }
  .hero-symbol { width: 44px; margin-bottom: 15px; }
  .ornament { margin-bottom: 14px; }
  h1 { font-size: 4.25rem; }
  .intro { margin-top: 24px; font-size: 1.43rem; }
  .supporting-copy { font-size: .86rem; line-height: 1.42; }
  .contact-card { margin-top: 24px; padding: 15px 16px; gap: 12px; }
  .contact-text .email { font-size: 1.33rem; }
  .features { margin-top: 30px; }
  .feature { padding: 0 6px; }
  .feature-icon { width: 29px; }
  .feature h2 { font-size: .89rem; }
  .machine-wrap { width: min(66vw, 250px); }
}

@media (min-width: 1100px) and (min-height: 850px) {
  .hero { padding-top: 50px; padding-bottom: 305px; }
  .machine-wrap { width: min(29vw, 440px); }
}
