/* =============================================================
   ÉRIC BOURQUIN EVENTS — design system (prototype)
   Couleurs/typo d'après specs Adobe XD : Inter + cream/rouge/noir
   ============================================================= */

:root{
  --cream:   #F5F3EF;   /* crème clair (specs) */
  --page:    #EDEBE7;   /* fond de page (gris chaud) */
  --ink:     #111111;
  --black:   #000000;
  --red:     #B12F23;   /* rouge accent / footer */
  --red-2:   #B12F24;
  --muted:   #4d4d4d;
  --line:    #d9d6d1;
  --overlay: rgba(245,243,239,.86); /* boîte héro translucide */
  --shadow:  0 18px 50px rgba(0,0,0,.16);
  --maxw:    1180px;
  --gut:     clamp(18px, 5vw, 64px);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }
html,body{ overflow-x:clip; }   /* évite tout débordement horizontal (header collant préservé) */
body{
  margin:0;
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  color:var(--ink);
  background:var(--page);
  font-size:16px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
p{ margin:0 0 1em; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }

/* Petit carré rouge d'accent */
.sq{
  position:absolute; width:20px; height:20px; background:var(--red); z-index:3;
}

/* =======================  HEADER  ======================= */
.site-header{
  position:sticky; top:0; z-index:50;
  background:var(--cream);
  border-bottom:1px solid rgba(0,0,0,.06);
  box-shadow:0 1px 0 rgba(0,0,0,.04);
}
.site-header__inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; min-height:92px;
}
.brand{ display:flex; flex-direction:column; align-items:center; line-height:1; }
.brand__logo{ display:block; height:70px; width:auto; }
.brand__name{
  font-family:"EB Garamond","Cormorant Garamond",Georgia,serif;
  font-weight:600; letter-spacing:.06em; font-size:20px; color:#1a1a1a;
}
.brand__name small{ font-size:.62em; display:block; text-align:center; }
.brand__sub{
  font-family:"EB Garamond",Georgia,serif; font-size:10px;
  letter-spacing:.42em; margin-top:4px; color:#333; text-indent:.42em;
}

.nav{ }
.nav__list{
  list-style:none; display:flex; align-items:center; gap:clamp(14px,2vw,30px);
  margin:0; padding:0;
}
.nav__list a{
  font-size:13px; font-weight:500; letter-spacing:.04em;
  text-transform:uppercase; color:#111; white-space:nowrap;
  padding:6px 0; position:relative;
}
.nav__list a:hover{ color:var(--red); }
.nav__list a.is-active{ color:var(--red); font-weight:700; }
.nav__list a[data-cta]::after{ content:" ›"; }

/* Hamburger */
.nav-toggle{
  display:none; background:none; border:0; cursor:pointer; padding:8px;
  width:44px; height:44px;
}
.nav-toggle span{ display:block; height:2px; background:var(--red); margin:5px 0; transition:.25s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* =======================  HERO  ======================= */
.hero{ padding:0; }
.hero__wrap{ position:relative; max-width:none; margin-inline:0; padding-inline:0; }
.hero__media{ width:100%; aspect-ratio:16/7; overflow:hidden; }
.hero__media img{ width:100%; height:100%; object-fit:cover; }
.hero__box{
  position:absolute; right:0; top:50%;
  transform:translateY(-50%);
  width:min(46%, 520px);
  background:var(--overlay); backdrop-filter:blur(2px);
  padding:26px 30px; box-shadow:var(--shadow);
  transition:transform .45s cubic-bezier(.16,.84,.44,1), box-shadow .45s ease;
}
/* Micro-animation au survol/clic : accent rouge qui se déploie depuis le bas
   du bloc, et léger soulèvement de la boîte. */
.hero__box::after{
  content:""; position:absolute; left:0; bottom:0;
  width:100%; height:4px; background:var(--red);
  transform:scaleX(0); transform-origin:left bottom;
  transition:transform .55s cubic-bezier(.16,.84,.44,1);
}
.hero__box:hover, .hero__box.is-revealed{
  transform:translateY(calc(-50% - 7px));
  box-shadow:0 28px 66px rgba(0,0,0,.22);
}
.hero__box:hover::after, .hero__box.is-revealed::after{ transform:scaleX(1); }
.hero__box .sq{ top:-10px; left:-10px; z-index:4; }
.hero__box p{ margin:0; font-size:15px; line-height:1.7; color:#1a1a1a; }

@media (prefers-reduced-motion: reduce){
  .hero__box, .hero__box::after{ transition:none; }
}

/* =======================  SECTION SPLIT  ======================= */
.section{ padding:clamp(48px,8vw,104px) 0; }
.split{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,72px);
  align-items:center;
}
.split--media-right .split__media{ order:2; }

.split__body{ }
.title{ margin:0 0 22px; line-height:1.02; }
.title__a{
  display:block; color:var(--red); font-weight:900;
  font-size:clamp(28px,4.2vw,46px); letter-spacing:-.01em; text-transform:uppercase;
}
.title__b{
  display:block; color:#111; font-weight:500;
  font-size:clamp(21px,3vw,34px); text-transform:uppercase; letter-spacing:.01em;
  margin-left:3.8em; margin-top:2px;
}
.split__body p{ font-size:16px; color:#000000; }
.split--center .split__body{ text-align:right; }
.split--center .title__b{ margin-left:0; margin-right:113px; }

/* media : images superposées avec carré rouge */
.stack{ position:relative; display:flex; gap:18px; }
.stack img{ width:100%; object-fit:cover; box-shadow:0 10px 30px rgba(0,0,0,.12); }
.stack--offset{ align-items:flex-start; }
.stack--offset .stack__a{ width:50%; aspect-ratio:3/4; margin-top:72px; }
.stack--offset .stack__b{ width:50%; aspect-ratio:3/4.4; }
.frame{ position:relative; }
.frame img{ width:100%; aspect-ratio:4/5; object-fit:cover; box-shadow:0 10px 30px rgba(0,0,0,.12); }
.frame .sq--tl{ top:-10px; left:-10px; }
.frame .sq--bl{ bottom:-10px; left:-10px; }
.frame .sq--tr{ top:-10px; right:-10px; }

.linklike{ color:var(--red); font-weight:700; font-size:13px; letter-spacing:.06em; text-transform:uppercase; }
.linklike::after{ content:" ›"; }

/* =======================  GALLERY  ======================= */
.gallery{
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
  grid-auto-rows:1fr;
}
.gallery a, .gallery figure{ margin:0; overflow:hidden; }
.gallery img{ width:100%; height:100%; object-fit:cover; aspect-ratio:1/1;
  transition:transform .5s ease; }
.gallery img:hover{ transform:scale(1.04); }
.gallery .feature{ grid-column:2; grid-row:1 / span 2; }
.gallery .feature img{ aspect-ratio:auto; height:100%; }

/* =======================  CARDS (À propos)  ======================= */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.card{ position:relative; display:block; }
.card__media{ position:relative; display:block; overflow:hidden; aspect-ratio:1/1; }
.card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.card:hover .card__media img{ transform:scale(1.05); }
.card__label{
  position:absolute; left:0; right:0; bottom:0; padding:18px 22px;
  background:rgba(177,47,35,.55);
  text-align:right;
  opacity:0; transition:opacity .35s ease;
}
.card:hover .card__label{ opacity:1; }
.card__label span{
  color:#fff; font-weight:700; font-size:13px;
  letter-spacing:.08em; text-transform:uppercase;
}
.card__label span::after{ content:" ›"; }
.card .sq{ top:-10px; left:-10px; z-index:3; }

/* =======================  CONTACT (page CONCLUSION)  ======================= */
.conclusion .stack--offset .stack__a{ aspect-ratio:3/4; }
.contact-info{ font-size:14px; color:#222; line-height:2; margin-top:8px; }
.contact-info span{ color:#555; }

/* =======================  FOOTER CONTACT (rouge)  ======================= */
.contact-band{ background:var(--red); color:var(--cream); }
.contact-band__inner{
  display:grid; grid-template-columns:1fr 1.25fr; gap:clamp(24px,5vw,64px);
  padding:clamp(40px,6vw,72px) 0;
}
.contact-band h2{
  margin:0; font-weight:800; font-size:clamp(34px,5vw,58px);
  letter-spacing:.01em; line-height:1; color:var(--cream); text-transform:uppercase;
}
.contact-band__lead{
  margin-top:14px; font-weight:700; font-size:13px; letter-spacing:.04em;
  line-height:1.7; max-width:300px; text-transform:uppercase;
}
.cform{ grid-template-columns:1fr 1fr; gap:22px 26px; align-content:start; }
.cform .full{ grid-column:1 / -1; }
.field label{
  display:block; font-size:12px; letter-spacing:.06em; text-transform:uppercase;
  margin-bottom:6px; color:var(--cream);
}
.field input, .field textarea{
  width:100%; background:transparent; border:0; border-bottom:1px solid rgba(245,243,239,.55);
  color:var(--cream); font-family:inherit; font-size:15px; padding:6px 0; outline:none; resize:none;
}
.field textarea{ min-height:54px; }
.field input::placeholder, .field textarea::placeholder{ color:rgba(245,243,239,.55); }
.cform__actions{ grid-column:1 / -1; display:flex; justify-content:flex-end; }
.btn-send{
  background:none; border:0; color:var(--cream); cursor:pointer;
  font-weight:700; font-size:14px; letter-spacing:.08em; text-transform:uppercase;
}
.btn-send::after{ content:" ›"; }

.site-foot{ background:var(--page); padding:18px 0; }

/* =======================  RESPONSIVE  ======================= */
@media (max-width:880px){
  /* --- Header compact --- */
  .site-header__inner{ position:relative; min-height:72px; padding-right:54px; gap:12px; }
  .brand__logo{ height:52px; }
  .nav-toggle{ display:block; position:absolute; right:14px; top:50%; transform:translateY(-50%); }
  .nav{
    position:absolute; left:0; right:0; top:100%;
    background:var(--cream); border-bottom:1px solid rgba(0,0,0,.08);
    transform:scaleY(0); transform-origin:top; transition:.22s; overflow:hidden;
  }
  .nav.is-open{ transform:scaleY(1); }
  .nav__list{ flex-direction:column; align-items:flex-start; gap:0; padding:8px var(--gut); }
  .nav__list li{ width:100%; }
  .nav__list a{ display:block; padding:12px 0; border-bottom:1px solid rgba(0,0,0,.06); width:100%; }

  /* --- Sections empilées et plus compactes --- */
  .section{ padding:30px 0; }
  .split{ grid-template-columns:1fr; gap:16px; }
  .split--media-right .split__media{ order:0; }
  .split__body p{ margin-bottom:.5em; line-height:1.5; }
  .linklike{ display:inline-block; margin-top:0; }

  /* --- Héro : boîte texte SUPERPOSÉE sur l'image (carré rouge en haut-gauche) --- */
  .hero{ padding-bottom:76px; }
  .hero__media{ aspect-ratio:4/3; }
  .hero__box{
    position:absolute; left:50%; right:auto; bottom:0; top:auto;
    transform:translate(-50%,50%); width:min(88%,360px); margin:0; padding:22px 18px 16px;
  }
  .hero__box:hover, .hero__box.is-revealed{ transform:translate(-50%,50%); }
  .hero__box p{ font-size:13px; line-height:1.5; }
  .hero__box .sq{ top:-10px; left:-10px; border:2px solid #fff; }

  /* (Sections centrées : laissées identiques au desktop sur mobile) */

  /* --- Cartes : label rouge toujours visible --- */
  .card__media{ aspect-ratio:21/9; }
  /* Mobile : overlay rouge sur TOUTE l'image, uniquement au survol (pas en permanence) */
  .card__label{ inset:0; padding:14px 16px; display:flex; align-items:flex-end; justify-content:flex-end; }

  /* --- Contact compact --- */
  .contact-band__inner{ grid-template-columns:1fr; padding:24px 14px; gap:12px; }
  .contact-band h2{ font-size:38px; }
  .contact-band__lead{ margin-top:8px; }
  .contact-band .wpcf7-form{ gap:10px; }
  .contact-band .wpcf7-form > p:has(input[type=submit]){ margin-top:2px; }
}
@media (max-width:560px){
  .gallery{ grid-template-columns:1fr 1fr; }
  .gallery .feature{ grid-column:auto; grid-row:auto; }
  .cards{ grid-template-columns:1fr; }
  .cform{ grid-template-columns:1fr; }
}
/* =======================  CONTACT FORM 7 (dans la bande rouge)  ======================= */
.contact-band .wpcf7{ width:100%; }
.contact-band .wpcf7-form{ display:grid; grid-template-columns:1fr 1fr; gap:20px 26px; align-content:start; }
.contact-band .wpcf7-form > p{ margin:0; }
/* Téléphone, message, bouton et messages = pleine largeur ; Nom + Email côte à côte */
.contact-band .wpcf7-form > p:has(textarea),
.contact-band .wpcf7-form > p:has(input[type=tel]),
.contact-band .wpcf7-form > p:has(input[type=submit]),
.contact-band .wpcf7-form > .wpcf7-response-output{ grid-column:1 / -1; }
.contact-band .wpcf7-form > p:has(input[type=submit]){ text-align:right; }
.contact-band .wpcf7-form > p:has(input[type=submit])::after{
  content:"›"; margin-left:2px; color:var(--cream); font-weight:700; font-size:14px; letter-spacing:.08em;
}
@media (max-width:560px){ .contact-band .wpcf7-form{ grid-template-columns:1fr; } }
.contact-band .wpcf7-form label{
  display:block; width:100%;
  font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--cream);
}
.contact-band .wpcf7-form input[type=text],
.contact-band .wpcf7-form input[type=email],
.contact-band .wpcf7-form input[type=tel],
.contact-band .wpcf7-form input[type=url],
.contact-band .wpcf7-form input[type=number],
.contact-band .wpcf7-form textarea{
  width:100%; background:transparent; border:0;
  border-bottom:1px solid rgba(245,243,239,.55);
  color:var(--cream); font-family:inherit; font-size:15px;
  padding:6px 0; margin-top:6px; outline:none; resize:none;
}
.contact-band .wpcf7-form textarea{ min-height:44px; height:44px; }
.contact-band .wpcf7-form input::placeholder,
.contact-band .wpcf7-form textarea::placeholder{ color:rgba(245,243,239,.55); }
.contact-band .wpcf7-form input:focus,
.contact-band .wpcf7-form textarea:focus{ border-bottom-color:var(--cream); }

/* Bouton Envoyer aligné à droite, style "lien fléché" du design */
.contact-band .wpcf7-form input[type=submit],
.contact-band .wpcf7-form button[type=submit]{
  justify-self:end; background:none; border:0; cursor:pointer;
  color:var(--cream); font-family:inherit; font-weight:700;
  font-size:14px; letter-spacing:.08em; text-transform:uppercase;
}
.contact-band .wpcf7-form input[type=submit]:hover,
.contact-band .wpcf7-form button[type=submit]:hover{ opacity:.85; }
.contact-band .wpcf7-spinner{ display:none; }

/* Messages de validation / réponse */
.contact-band .wpcf7-response-output{
  color:var(--cream); font-size:13px; margin:4px 0 0;
  border-color:rgba(245,243,239,.6)!important;
}
.contact-band .wpcf7-not-valid-tip{ color:#ffd9d4; font-size:12px; }
