/* ================================
   TASTE LAYER — Premium harmonization
   Variance 8 · Motion 6 · Density 4
   ================================ */

:root {
  --surface-1: #0d0d0e;
  --surface-2: #131316;
  --surface-3: #1a1a1f;
  --hairline: rgba(255, 255, 255, 0.06);
  --hairline-strong: rgba(255, 255, 255, 0.12);
  --accent: #e63946;
  --accent-soft: rgba(230, 57, 70, 0.12);
  --accent-edge: rgba(230, 57, 70, 0.35);
  --text-mute: rgba(255, 255, 255, 0.55);
  --text-soft: rgba(255, 255, 255, 0.72);
  --shadow-diffuse: 0 30px 60px -25px rgba(0, 0, 0, 0.6),
                    0 12px 24px -12px rgba(0, 0, 0, 0.4);
  --shadow-edge: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  --ease-spring: cubic-bezier(0.16, 1, 0.3, 1);
}

/* ── Navbar overrides — desserrer le menu ── */
.navbar .nav-container {
  max-width: 1440px;
  padding: 0 32px;
  gap: 2rem;
}
.navbar .logo {
  margin-left: 0;
  gap: 14px;
  flex-shrink: 0;
}
.navbar .logo-circle {
  --circle-size: 92px;
  padding: 10px;
  border-width: 1px;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.3);
}
.navbar.scrolled .logo-circle { --circle-size: 76px; padding: 9px; }
.navbar .logo-img { height: 60px; }
.navbar.scrolled .logo-img { height: 50px; }
.navbar .logo-text {
  font-size: 1.15rem;
  letter-spacing: 0.18em;
}
.navbar .nav-links {
  gap: 2.4rem;
  flex: 1;
  justify-content: center;
}
.navbar .nav-link {
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  white-space: nowrap;
}
.navbar .btn-nav {
  padding: 11px 24px;
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  white-space: nowrap;
  flex-shrink: 0;
}

@media (max-width: 1100px) {
  .navbar .nav-links { gap: 1.6rem; }
  .navbar .logo-text { display: none; }
}
@media (max-width: 960px) {
  .navbar .nav-container { padding: 0 20px; }
}

/* ── Page chrome ── */
.page-shell {
  background: var(--surface-1);
  /* padding top assez large pour passer sous le logo flottant (92px circle + 20px nav-padding ≈ 132px) */
  padding: 10rem 0 5rem;
  position: relative;
}
.page-shell::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(70% 60% at 12% 0%, rgba(230, 57, 70, 0.08), transparent 60%),
    radial-gradient(50% 40% at 100% 30%, rgba(255, 255, 255, 0.03), transparent 60%);
  pointer-events: none;
}
.page-shell > .container { position: relative; z-index: 1; }

/* ── Hero asymétrique ── */
.taste-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: clamp(2rem, 6vw, 5rem);
  align-items: end;
  padding-bottom: 4rem;
  border-bottom: 1px solid var(--hairline);
  margin-bottom: 4rem;
}
.taste-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-mute);
  margin-bottom: 1.5rem;
}
.taste-hero-eyebrow::before {
  content: "";
  width: 28px; height: 1px;
  background: var(--accent);
}
.taste-hero-title {
  font-family: var(--font-heading);
  font-size: clamp(2.6rem, 6vw, 4.8rem);
  line-height: 0.95;
  letter-spacing: -0.01em;
  color: #fff;
  margin: 0 0 1.5rem;
}
.taste-hero-title .accent { color: var(--accent); }
.taste-hero-lede {
  color: var(--text-soft);
  font-size: 1.05rem;
  line-height: 1.65;
  max-width: 56ch;
}
.taste-hero-side {
  display: flex; flex-direction: column;
  gap: 1.25rem;
  padding-bottom: 0.5rem;
}
.taste-hero-meta {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  border-top: 1px solid var(--hairline);
  padding-top: 1.5rem;
}
.taste-hero-meta-row {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 1rem;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid var(--hairline);
}
.taste-hero-meta-row:last-child { border-bottom: 0; }
.taste-hero-meta-key {
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-mute);
}
.taste-hero-meta-val {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  letter-spacing: 0.02em;
  color: #fff;
}

@media (max-width: 860px) {
  .taste-hero { grid-template-columns: 1fr; gap: 2rem; }
  .taste-hero-side { padding-bottom: 0; }
}

/* ── Bento grid ── */
.bento {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1.25rem;
}
.bento-tile {
  position: relative;
  background: var(--surface-2);
  border: 1px solid var(--hairline);
  border-radius: 18px;
  padding: 2rem;
  overflow: hidden;
  box-shadow: var(--shadow-edge);
  transition: border-color 0.5s var(--ease-spring),
              transform 0.5s var(--ease-spring);
}
.bento-tile::after {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(120% 80% at 0% 0%, rgba(255, 255, 255, 0.04), transparent 60%);
  pointer-events: none;
  opacity: 0.6;
  transition: opacity 0.5s var(--ease-spring);
}
.bento-tile:hover {
  border-color: var(--hairline-strong);
  transform: translateY(-2px);
}
.bento-tile:hover::after { opacity: 1; }

.bento-tile.span-3 { grid-column: span 3; }
.bento-tile.span-4 { grid-column: span 4; }
.bento-tile.span-2 { grid-column: span 2; }
.bento-tile.span-6 { grid-column: span 6; }

@media (max-width: 860px) {
  .bento { grid-template-columns: 1fr; gap: 1rem; }
  .bento-tile.span-2,
  .bento-tile.span-3,
  .bento-tile.span-4,
  .bento-tile.span-6 { grid-column: span 1; }
  .bento-tile { padding: 1.5rem; }
}

.bento-eyebrow {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 1rem;
  position: relative;
  z-index: 1;
}
.bento-title {
  font-family: var(--font-heading);
  font-size: 1.7rem;
  letter-spacing: 0.02em;
  color: #fff;
  margin: 0 0 0.85rem;
  line-height: 1.05;
  position: relative;
  z-index: 1;
}
.bento-body {
  color: var(--text-soft);
  font-size: 0.95rem;
  line-height: 1.65;
  position: relative;
  z-index: 1;
}
.bento-body p + p { margin-top: 0.85rem; }
.bento-body a { color: #fff; border-bottom: 1px solid var(--accent-edge); transition: border-color 0.3s; }
.bento-body a:hover { border-color: var(--accent); }

/* ── Split sections ── */
.taste-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.3fr);
  gap: clamp(2rem, 5vw, 4rem);
  margin: 4rem 0;
  align-items: start;
}
.taste-split.flip { grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr); }
.taste-split.flip .taste-split-aside { order: 2; }

.taste-split-aside {
  position: sticky;
  top: 7rem;
}
.taste-split-eyebrow {
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 1rem;
  display: block;
}
.taste-split-title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1;
  letter-spacing: 0.01em;
  color: #fff;
  margin-bottom: 1rem;
}
.taste-split-lede {
  color: var(--text-mute);
  font-size: 0.95rem;
  line-height: 1.6;
  max-width: 38ch;
}

@media (max-width: 860px) {
  .taste-split,
  .taste-split.flip { grid-template-columns: 1fr; }
  .taste-split-aside { position: static; }
  .taste-split.flip .taste-split-aside { order: 0; }
}

/* ── Prose (long-form) ── */
.taste-prose { max-width: 68ch; }
.taste-prose h2 {
  font-family: var(--font-heading);
  font-size: 1.9rem;
  letter-spacing: 0.02em;
  color: #fff;
  margin: 2.5rem 0 1rem;
  display: flex; align-items: center; gap: 0.8rem;
}
.taste-prose h2::before {
  content: "";
  width: 18px; height: 1px;
  background: var(--accent);
}
.taste-prose h3 {
  font-family: var(--font-heading);
  font-size: 1.3rem;
  letter-spacing: 0.03em;
  color: #fff;
  margin: 1.75rem 0 0.6rem;
}
.taste-prose p {
  color: var(--text-soft);
  font-size: 1rem;
  line-height: 1.75;
  margin-bottom: 1rem;
}
.taste-prose ul {
  list-style: none;
  padding-left: 0;
  margin: 0.5rem 0 1.25rem;
}
.taste-prose li {
  position: relative;
  padding-left: 1.4rem;
  color: var(--text-soft);
  line-height: 1.65;
  margin-bottom: 0.5rem;
}
.taste-prose li::before {
  content: "";
  position: absolute;
  left: 0; top: 0.7rem;
  width: 6px; height: 1px;
  background: var(--accent);
}
.taste-prose em { color: #fff; font-style: italic; }
.taste-prose strong { color: #fff; }
.taste-prose a {
  color: #fff;
  border-bottom: 1px solid var(--accent-edge);
  transition: border-color 0.3s, color 0.3s;
}
.taste-prose a:hover { color: var(--accent); border-color: var(--accent); }

/* ── Definition list (bento-style data) ── */
.taste-defs {
  display: grid;
  gap: 0;
  margin: 0;
}
.taste-defs > div {
  display: grid;
  grid-template-columns: 11rem 1fr;
  gap: 1.5rem;
  padding: 1rem 0;
  border-top: 1px solid var(--hairline);
}
.taste-defs > div:last-child { border-bottom: 1px solid var(--hairline); }
.taste-defs dt {
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-mute);
  padding-top: 0.15rem;
}
.taste-defs dd {
  color: #fff;
  font-size: 0.98rem;
  line-height: 1.55;
  margin: 0;
}
.taste-defs dd a { color: #fff; border-bottom: 1px solid var(--accent-edge); }
.taste-defs dd a:hover { color: var(--accent); border-color: var(--accent); }

@media (max-width: 640px) {
  .taste-defs > div { grid-template-columns: 1fr; gap: 0.35rem; }
}

/* ── Index nav (chip pills) ── */
.taste-chips {
  display: flex; flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0 0 3rem;
}
.taste-chips a {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.55rem 1rem;
  border-radius: 999px;
  border: 1px solid var(--hairline);
  background: var(--surface-2);
  color: var(--text-soft);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: border-color 0.3s var(--ease-spring),
              color 0.3s var(--ease-spring),
              transform 0.3s var(--ease-spring);
}
.taste-chips a:hover {
  border-color: var(--accent-edge);
  color: #fff;
  transform: translateY(-1px);
}
.taste-chips a::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent);
}

/* ── Stat row ── */
.taste-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  margin: 2.5rem 0;
}
.taste-stats > div {
  padding: 1.5rem 1.25rem;
  border-right: 1px solid var(--hairline);
}
.taste-stats > div:last-child { border-right: 0; }
.taste-stat-num {
  font-family: var(--font-heading);
  font-size: 2.4rem;
  line-height: 1;
  letter-spacing: 0.02em;
  color: #fff;
}
.taste-stat-num .accent { color: var(--accent); }
.taste-stat-label {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-mute);
  margin-top: 0.5rem;
}
@media (max-width: 720px) {
  .taste-stats { grid-template-columns: repeat(2, 1fr); }
  .taste-stats > div:nth-child(2) { border-right: 0; }
  .taste-stats > div:nth-child(1),
  .taste-stats > div:nth-child(2) { border-bottom: 1px solid var(--hairline); }
}

/* ── Form refinement ── */
.taste-form {
  background: var(--surface-2);
  border: 1px solid var(--hairline);
  border-radius: 22px;
  padding: 2rem;
  box-shadow: var(--shadow-diffuse), var(--shadow-edge);
}
.taste-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}
.taste-form-grid .full { grid-column: 1 / -1; }
.taste-field { display: grid; gap: 0.4rem; }
.taste-field label {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-mute);
}
.taste-field input,
.taste-field select,
.taste-field textarea {
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: 10px;
  padding: 0.85rem 1rem;
  color: #fff;
  font-family: var(--font-body);
  font-size: 0.95rem;
  transition: border-color 0.3s var(--ease-spring),
              background 0.3s var(--ease-spring);
}
.taste-field input:focus,
.taste-field select:focus,
.taste-field textarea:focus {
  outline: none;
  border-color: var(--accent-edge);
  background: var(--surface-3);
}
.taste-field textarea { resize: vertical; min-height: 110px; }

@media (max-width: 640px) {
  .taste-form-grid { grid-template-columns: 1fr; }
  .taste-form { padding: 1.5rem; }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}
