@import url("fonts/fonts.css");

:root {
  --cream: oklch(0.97 0.018 92);
  --cream-dark: oklch(0.925 0.045 102);
  --forest: oklch(0.36 0.07 145);
  --forest-deep: oklch(0.27 0.055 150);
  --leaf: oklch(0.68 0.14 132);
  --sun: oklch(0.85 0.14 83);
  --coral: oklch(0.65 0.16 34);
  --body: "DM Sans", Arial, sans-serif;
  --display: "DM Serif Display", Georgia, serif;
  --hand: "Gaegu", cursive;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { background: var(--cream); color: var(--forest-deep); font-family: var(--body); margin: 0; }
img { display: block; max-width: 100%; }
a { color: inherit; }
.wrap { margin: 0 auto; max-width: 1180px; padding-left: 24px; padding-right: 24px; }
.top { background: var(--forest-deep); color: var(--cream); }
.nav { align-items: center; display: flex; justify-content: space-between; min-height: 78px; }
.brand { align-items: center; display: flex; font-family: var(--display); font-size: 1.25rem; gap: 10px; letter-spacing: -.03em; text-decoration: none; }
.brand svg { width: 36px; }
.back { border: 1px solid oklch(0.97 0.018 92 / .38); border-radius: 999px; font-size: .82rem; font-weight: 800; padding: 11px 15px; text-decoration: none; transition: background .25s ease-out, color .25s ease-out; }
.back:hover { background: var(--sun); color: var(--forest-deep); }
.hero { background: var(--forest-deep); color: var(--cream); padding: 54px 0 82px; }
.hero-grid { align-items: center; display: grid; gap: 52px; grid-template-columns: 1fr .88fr; }
.eyebrow { color: var(--sun); display: block; font-size: .72rem; font-weight: 800; letter-spacing: .15em; margin-bottom: 14px; text-transform: uppercase; }
h1, h2, h3 { font-family: var(--display); font-weight: 400; letter-spacing: -.055em; margin: 0; }
h1 { font-size: clamp(4.8rem, 9vw, 8.5rem); line-height: .84; }
h2 { color: var(--forest-deep); font-size: clamp(3.3rem, 6vw, 5.7rem); line-height: .88; }
h3 { color: var(--coral); font-size: 1.75rem; line-height: .98; }
.hero p { line-height: 1.7; margin: 20px 0 0; max-width: 600px; }
.hero img { aspect-ratio: 4 / 3.6; border-radius: 28px 88px 28px 88px; object-fit: cover; }
.section { padding: clamp(72px, 9vw, 112px) 0; }
.intro { display: grid; gap: 34px; grid-template-columns: 1fr .75fr; }
.intro p { font-size: 1.06rem; line-height: 1.72; margin: 15px 0 0; max-width: 690px; }
.scribble { color: var(--coral); font-family: var(--hand); font-size: 1.55rem; line-height: .9; margin: 0 0 12px; }
.note { align-self: start; background: var(--sun); border-radius: 24px 68px 24px 68px; color: var(--forest-deep); font-family: var(--hand); font-size: 1.7rem; line-height: .94; padding: 28px 25px; transform: rotate(2deg); }
.cards { display: grid; gap: 14px; grid-template-columns: repeat(3, 1fr); margin-top: 40px; }
.card { background: var(--cream-dark); border-radius: 21px; padding: 25px 22px; }
.card b { color: var(--coral); display: block; font-family: var(--display); font-size: 1.45rem; letter-spacing: -.04em; margin-bottom: 8px; }
.card p { line-height: 1.6; margin: 0; }
.timeline { display: grid; grid-template-columns: repeat(5, 1fr); margin-top: 42px; }
.day { border-top: 2px solid var(--forest); padding: 19px 14px 5px 0; position: relative; }
.day + .day { padding-left: 15px; }
.day::before { background: var(--coral); border: 4px solid var(--cream); border-radius: 50%; content: ""; height: 17px; left: 0; position: absolute; top: -10px; width: 17px; }
.day + .day::before { left: 15px; }
.day b { color: var(--coral); display: block; font-family: var(--display); font-size: 1.35rem; margin-bottom: 7px; }
.day p { font-size: .9rem; line-height: 1.52; margin: 0; }
.split { align-items: stretch; display: grid; grid-template-columns: 1fr 1fr; }
.split img { height: 100%; min-height: 450px; object-fit: cover; width: 100%; }
.split-copy { background: var(--forest); color: var(--cream); padding: clamp(50px, 7vw, 90px); }
.split-copy h2 { color: var(--cream); }
.split-copy p { line-height: 1.7; margin: 18px 0; }
.gourmello-brand {
  align-items: center;
  background: var(--cream-dark);
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 520px;
  padding: clamp(42px, 7vw, 92px);
  text-align: center;
  transition: box-shadow .3s ease-out, transform .3s cubic-bezier(.16,1,.3,1);
}
.gourmello-brand:hover { box-shadow: inset 0 0 0 1px oklch(0.36 0.07 145 / .16), 0 18px 38px oklch(0.27 0.055 150 / .12); transform: translateY(-4px); }
.gourmello-brand img { height: 92px; min-height: 0; object-fit: contain; width: auto; }
.gourmello-brand strong { color: var(--forest-deep); display: block; font-family: var(--display); font-size: clamp(3rem, 6vw, 5.5rem); font-weight: 400; letter-spacing: -.06em; line-height: .9; margin-top: 18px; }
.gourmello-brand span { color: var(--coral); display: block; font-size: .72rem; font-weight: 800; letter-spacing: .14em; margin-top: 9px; text-transform: uppercase; }
.gourmello-facts { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin-top: 26px; max-width: 440px; }
.gourmello-facts b { border: 1px solid oklch(0.36 0.07 145 / .22); border-radius: 999px; color: var(--forest-deep); font-size: .78rem; padding: 9px 11px; }
.gallery { display: grid; gap: 12px; grid-template-columns: 1.2fr .8fr .8fr; margin-top: 35px; }
.gallery img { border-radius: 18px; height: 240px; object-fit: cover; width: 100%; }
.cta { background: var(--coral); color: var(--cream); padding: 52px 0; }
.cta-grid { align-items: center; display: flex; gap: 28px; justify-content: space-between; }
.cta h2 { color: var(--cream); font-size: clamp(3.2rem, 6vw, 5rem); }
.button { background: var(--sun); border-radius: 999px; color: var(--forest-deep); display: inline-block; font-size: .85rem; font-weight: 800; padding: 15px 19px; text-decoration: none; }
.concept-layout { display: grid; gap: 34px; grid-template-columns: 260px 1fr; }
.concept-nav { align-self: start; background: var(--cream-dark); border-radius: 24px; display: grid; gap: 7px; padding: 14px; position: sticky; top: 18px; }
.concept-nav a { border-radius: 999px; color: var(--forest-deep); font-size: .83rem; font-weight: 800; padding: 10px 12px; text-decoration: none; }
.concept-nav a:hover { background: var(--sun); }
.concept-stack { display: grid; gap: 12px; }
.concept-chapter { background: white; border: 1px solid oklch(0.36 0.07 145 / .16); border-radius: 22px; box-shadow: 0 12px 28px oklch(0.27 0.055 150 / .08); overflow: hidden; }
.concept-chapter summary { color: var(--forest-deep); cursor: pointer; font-family: var(--display); font-size: clamp(1.7rem, 3vw, 2.35rem); letter-spacing: -.04em; list-style: none; padding: 22px 24px; }
.concept-chapter summary::-webkit-details-marker { display: none; }
.concept-chapter summary::after { color: var(--coral); content: "+"; float: right; font-family: var(--body); font-size: 1.4rem; font-weight: 800; }
.concept-chapter[open] summary::after { content: "-"; }
.concept-body { border-top: 1px solid oklch(0.36 0.07 145 / .12); padding: 8px 24px 24px; }
.concept-body p { line-height: 1.72; margin: 14px 0; }
.concept-article { margin: 0 auto; max-width: 980px; }
.concept-jumpbar {
  background: var(--cream-dark);
  border-radius: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 36px;
  padding: 14px;
}
.concept-jumpbar a {
  background: oklch(0.97 0.018 92 / .72);
  border-radius: 999px;
  color: var(--forest-deep);
  font-size: .78rem;
  font-weight: 800;
  padding: 10px 12px;
  text-decoration: none;
}
.concept-jumpbar a:hover { background: var(--sun); }
.concept-section {
  border-top: 1px solid oklch(0.36 0.07 145 / .18);
  padding: 36px 0 26px;
  scroll-margin-top: 24px;
}
.concept-section:first-of-type { border-top: 0; padding-top: 0; }
.concept-section h2 {
  color: var(--forest-deep);
  font-size: clamp(2.35rem, 4.5vw, 4.6rem);
  line-height: .9;
  margin-bottom: 18px;
  overflow-wrap: anywhere;
}
.concept-section p {
  color: var(--forest-deep);
  font-size: 1.03rem;
  line-height: 1.78;
  margin: 14px 0;
  max-width: 840px;
  overflow-wrap: anywhere;
}
footer { background: var(--forest-deep); color: var(--cream); font-size: .8rem; padding: 24px 0; }
.footer-row { display: flex; flex-wrap: wrap; gap: 15px; justify-content: space-between; }
.footer-row a { color: var(--cream); text-decoration: underline; text-underline-offset: 2px; }
@media (max-width: 800px) {
  .hero-grid, .intro, .split { grid-template-columns: 1fr; }
  .hero-grid > * { min-width: 0; }
  h1 { overflow-wrap: anywhere; }
  .hero img { width: 100%; }
  .concept-layout { grid-template-columns: 1fr; }
  .concept-nav { position: static; }
  .hero { padding: 35px 0 58px; }
  h1 { font-size: clamp(4.3rem, 18vw, 6rem); }
  .cards, .gallery { grid-template-columns: 1fr; }
  .timeline { grid-template-columns: 1fr; }
  .day, .day + .day { border-left: 2px solid var(--forest); border-top: 0; padding: 0 0 22px 22px; }
  .day::before, .day + .day::before { left: -9px; top: 0; }
  .split img { min-height: 290px; }
  .gourmello-brand { min-height: 310px; padding: 48px 36px; }
  .gallery img { height: 215px; }
  .cta-grid { align-items: start; flex-direction: column; }
}
