/* Components production — direction luxe nocturne, base 1920. */

/* Marque */
.brand {
  display: inline-flex;
  align-items: flex-start;
  gap: clamp(18px, 1.2vw, 23px);
  color: var(--color-text-ivory);
  text-decoration: none;
  text-transform: uppercase;
  text-shadow: 0 2px 22px rgba(0, 0, 0, .78);
}
.brand__mark {
  flex: 0 0 clamp(92px, 5.6vw, 108px);
  inline-size: clamp(92px, 5.6vw, 108px);
  block-size: clamp(112px, 6.4vw, 124px);
}
.brand__logo-mark {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
  filter: drop-shadow(0 0 14px rgba(184, 134, 69, .14));

}
@media (min-width: 1200px){
	.brand__logo-mark {
		  object-position: center -16%;
	}
}

.brand__text {
  display: block;
  padding-block-start: .05em;
  inline-size: clamp(230px, 16.15vw, 310px);
  color: var(--color-text-ivory);
  font-family: var(--font-logo);
  font-size: clamp(32px, 2.24vw, 43px);
  font-weight: 400;
  line-height: 1.16;
  letter-spacing: .112em;
}
.brand__line { display: block; white-space: nowrap; }

/* Boutons */
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-inline-size: 0;
  min-block-size: var(--tap-target-min);
  padding: 0 var(--space-button-x);
  color: var(--color-gold-light);
  font-family: var(--font-cta);
  font-size: var(--type-cta-ref);

  line-height: var(--type-cta-line);
  letter-spacing: var(--type-cta-tracking);
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  border: var(--border-cta);
  border-radius: var(--radius-button);
  background: rgba(5, 4, 3, .18);
  box-shadow: inset 0 0 0 1px rgba(214, 168, 102, .035);
  transition: color var(--motion-duration-button) var(--motion-ease-premium), border-color var(--motion-duration-button) var(--motion-ease-premium), background-color var(--motion-duration-button) var(--motion-ease-premium), box-shadow var(--motion-duration-button) var(--motion-ease-premium), transform var(--motion-duration-button) var(--motion-ease-premium);
}
.button--header { padding-inline: clamp(18px, 1.35vw, 26px); font-size: clamp(10px, .63vw, 12px); letter-spacing: .19em; }
.button:hover,
.button:focus-visible { color: var(--color-text-ivory); border-color: rgba(214, 168, 102, .92); background: rgba(214, 168, 102, .08); box-shadow: 0 0 30px rgba(214, 168, 102, .08); }
.button:active { transform: translateY(var(--state-active-press-y)); }
.hero__actions .button--primary::after { content: "☰"; margin-inline-start: clamp(16px, 1vw, 20px); font-size: .9em; letter-spacing: 0; opacity: .72; }

/* Textes */
.eyebrow,
.collection-heading__eyebrow,
.signatures__eyebrow,
.invitation__eyebrow {
  color: var(--color-gold-main);
  font-family: var(--font-label);
  font-size: var(--type-label-ref);
  font-weight: var(--type-label-weight);
  line-height: var(--type-label-line);
  letter-spacing: var(--type-label-tracking);
  text-transform: uppercase;
}
.hero__eyebrow { margin-block-end: clamp(26px, 1.88vw, 36px); letter-spacing: .245em; }
.hero__title {
  max-inline-size: 100%;
  color: var(--color-text-ivory);
  font-family: var(--font-hero-title);
  font-size: var(--type-hero-size-ref);
  font-weight: var(--type-hero-weight);
  line-height: var(--type-hero-line);
  letter-spacing: var(--type-hero-tracking);
  text-transform: uppercase;
  text-shadow: 0 14px 40px rgba(0, 0, 0, .88);
}
.hero__title span {
  margin-block-start: clamp(16px, 1.05vw, 20px);
  color: var(--color-gold-main);
  font-family: var(--font-label);
  font-size: clamp(18px, 1.35vw, 26px);
  font-weight: 300;
  line-height: 1.2;
  letter-spacing: .42em;
}
.hero__body {
  --flow-space: clamp(16px, 1.05vw, 20px);
  color: rgba(232, 220, 203, .78);
  font-family: var(--font-body);
  font-size: var(--type-body-ref);
  font-weight: 300;
  line-height: var(--type-body-line);
}
.hero__credit {
  color: rgba(184, 134, 69, .88);
  font-family: var(--font-serif-display);
  font-size: clamp(15px, .94vw, 18px);
  font-style: italic;
  line-height: 1.25;
}

/* Bouton film */
.video-trigger {
  display: inline-flex;
  align-items: center;
  gap: clamp(16px, 1.35vw, 26px);
  min-inline-size: 0;
  color: var(--color-gold-light);
  font-family: var(--font-label);
  font-size: clamp(10px, .68vw, 13px);
  font-weight: var(--type-cta-weight);
  letter-spacing: .20em;
  text-transform: uppercase;
  transition: color var(--motion-duration-button) var(--motion-ease-premium), transform var(--motion-duration-button) var(--motion-ease-premium);
}
.video-trigger__icon {
  position: relative;
  display: inline-grid;
  flex: 0 0 var(--cta-hero-h-ref);
  place-items: center;
  inline-size: var(--cta-hero-h-ref);
  block-size: var(--cta-hero-h-ref);
  border: var(--border-cta);
  border-radius: 50%;
  background: rgba(5, 4, 3, .28);
  box-shadow: 0 0 26px rgba(214, 168, 102, .08);
}
.video-trigger__icon::before { content: ""; inline-size: 0; block-size: 0; margin-inline-start: 4px; border-block: 7px solid transparent; border-inline-start: 11px solid currentColor; }
.video-trigger__label { white-space: nowrap; }
.video-trigger:hover,
.video-trigger:focus-visible,
.video-trigger[aria-expanded="true"] { color: var(--color-text-ivory); }
.video-trigger:hover .video-trigger__icon,
.video-trigger:focus-visible .video-trigger__icon,
.video-trigger[aria-expanded="true"] .video-trigger__icon { border-color: rgba(214, 168, 102, .92); background: rgba(214, 168, 102, .08); box-shadow: 0 0 30px rgba(214, 168, 102, .12); }

/* Intro */
.intro-split__quote {
  color: var(--color-gold-light);
  font-family: var(--font-serif-display);
  font-size: clamp(28px, 1.98vw, 38px);
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: .135em;
  text-transform: uppercase;
}
.intro-split__quote p::first-line { color: var(--color-text-ivory); }
.intro-split__ornament { display: block; inline-size: clamp(70px, 4.7vw, 90px); block-size: 1px; margin: clamp(24px, 1.7vw, 32px) auto 0; background: linear-gradient(90deg, transparent, rgba(214, 168, 102, .86), transparent); }
.intro-split__copy { --flow-space: clamp(12px, .78vw, 15px); color:rgba(184, 170, 150, 0.99); font-family: var(--font-body); font-size: clamp(13px, .78vw, 15px); font-weight: 300; line-height: 1.74; }

/* Signatures */
.signatures__panel {
  color: var(--color-text-main);
  border: var(--border-panel);
  border-radius: var(--radius-panel);
  background:
    linear-gradient(180deg, rgba(232, 220, 203, .045), rgba(214, 168, 102, .022)),
    rgba(5, 4, 3, .20);
  -webkit-backdrop-filter: brightness(1.08) saturate(1.02);
  backdrop-filter: brightness(0.55) saturate(1.02) blur(0.5px);
  box-shadow:
    inset 0 0 0 1px rgba(214, 168, 102, .055),
    0 22px 70px rgba(0, 0, 0, .44);
}
.signatures__panel::before,
.signatures__panel::after { content: ""; position: absolute; z-index: 3; inline-size: clamp(54px, 4.4vw, 84px); block-size: clamp(26px, 2.1vw, 40px); pointer-events: none; }
.signatures__panel::before { inset-inline-start: -1px; inset-block-start: -1px; border-block-start: 1px solid rgba(214, 168, 102, .68); border-inline-start: 1px solid rgba(214, 168, 102, .68); border-start-start-radius: 24px; }
.signatures__panel::after { inset-inline-end: -1px; inset-block-end: -1px; border-block-end: 1px solid rgba(214, 168, 102, .68); border-inline-end: 1px solid rgba(214, 168, 102, .68); border-end-end-radius: 24px; }
.signatures__eyebrow { display: inline-flex; align-items: center; gap: clamp(28px, 2.1vw, 40px); letter-spacing: .31em; }
.signatures__eyebrow::before,
.signatures__eyebrow::after { content: "✦"; font-size: .8em; opacity: .86; }
.signature-item__icon {
  position: relative;
  display: grid;
  place-items: center;
  inline-size: var(--ornament-circle-icon);
  block-size: var(--ornament-circle-icon);
  margin: 0 auto clamp(22px, 1.72vw, 33px);
  color: var(--color-gold-main);
  border: 1px solid rgba(184, 134, 69, .48);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(184, 134, 69, .055), transparent 66%);
  box-shadow: inset 0 0 0 1px rgba(214, 168, 102, .04), 0 0 26px rgba(184, 134, 69, .08);
}
.signature-item__icon::before { content: ""; inline-size: 44%; block-size: 44%; opacity: .72; background: center / contain no-repeat; }
.signature-item[data-signature="expertise"] .signature-item__icon::before {
  background-image: url("../assets/icons/shaker.svg");
  transform: scale(2);
}
.signature-item[data-signature="rarete"] .signature-item__icon::before {
  background-image: url("../assets/icons/diamond.svg");
  transform: scale(2); 
}
.signature-item[data-signature="matieres-nobles"] .signature-item__icon::before {
  background-image: url("../assets/icons/noble.svg");
  transform: scale(2);
}
.signature-item[data-signature="mise-en-scene"] .signature-item__icon::before {
  background-image: url("../assets/icons/mise.svg");
  transform: scale(2);
}
.signature-item[data-signature="sur-mesure"] .signature-item__icon::before {
  background-image: url("../assets/icons/mesure.svg");
  transform: scale(2);
}
.signature-item[data-signature="souvenir-social"] .signature-item__icon::before {
  background-image: url("../assets/icons/social.svg");
  transform: scale(2);
}
.signature-item__index { display: block; margin-block-end: clamp(8px, .62vw, 12px); color: var(--color-gold-main); font-family: var(--font-card-index); font-size: clamp(16px, .94vw, 18px); line-height: 1; letter-spacing: .08em; }
.signature-item__title { margin-block-end: clamp(10px, .73vw, 14px); color: var(--color-gold-main); font-family: var(--font-signature-title); font-size: var(--type-signature-title-ref); font-weight: 500; line-height: 1.22; letter-spacing: .16em; text-transform: uppercase; }
.signature-item__text { max-inline-size: 170px; margin-inline: auto; color: rgba(232, 220, 203, .84); font-family: var(--font-body); font-size: clamp(12px, .73vw, 14px); font-weight: 300; line-height: 1.5; }

/* Collection */
.collection-heading__title { color: var(--color-text-ivory); font-family: var(--font-section-title); font-size: var(--type-section-title-ref); font-weight: 500; line-height: 1; letter-spacing: .075em; text-transform: uppercase; }
.collection-heading__text { color: rgba(184, 170, 150, .92); font-size: clamp(11px, .68vw, 13px); line-height: 1.25; }
.collection-heading__control { display: grid; place-items: center; min-inline-size: 44px; min-block-size: 44px; inline-size: 44px; block-size: 44px; color: var(--color-gold-light); font-size: 38px; line-height: 1; opacity: .68; transition: color var(--motion-duration-button) var(--motion-ease-premium), opacity var(--motion-duration-button) var(--motion-ease-premium); }
.collection-heading__control:disabled { cursor: default; opacity: .28; }
.collection-heading__control:not(:disabled):hover,
.collection-heading__control:not(:disabled):focus-visible { color: var(--color-text-ivory); opacity: 1; }
.collection-card__article { color: var(--color-text-ivory); border: var(--border-card); border-radius: var(--radius-card); background: rgba(5, 4, 3, .78); box-shadow: 0 24px 60px rgba(0, 0, 0, .48); transition: border-color var(--motion-duration-button) var(--motion-ease-premium), box-shadow var(--motion-duration-button) var(--motion-ease-premium), transform var(--motion-duration-button) var(--motion-ease-premium); }
.collection-card__media::after { content: ""; position: absolute; inset: 0; }
.collection-card__overlay { background: radial-gradient(circle at 50% 24%, rgba(214,168,102,.08), transparent 58%), linear-gradient(180deg, rgba(0,0,0,.04) 0%, rgba(0,0,0,.08) 36%, rgba(5,4,3,.46) 66%, rgba(5,4,3,.88) 86%, rgba(5,4,3,.98) 100%); }
.collection-card__index { position: absolute; inset-inline-start: var(--space-card-pad-x); inset-block-start: clamp(18px, 1.15vw, 22px); z-index: 3; color: rgba(232, 220, 203, .92); font-family: var(--font-card-index); font-size: var(--type-card-index-ref); line-height: 1; letter-spacing: .04em; text-shadow: 0 3px 14px rgba(0,0,0,.76); }
.collection-card__title { margin-block-start: 0; color: var(--color-text-ivory); font-family: var(--font-card-title); font-size: var(--type-card-title-ref); font-weight: 500; line-height: 1.02; letter-spacing: .008em; text-shadow: 0 3px 14px rgba(0,0,0,.76); }
.collection-card__text { margin-block-start: clamp(10px, .72vw, 14px); color: rgba(184,170,150,.96); font-family: var(--font-body); font-size: clamp(12px, .78vw, 15px); font-weight: 300; line-height: 1.46; }
.collection-card__detail { max-block-size: 0; margin: 0; overflow: hidden; color: rgba(214,168,102,.82); font-family: var(--font-body); font-size: clamp(11px, .68vw, 13px); line-height: 1.38; opacity: 0; transition: opacity var(--motion-duration-button) var(--motion-ease-premium), max-block-size var(--motion-duration-button) var(--motion-ease-premium), margin var(--motion-duration-button) var(--motion-ease-premium); }
.collection-card__cta { position: absolute; inset-inline: var(--space-card-pad-x); inset-block-end: clamp(14px, .94vw, 18px); z-index: 5; display: inline-flex; justify-content: center; padding: 8px 6px; color: var(--color-gold-light); font-family: var(--font-cta); font-size: clamp(8px, .52vw, 10px); line-height: 1.1; letter-spacing: .11em; text-align: center; text-decoration: none; text-transform: uppercase; border: 1px solid rgba(184,134,69,.58); background: rgba(5,4,3,.82); opacity: 0; pointer-events: none; transition: opacity var(--motion-duration-button) var(--motion-ease-premium), border-color var(--motion-duration-button) var(--motion-ease-premium), background-color var(--motion-duration-button) var(--motion-ease-premium), color var(--motion-duration-button) var(--motion-ease-premium); }
.collection-card:hover .collection-card__article,
.collection-card:focus-within .collection-card__article,
.collection-card.is-card-active .collection-card__article { border-color: var(--state-card-active-border); box-shadow: 0 28px 70px rgba(0,0,0,.58), 0 0 28px rgba(214,168,102,.08); }
.collection-card:hover .collection-card__detail,
.collection-card:focus-within .collection-card__detail,
.collection-card.is-card-active .collection-card__detail { max-block-size: 72px; margin-block-start: 8px; opacity: 1; }
.collection-card:hover .collection-card__cta,
.collection-card:focus-within .collection-card__cta,
.collection-card.is-card-active .collection-card__cta { opacity: 1; pointer-events: auto; }
.collection-card__cta:hover,
.collection-card__cta:focus-visible { color: var(--color-text-ivory); border-color: rgba(214,168,102,.82); background: rgba(184,134,69,.36); }

/* Invitation */
.invitation__eyebrow { margin-block-end: clamp(8px, .62vw, 12px); font-size: clamp(10px, .62vw, 12px); }
.invitation__title { color: var(--color-text-ivory); font-family: var(--font-serif-display); font-size: clamp(26px, 1.72vw, 33px); font-weight: 500; line-height: 1.08; letter-spacing: .02em; }
.invitation__proofs { display: grid; gap: 4px; margin: clamp(14px, .94vw, 18px) 0 0; padding: 0; list-style: none; color: rgba(184,170,150,.99); font-family: var(--font-body); font-size: clamp(11px, .68vw, 13px); font-weight: 300; line-height: 1.28; }
.invitation__proofs li { position: relative; padding-inline-start: 18px; }
.invitation__proofs li::before { content: "✦"; position: absolute; inset-inline-start: 0; inset-block-start: 0; color: var(--color-gold-main); font-size: .8em; }
.invitation__event-box { padding: clamp(18px, 1.15vw, 22px) clamp(18px, 1.15vw, 22px) clamp(60px, 4.17vw, 80px); color: rgba(184,170,150,.99); font-family: var(--font-body); font-weight: 300; border: 1px solid rgba(110,72,36,.58); background: rgba(5,4,3,.54); }
.invitation__event-box h3 { margin-block-end: 10px; color: var(--color-gold-main); font-family: var(--font-label); font-size: clamp(10px, .62vw, 12px); font-weight: 500; line-height: 1.25; letter-spacing: .16em; text-transform: uppercase; }
.invitation__event-box p { font-size: clamp(11px, .68vw, 13px); line-height: 1.42; }
.invitation__note { margin-block-start: 8px; color: rgba(184,170,150,.58); font-size: clamp(9px, .52vw, 10px) !important; letter-spacing: .08em; text-transform: uppercase; }
.invitation__cta { padding: 0 10px; color: #050403; background: linear-gradient(180deg, #d6a866, #b88645); border: 0; box-shadow: none; font-family: var(--font-label); font-size: clamp(10px, .62vw, 12px); font-weight: 700; letter-spacing: .09em; }
.invitation__cta:hover,
.invitation__cta:focus-visible { color: #050403; background: linear-gradient(180deg, #e3bd80, #c79755); box-shadow: 0 0 20px rgba(214,168,102,.10); }
.invitation.is-reservation-highlighted .invitation__event-box { border-color: rgba(214,168,102,.82); box-shadow: 0 0 28px rgba(214,168,102,.1); }

/* Footer */
.site-footer { color: rgba(184,134,69,.64); font-family: var(--font-footer); font-size: var(--type-footer-ref); line-height: var(--type-footer-line); letter-spacing: var(--type-footer-tracking); text-transform: uppercase; }
.site-footer__links a { color: rgba(143,129,112,.62); font-size: clamp(9px, .52vw, 10px); text-decoration: none; }

/* Modal */
.video-modal { display: grid; place-items: center; padding: 24px; opacity: 0; pointer-events: none; transition: opacity var(--motion-duration-button) var(--motion-ease-premium); }
.video-modal.is-open { opacity: 1; pointer-events: auto; }
.video-modal__overlay { background: var(--modal-overlay); }
.video-modal__panel { inline-size: min(100%, 760px); max-block-size: calc(100vh - 48px); margin: 0; overflow: auto; padding: 24px; color: var(--color-text-main); background: var(--modal-bg); border: var(--border-panel); transform: translateY(10px) scale(.99); transition: transform var(--motion-duration-button) var(--motion-ease-premium), opacity var(--motion-duration-button) var(--motion-ease-premium); }
.video-modal.is-open .video-modal__panel { transform: translateY(0) scale(1); }
.video-modal__close { position: absolute; inset-block-start: 12px; inset-inline-end: 12px; display: grid; place-items: center; min-inline-size: var(--modal-close-size); min-block-size: var(--modal-close-size); color: var(--color-text-ivory); }
.video-modal__title { max-inline-size: calc(100% - 64px); color: var(--color-text-ivory); font-family: var(--font-section-title); font-size: clamp(24px, 4vw, 34px); font-weight: 400; line-height: 1.05; letter-spacing: .06em; text-transform: uppercase; }
.video-modal__description { margin-block-start: 12px; color: var(--color-text-muted); font-size: 13px; line-height: 1.6; }
.video-modal__media { display: grid; place-items: center; margin-block-start: 20px; min-block-size: min(52vh, 360px); border: var(--border-panel); background: radial-gradient(circle at 50% 35%, rgba(214,168,102,.10), transparent 52%), rgba(5,4,3,.78); }
.video-modal__placeholder { color: var(--color-text-muted); font-family: var(--font-label); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; }
.video-modal__close:hover,
.video-modal__close:focus-visible { color: var(--color-text-ivory); background: var(--state-hover-bg); box-shadow: 0 0 24px rgba(214,168,102,.1); }

@media (hover: none), (pointer: coarse) { .collection-card:hover .collection-card__article { box-shadow: 0 24px 60px rgba(0,0,0,.48); } }
@media (prefers-reduced-motion: reduce) {
  .button,
  .video-trigger,
  .collection-heading__control,
  .collection-card__article,
  .collection-card__detail,
  .collection-card__cta,
  .video-modal,
  .video-modal__panel { transition-duration: var(--motion-reduced-duration) !important; }
  .video-modal__panel { transform: none !important; }
}
