:root{
  --charcoal:#1C1815;
  --paper:#F3EEE6;
  --ivory:#FAF6F0;
  --line:rgba(28,24,21,.08);
  --line-strong:rgba(28,24,21,.14);
  --purple:#8E7D9D;
  --seafoam:#9FC6BC;
  --sand:#DCCFC0;
  --white:#F5F1EA;
  --shadow:0 18px 50px rgba(0,0,0,.07);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  color:var(--charcoal);
  background:var(--ivory);
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img,video{
  display:block;
  width:100%;
  height:auto;
}

a{
  color:inherit;
  text-decoration:none;
}

button,input{
  font:inherit;
}

/* NAV */
.nav{
  position:fixed;
  top:0;
  left:0;
  right:0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 34px;
  background:rgba(250,246,240,.72);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(28,24,21,.05);
  z-index:30;
  transition:background .28s ease, border-color .28s ease;
}

.nav.scrolled{
  background:rgba(250,246,240,.84);
  border-bottom:1px solid rgba(28,24,21,.09);
}

.brand{
  font-family:"Crimson Text", serif;
  letter-spacing:.24em;
  text-transform:uppercase;
  font-size:15px;
  color:var(--charcoal);
}

.links{
  display:flex;
  align-items:center;
  gap:22px;
}

.links a{
  font-size:13px;
  letter-spacing:.06em;
  opacity:.78;
  transition:opacity .2s ease;
}

.links a:hover{
  opacity:1;
}

.menuToggle{
  display:none;
  width:42px;
  height:42px;
  border:1px solid rgba(28,24,21,.14);
  background:transparent;
  border-radius:999px;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
}

.menuToggle span{
  width:15px;
  height:1px;
  background:var(--charcoal);
  display:block;
}

/* HERO */
.hero{
  position:relative;
  min-height:100vh;
  overflow:hidden;
  background:#000;
}

.heroVideo{
  width:100%;
  height:100%;
  min-height:100vh;
  object-fit:cover;
  object-position:center center;
  filter:saturate(.76) contrast(.92) brightness(.68);
  transform:scale(1.14);
}

@media (orientation: portrait){
  .heroVideo{
    transform:scale(1.32);
  }
}

.heroShade{
  position:absolute;
  inset:0;
  background:linear-gradient(
    to bottom,
    rgba(0,0,0,.16),
    rgba(0,0,0,.28) 36%,
    rgba(0,0,0,.54) 100%
  );
}

.heroVignette{
  position:absolute;
  inset:0;
  background:radial-gradient(circle at center, transparent 34%, rgba(0,0,0,.24) 100%);
}

.heroOverlay{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:24px;
  color:var(--white);
}

.heroKicker,
.sectionEyebrow,
.entryMeta{
  margin:0 0 16px;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  opacity:.76;
}

.wordmark{
  font-family:"Crimson Text", serif;
  letter-spacing:.26em;
  text-transform:uppercase;
  font-size:clamp(44px, 6vw, 86px);
  line-height:1;
  margin:0;
  color:var(--white);
  font-weight:400;
}

.tagline{
  font-family:"Crimson Text", serif;
  font-size:clamp(18px, 2vw, 26px);
  margin:18px 0 0;
  color:var(--white);
  opacity:.95;
}

.heroActions{
  display:flex;
  gap:22px;
  flex-wrap:wrap;
  justify-content:center;
  margin-top:24px;
}

.quietLink{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.14em;
  padding-bottom:8px;
  border-bottom:1px solid rgba(245,241,234,.44);
}

.quietLink.muted{
  opacity:.74;
}

.down{
  margin-top:24px;
  color:var(--white);
  opacity:.82;
  font-size:22px;
}

/* LAYOUT */
.section{
  width:min(1180px, calc(100% - 64px));
  margin:0 auto;
  padding:110px 0;
}

.section.alt{
  width:100%;
  max-width:none;
  background:var(--paper);
}

.sectionHeader,
.motionHeader,
.journalHeader{
  margin-bottom:44px;
}

.sectionHeader{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:28px;
}

.sectionTitle{
  font-family:"Crimson Text", serif;
  font-size:clamp(34px, 4vw, 52px);
  margin:0;
  letter-spacing:.03em;
  font-weight:400;
}

.sectionAside{
  max-width:34ch;
  opacity:.72;
  font-size:15px;
  line-height:1.75;
}

.sectionIntro{
  max-width:62ch;
  margin:12px auto 0;
  opacity:.78;
  line-height:1.75;
  text-align:center;
  font-size:16px;
}

/* PRODUCTS */
.grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:34px;
  align-items:start;
}

.card{
  display:flex;
  flex-direction:column;
  background:transparent;
  border:none;
  padding:0;
}

.productFrame{
  width:100%;
  aspect-ratio:4 / 4.9;
  overflow:hidden;
  border-radius:2px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#EEE6DC;
}

.productFrame img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.bg-purple{background:color-mix(in srgb, var(--purple) 68%, white)}
.bg-seafoam{background:color-mix(in srgb, var(--seafoam) 70%, white)}
.bg-sand{background:color-mix(in srgb, var(--sand) 74%, white)}

.cardBody{
  padding-top:18px;
}

.productType{
  margin:0 0 6px;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  opacity:.56;
}

.card h3{
  font-family:"Crimson Text", serif;
  font-size:clamp(24px, 2vw, 34px);
  line-height:1.15;
  margin:0 0 8px;
  font-weight:400;
}

.meta{
  margin:0;
  color:rgba(28,24,21,.72);
  font-size:15px;
  line-height:1.7;
}

.specs{
  list-style:none;
  padding:0;
  margin:16px 0 0;
  display:grid;
  gap:8px;
}

.specs li{
  position:relative;
  padding-left:16px;
  font-size:14px;
  color:rgba(28,24,21,.74);
}

.specs li::before{
  content:"";
  position:absolute;
  left:0;
  top:.74em;
  width:5px;
  height:5px;
  border-radius:999px;
  background:rgba(28,24,21,.4);
  transform:translateY(-50%);
}

.cardFooter{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-top:18px;
}

.price{
  margin:0;
  font-weight:500;
  font-size:16px;
  letter-spacing:.02em;
  color:rgba(28,24,21,.94);
}

.quietBtn{
  display:inline-block;
  padding:12px 18px;
  border:1px solid var(--charcoal);
  border-radius:2px;
  color:var(--charcoal);
  background:transparent;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  transition:all .22s ease;
}

.quietBtn:hover{
  background:var(--charcoal);
  color:var(--ivory);
}

/* DETAIL STRIP */
.detailStrip{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:#F6F1EA;
}

.detailGrid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:32px;
}

.detailBlock{
  padding:10px 0;
}

.detailBlock h2{
  font-family:"Crimson Text", serif;
  font-size:clamp(28px, 3vw, 42px);
  line-height:1.08;
  font-weight:400;
  margin:0 0 10px;
}

.detailBlock p{
  margin:0;
  color:rgba(28,24,21,.72);
  line-height:1.8;
}

/* MOTION */
.motionGrid{
  width:min(1180px, calc(100% - 64px));
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:28px;
}

.motionCard{
  margin:0;
  background:transparent;
  overflow:hidden;
}

.motionCard video{
  width:100%;
  height:320px;
  object-fit:cover;
  display:block;
  border-radius:2px;
}

.motionCard figcaption{
  padding:12px 6px 0;
  font-family:"Crimson Text", serif;
  font-size:18px;
  text-align:center;
  color:rgba(28,24,21,.82);
}

/* JOURNAL */
.journal{
  display:grid;
  gap:22px;
  max-width:920px;
  margin:0 auto;
}

.entry{
  padding:0 0 24px;
  border-bottom:1px solid var(--line);
}

.entry:last-child{
  border-bottom:none;
}

.entry h3{
  font-family:"Crimson Text", serif;
  margin:0 0 10px;
  font-size:30px;
  font-weight:400;
}

.entry p{
  margin:0;
  color:rgba(28,24,21,.72);
  font-size:16px;
  line-height:1.75;
}

/* ACCESS */
.accessSection{
  text-align:center;
}

.waitlistForm{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:12px;
  margin-top:24px;
  flex-wrap:wrap;
}

.waitlistForm input{
  padding:13px 15px;
  border:1px solid rgba(28,24,21,.14);
  border-radius:2px;
  font-size:14px;
  width:300px;
  background:#fff;
  color:var(--charcoal);
  outline:none;
}

.waitlistForm input:focus{
  border-color:rgba(28,24,21,.35);
}

.hiddenField{
  position:absolute;
  left:-9999px;
}

.formStatus{
  min-height:20px;
  margin-top:12px;
  font-size:14px;
  color:rgba(28,24,21,.62);
}

/* FOOTER */
.footer{
  padding:34px 18px 42px;
  text-align:center;
  color:rgba(28,24,21,.56);
  border-top:1px solid var(--line);
  font-size:13px;
  letter-spacing:.04em;
}

/* REVEALS */
.reveal,
.reveal-section{
  opacity:0;
  transform:translateY(18px);
  transition:
    opacity .7s cubic-bezier(.22,1,.36,1),
    transform .7s cubic-bezier(.22,1,.36,1);
}

.reveal.is-visible,
.reveal-section.is-visible{
  opacity:1;
  transform:translateY(0);
}

.reveal-delay-1{transition-delay:.08s}
.reveal-delay-2{transition-delay:.16s}
.reveal-delay-3{transition-delay:.24s}
.reveal-delay-4{transition-delay:.32s}

/* MOBILE */
@media (max-width: 900px){
  .nav{
    padding:16px 18px;
  }

  .menuToggle{
    display:flex;
  }

  .links{
    position:absolute;
    top:calc(100% + 10px);
    right:18px;
    width:min(240px, calc(100% - 36px));
    display:none;
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
    padding:16px;
    background:rgba(250,246,240,.96);
    border:1px solid rgba(28,24,21,.08);
    box-shadow:var(--shadow);
  }

  .links.open{
    display:flex;
  }

  .section,
  .motionGrid{
    width:min(100%, calc(100% - 32px));
  }

  .section{
    padding:84px 0;
  }

  .sectionHeader{
    flex-direction:column;
    align-items:flex-start;
  }

  .grid,
  .motionGrid,
  .detailGrid{
    grid-template-columns:1fr;
    gap:28px;
  }

  .productFrame{
    aspect-ratio:4 / 4.7;
  }

  .motionCard video{
    height:240px;
  }

  .waitlistForm{
    flex-direction:column;
  }

  .waitlistForm input{
    width:100%;
    max-width:360px;
  }

  .cardFooter{
    flex-direction:column;
    align-items:flex-start;
  }
}.thankYouPage{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:40px 20px;
  background:var(--ivory);
}

.thankYouWrap{
  max-width:680px;
  text-align:center;
}