:root {
  --ink: #151515;
  --muted: #626870;
  --line: rgba(20, 22, 24, .12);
  --gold: #9d7a31;
  --paper: #f7f7f4;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  overflow-x: hidden;
  background:
    radial-gradient(circle at 8% 8%, rgba(237, 225, 201, .55), transparent 23%),
    radial-gradient(circle at 92% 12%, rgba(214, 230, 238, .62), transparent 27%),
    var(--paper);
  color: var(--ink);
  font-family: Inter, system-ui, sans-serif;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

.case-bar {
  position: fixed;
  z-index: 30;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 26px 36px;
  color: #171717;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .05em;
  text-transform: uppercase;
  mix-blend-mode: multiply;
}
.case-bar a { border-bottom: 1px solid currentColor; padding-bottom: 5px; }

.photo-cover {
  position: relative;
  width: calc(100% - 32px);
  height: min(88vh, 900px);
  min-height: 650px;
  margin: 16px auto 0;
  overflow: hidden;
  background:
    radial-gradient(circle at 70% 40%, rgba(255,255,255,.98), rgba(245,248,249,.82) 44%, transparent 68%),
    linear-gradient(135deg, #f5efe4, #eef5f8 58%, #f7f5ef);
}
.photo-cover::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255,255,255,.2), transparent 52%);
  pointer-events: none;
}
.cover-orbit {
  position: absolute;
  border: 1px solid rgba(119, 144, 157, .16);
  border-radius: 50%;
}
.orbit-one { width: 620px; height: 620px; right: 4%; top: 5%; }
.orbit-two { width: 420px; height: 420px; right: 14%; top: 19%; }

.product-stage {
  position: absolute;
  z-index: 1;
  top: 10%;
  right: 2.5%;
  width: 62%;
  height: 80%;
}
.stage-product {
  position: absolute;
  width: 42%;
  aspect-ratio: 1;
  object-fit: contain;
  mix-blend-mode: multiply;
  filter: drop-shadow(0 30px 24px rgba(38, 46, 52, .12));
}
.stage-salt { left: 0; bottom: 2%; z-index: 2; }
.stage-pepper { left: 25%; top: 2%; z-index: 3; }
.stage-cinnamon { right: 3%; bottom: -1%; z-index: 2; }
.stage-turmeric { right: -5%; top: -6%; width: 34%; opacity: .94; }

.cover-caption {
  position: absolute;
  z-index: 5;
  left: 34px;
  bottom: 34px;
  width: min(510px, calc(100% - 68px));
  padding: 25px 28px 27px;
  border: 1px solid rgba(255,255,255,.85);
  border-radius: 26px;
  background: rgba(255,255,255,.62);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.95), 0 22px 60px rgba(61,71,75,.12);
  -webkit-backdrop-filter: blur(24px) saturate(1.2);
  backdrop-filter: blur(24px) saturate(1.2);
}
.cover-caption p,
.label {
  margin: 0 0 16px;
  color: var(--gold);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .17em;
  text-transform: uppercase;
}
.cover-caption h1 {
  margin: 0 0 14px;
  font-family: "Playfair Display", serif;
  font-size: clamp(52px, 6.4vw, 88px);
  font-weight: 500;
  line-height: .88;
  letter-spacing: -.065em;
}
.cover-caption span { color: #606870; font-size: 13px; font-weight: 600; }

.summary {
  width: min(1120px, calc(100% - 56px));
  margin: 96px auto;
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 90px;
}
.summary h2,
.final-frame h2 {
  margin: 0;
  font-size: clamp(42px, 4.9vw, 68px);
  line-height: .98;
  letter-spacing: -.06em;
}
.summary-copy > p {
  margin: 0 0 34px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.65;
}
.summary dl {
  margin: 0;
  padding-top: 20px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  border-top: 1px solid var(--line);
}
.summary dt { margin-bottom: 8px; color: var(--gold); font-size: 9px; font-weight: 900; letter-spacing: .14em; text-transform: uppercase; }
.summary dd { margin: 0; font-size: 12px; font-weight: 700; line-height: 1.45; }

.photo-grid {
  width: min(1320px, calc(100% - 32px));
  margin: 0 auto 82px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.photo-card {
  position: relative;
  min-height: 530px;
  margin: 0;
  overflow: hidden;
  background: rgba(255,255,255,.72);
}
.photo-card > img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 9%;
  mix-blend-mode: multiply;
  transition: transform .6s cubic-bezier(.2,.7,.2,1);
}
.photo-card:hover > img { transform: scale(1.035); }
.photo-card.warm { background: linear-gradient(145deg, #f8ece5, #fff); }
.photo-card.dark { background: linear-gradient(145deg, #e8ecec, #f8f8f6); }
.photo-card.gold { background: linear-gradient(145deg, #f6e9cb, #fff); }
.photo-card figcaption {
  position: absolute;
  left: 20px;
  bottom: 18px;
  padding: 9px 13px;
  border: 1px solid rgba(255,255,255,.9);
  border-radius: 999px;
  background: rgba(255,255,255,.65);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .11em;
  text-transform: uppercase;
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
}
.photo-card.wide {
  grid-column: 1 / -1;
  min-height: 620px;
  background: linear-gradient(120deg, #f0f4f5, #fff 48%, #f4eee8);
}
.duo {
  height: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: center;
  padding: 40px 8% 55px;
}
.duo img { width: 100%; max-height: 500px; object-fit: contain; mix-blend-mode: multiply; }
.photo-card.wide figcaption { left: 28px; }

.process-panel {
  width: min(1120px, calc(100% - 56px));
  margin: 0 auto 96px;
  padding: 32px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid rgba(255,255,255,.82);
  border-radius: 28px;
  background: rgba(255,255,255,.58);
  box-shadow: inset 0 1px 0 #fff, 0 24px 60px rgba(61,71,75,.08);
  -webkit-backdrop-filter: blur(24px) saturate(1.15);
  backdrop-filter: blur(24px) saturate(1.15);
}
.process-panel div { padding: 8px 30px; border-right: 1px solid var(--line); }
.process-panel div:last-child { border: 0; }
.process-panel span { display: block; margin-bottom: 22px; color: var(--gold); font-size: 10px; font-weight: 900; }
.process-panel strong { display: block; margin-bottom: 10px; font-size: 20px; }
.process-panel p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.55; }

.final-frame {
  width: min(1120px, calc(100% - 56px));
  margin: 0 auto 88px;
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  align-items: center;
  gap: 72px;
}
.final-frame > img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: contain;
  padding: 8%;
  background: #fff;
  mix-blend-mode: multiply;
}

.project-end {
  width: min(1120px, calc(100% - 56px));
  margin: 0 auto 42px;
  padding: 30px 0;
  display: flex;
  justify-content: space-between;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  font-size: 13px;
  font-weight: 800;
}
footer { width: min(1120px, calc(100% - 56px)); margin: 0 auto 28px; color: #878d94; font-size: 12px; }

@media (max-width: 760px) {
  .case-bar { padding: 18px; font-size: 9px; }
  .photo-cover { width: 100%; height: 78vh; min-height: 600px; margin-top: 0; }
  .product-stage { top: 10%; right: -14%; width: 110%; height: 58%; }
  .stage-product { width: 44%; }
  .stage-salt { left: 1%; }
  .stage-pepper { left: 29%; }
  .stage-cinnamon { right: 0; }
  .stage-turmeric { display: none; }
  .cover-caption { left: 16px; right: 16px; bottom: 16px; width: auto; padding: 20px; }
  .cover-caption h1 { font-size: 54px; }
  .summary { grid-template-columns: 1fr; gap: 32px; margin: 68px auto; }
  .summary-copy > p { font-size: 16px; }
  .summary dl { grid-template-columns: 1fr; gap: 14px; }
  .photo-grid { grid-template-columns: 1fr; margin-bottom: 64px; }
  .photo-card { min-height: 440px; }
  .photo-card.wide { grid-column: auto; min-height: 720px; }
  .duo { grid-template-columns: 1fr; padding: 36px 12% 70px; }
  .duo img { max-height: 220px; }
  .process-panel { grid-template-columns: 1fr; padding: 20px; margin-bottom: 68px; }
  .process-panel div { padding: 20px 8px; border-right: 0; border-bottom: 1px solid var(--line); }
  .process-panel span { margin-bottom: 12px; }
  .final-frame { grid-template-columns: 1fr; gap: 36px; margin-bottom: 64px; }
  .project-end { gap: 24px; font-size: 11px; }
}
