/* Good Allure — sections (home + pages) */

/* ============ HERO ============ */
.hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; overflow: hidden; padding-bottom: clamp(40px, 7vw, 90px); }
.hero__bg { position: absolute; inset: 0; z-index: 0; }
.hero__bg img { width: 100%; height: 120%; object-fit: cover; }
.hero__bg:empty, .hero:has(.hero__bg:empty) { background: linear-gradient(160deg, #cdbf9e, #a98f63); }
.hero__veil { position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(20,18,12,.28) 0%, transparent 30%, rgba(20,18,12,.15) 60%, rgba(20,18,12,.62) 100%); }
.hero__inner { z-index: 2; color: var(--paper); width: 100%; }
.hero__eyebrow { color: var(--paper); }
.hero__title { font-size: var(--step-5); color: var(--paper); margin: .3em 0 0; text-shadow: 0 1px 40px rgba(20,18,12,.25); }
.hero__meta { display: flex; gap: clamp(20px, 4vw, 56px); margin-top: clamp(28px, 4vw, 48px); flex-wrap: wrap; }
.hero__meta .stamp { color: rgba(242,235,218,.85); }
.hero__cue { position: absolute; right: var(--gutter); bottom: clamp(40px, 7vw, 90px); z-index: 2; display: flex; align-items: center; gap: 12px; color: var(--paper); }
.hero__cue-line { width: 1px; height: 56px; background: linear-gradient(var(--paper), transparent); animation: cue 2.2s var(--ease) infinite; transform-origin: top; }
@keyframes cue { 0% { transform: scaleY(0); } 40% { transform: scaleY(1); } 100% { transform: scaleY(0); transform-origin: bottom; } }
@media (max-width: 860px) { .hero__cue { display: none; } }

/* ============ MANIFESTE ============ */
.manifeste__p .drop { float: left; font-family: var(--display); font-weight: 300; font-size: 3.6em; line-height: .72; padding: .04em .1em 0 0; color: var(--terra); }
.manifeste__img { overflow: hidden; }
@media (max-width: 860px) {
  .manifeste__text { grid-column: 1 / -1 !important; }
  .manifeste__img { grid-column: 1 / -1 !important; margin-top: 40px; }
}

/* ============ PILIERS ============ */
.pillar { display: grid; grid-template-columns: 5fr 7fr; gap: clamp(28px, 5vw, 80px); align-items: center; padding-block: clamp(40px, 6vw, 90px); border-top: 1px solid var(--rule); }
.pillar:last-child { border-bottom: 1px solid var(--rule); }
.pillar--rev .pillar__media { order: 2; }
.pillar__media { overflow: hidden; }
.pillar__body .split-num { display: block; margin-bottom: .4em; }
.pillar__title { font-size: var(--step-3); margin: .1em 0 .5em; }
@media (max-width: 860px) {
  .pillar { grid-template-columns: 1fr; gap: 24px; }
  .pillar--rev .pillar__media { order: 0; }
}

/* ============ LOOKBOOK horizontal ============ */
.hscroll { position: relative; overflow: hidden; padding-block: clamp(60px,9vw,120px); }
.hscroll__head { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; margin-bottom: clamp(28px,4vw,48px); }
.hscroll__track { display: flex; gap: clamp(20px, 3vw, 48px); padding-inline: var(--gutter); width: max-content; align-items: center; }
.shot { width: clamp(240px, 30vw, 420px); flex: 0 0 auto; margin: 0; }
.shot--wide { width: clamp(360px, 46vw, 680px); }
@media (max-width: 860px) {
  .hscroll__track { width: auto; flex-wrap: nowrap; overflow-x: auto; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; padding-bottom: 12px; }
  .shot { scroll-snap-align: center; width: 72vw; }
  .shot--wide { width: 82vw; }
}

/* ============ CITRON ============ */
.citron { position: relative; overflow: hidden; background: var(--night); padding-block: clamp(120px, 20vw, 280px); }
.citron__bg { position: absolute; inset: 0; z-index: 0; opacity: .55; }
.citron__bg img { width: 100%; height: 120%; object-fit: cover; filter: saturate(.9) contrast(1.05); }
.citron::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(20,18,12,.85), rgba(20,18,12,.35)); z-index: 1; }
.citron__inner { position: relative; z-index: 2; }

/* ============ CHIFFRES ============ */
.ethos__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px, 3vw, 40px); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.ethos__cell { padding: clamp(28px,4vw,52px) 0; text-align: center; border-right: 1px solid var(--rule); display: flex; flex-direction: column; gap: .6em; }
.ethos__cell:last-child { border-right: 0; }
.ethos__num { font-size: var(--step-4); line-height: 1; }
@media (max-width: 720px) { .ethos__grid { grid-template-columns: repeat(2, 1fr); } .ethos__cell:nth-child(2) { border-right: 0; } .ethos__cell:nth-child(1), .ethos__cell:nth-child(2) { border-bottom: 1px solid var(--rule); } }

/* ============ ECOSYSTEME ============ */
.eco__list { list-style: none; margin: clamp(32px,5vw,56px) 0 0; padding: 0; }
.eco__item { display: grid; grid-template-columns: 1fr auto auto; align-items: baseline; gap: clamp(16px,3vw,40px); padding: clamp(20px,3vw,34px) 0; border-top: 1px solid var(--rule); transition: padding-left .4s var(--ease), color .4s var(--ease); }
.eco__item:last-child { border-bottom: 1px solid var(--rule); }
.eco__item:hover { padding-left: clamp(12px,2vw,28px); color: var(--terra); }
.eco__name { font-family: var(--display); font-weight: 360; font-size: var(--step-2); }
.eco__arrow { font-family: var(--display); transition: transform .4s var(--ease); }
.eco__item:hover .eco__arrow { transform: translateX(10px); }
@media (max-width: 620px) { .eco__item { grid-template-columns: 1fr auto; } .eco__item .stamp { display: none; } }

/* ============ JOURNAL ============ */
.journal__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px,3vw,40px); }
.jentry { display: block; }
.jentry .media { margin-bottom: 1em; }
.jentry__cat { display: inline-block; margin-bottom: .5em; }
.jentry__t { font-size: var(--step-1); font-weight: 360; line-height: 1.05; transition: color .3s var(--ease); }
.jentry:hover .jentry__t { color: var(--terra); }
@media (max-width: 860px) { .journal__grid { grid-template-columns: 1fr; gap: 40px; } }

/* ============ PAGES (intro commune) ============ */
.page-hero { padding-top: clamp(140px, 20vh, 240px); padding-bottom: clamp(40px, 6vw, 80px); }
.page-hero__title { font-size: var(--step-5); margin: .2em 0 0; }
.page-hero .lead { margin-top: 1.2em; }
.prose { max-width: 60ch; }
.prose p { margin-bottom: 1.4em; }
.prose p:first-of-type::first-letter { font-family: var(--display); font-size: 3.4em; float: left; line-height: .72; padding: .05em .12em 0 0; color: var(--terra); }
