/* —— Thème & tokens —— */
:root{
  --accent:#b76e79;
  --accent-2:#a05f6a;
  --ink:#1f2937;
  --muted:#6b7280;
  --surface:#faf7f8;
  --radius:16px;
  --container:960px;

  --hero-aspect: 16/9;

  /* Position/tailles du personnage */
  --avatar-x: 50%;
  --avatar-bottom: 3.5%;
  --avatar-width: min(40vw, 460px);
  --foot-fade: 18%;
}

/* —— Reset minimal —— */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  line-height:1.6;
  background:#fff;
}
img{max-width:100%;height:auto;display:block;border-radius:14px}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* —— Layout —— */
.wrap{max-width:var(--container);margin:0 auto;padding:0 20px}
.section{padding:56px 0}
@media (max-width:600px){.section{padding:42px 0}}

/* —— HERO —— */
.hero{
  position:relative;
  aspect-ratio: var(--hero-aspect);
  width:100%;
  min-height: clamp(50vh, 60vw, 85vh);
  overflow:hidden;
  color:#fff;
  background:#fff;
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:0;
  background: url('assets/photos/mariage%20background.png') top center / contain no-repeat;
  transform: translateZ(0);
}
.hero::after{
  content:""; position:absolute; inset:0; z-index:1;
  background: radial-gradient(120% 160% at 50% 55%, rgba(0,0,0,0) 65%, rgba(0,0,0,0.14) 100%);
  pointer-events:none;
}

/* —— Personnage devant la porte —— */
.avatar-on-hero{
  position:absolute; z-index:2;
  left: var(--avatar-x);
  bottom: var(--avatar-bottom);
  transform: translateX(-50%);
}
.avatar-on-hero img{
  position:relative; z-index:2;
  width: var(--avatar-width);
  height:auto;
  border-radius:0;
  cursor:pointer;
  user-select:none;
  transition: transform .12s ease, opacity .18s ease;

  /* Cache progressif des pieds (derrière la ligne) */
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 calc(100% - var(--foot-fade)), transparent 100%);
          mask-image: linear-gradient(to bottom, #000 0%, #000 calc(100% - var(--foot-fade)), transparent 100%);

  /* Surbrillance nette qui suit la silhouette PNG */
  filter:
    drop-shadow(0 0 16px rgba(255,255,255,0.95))
    drop-shadow(0 0 28px rgba(255,255,255,0.75))
    drop-shadow(0 0 42px rgba(183,110,121,0.40));
  animation: glowPulse 2.2s ease-in-out infinite;
}
.avatar-on-hero img:hover{ transform: translateY(-1px) }
.avatar-on-hero img:active{ transform: scale(.985) }

/* Pulse plus marqué au survol (desktop) */
@media (hover:hover){
  .avatar-on-hero img:hover{
    animation-duration: 1.6s;
    filter:
      drop-shadow(0 0 20px rgba(255,255,255,1))
      drop-shadow(0 0 36px rgba(255,255,255,0.85))
      drop-shadow(0 0 56px rgba(183,110,121,0.55));
  }
}

/* Animation du halo */
@keyframes glowPulse{
  0%,100%{
    filter:
      drop-shadow(0 0 16px rgba(255,255,255,0.95))
      drop-shadow(0 0 28px rgba(255,255,255,0.75))
      drop-shadow(0 0 42px rgba(183,110,121,0.40));
  }
  50%{
    filter:
      drop-shadow(0 0 24px rgba(255,255,255,1))
      drop-shadow(0 0 42px rgba(255,255,255,0.85))
      drop-shadow(0 0 64px rgba(183,110,121,0.55));
  }
}

/* Respect des préférences d’animation */
@media (prefers-reduced-motion: reduce){
  .avatar-on-hero img{ animation: none }
}

/* —— Titres, textes —— */
.title{
  font-family:"Playfair Display",Georgia,serif;
  font-weight:700; margin:0 0 8px;
  font-size:clamp(26px,4.6vw,40px);
  color:var(--ink); text-align:center;
}
.subtitle{
  font-family:"Playfair Display",Georgia,serif;
  font-weight:700; margin:0 0 12px;
  font-size:clamp(22px,3.6vw,30px); color:var(--ink);
}
.intro{text-align:center; display:flex; flex-direction:column; align-items:center; gap:18px}
.lead{ font-size:clamp(18px,2.6vw,22px); color:var(--muted); margin:0 auto; max-width:44ch }

/* —— INVITATION CARD —— */
.invite-card{
  position:relative;
  border-radius:24px;
  padding:28px 22px;
  background:
    radial-gradient(180% 130% at 10% 0%, #fff7fa 0%, rgba(255,247,250,0) 45%),
    radial-gradient(160% 120% at 90% 100%, #f2fff5 0%, rgba(242,255,245,0) 45%),
    #fff;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 10px 30px rgba(31,41,55,.08);
}
.invite-head{ text-align:center; margin-bottom:8px }
.invite-title{
  font-family:"Playfair Display",Georgia,serif;
  font-weight:700; margin:0; color:var(--ink);
  font-size:clamp(28px,4.8vw,40px);
}
/* Noms mis en valeur */
.invite-names{
  margin:6px 0 0;
  color:#0f172a;
  font-weight:700;
  font-size:clamp(22px,3.8vw,28px);
  letter-spacing:.01em;
  position:relative;
}
.invite-names::after{
  content:"";
  display:block;
  width:140px; height:6px; margin:10px auto 0;
  border-radius:999px;
  background:linear-gradient(90deg, #ffd6e2, #ffeab9, #d1f7d9);
  opacity:.9;
}

.divider{
  height:14px; margin:16px auto 14px; width:min(360px, 60%);
  --c1:#ffd6e2; --c2:#d1f7d9; --c3:#ffeab9;
  background: linear-gradient(90deg, var(--c1), var(--c2), var(--c3));
  border-radius:999px;
  filter:blur(.2px);
  box-shadow:0 2px 6px rgba(0,0,0,.06) inset;
}

/* Grille 3 colonnes — tout CENTRÉ */
.invite-list{
  list-style:none; padding:0; margin:0;
  display:grid; gap:10px;
  grid-template-columns:repeat(3, minmax(0,1fr));
  text-align:center;
}
.invite-item{
  background:#fff; border:1px solid rgba(0,0,0,.06);
  border-radius:16px; padding:12px 10px;
  box-shadow:0 6px 18px rgba(0,0,0,.05);
}
.invite-list .emoji{ margin-right:6px }
.invite-list strong{ color:var(--ink) }

.invite-note{ text-align:center; color:var(--muted); margin:14px 0 0; font-size:15px }

/* responsive: colonne unique sur mobile */
@media (max-width:800px){
  .invite-list{ grid-template-columns:1fr; }
}

/* —— Mini Google Map pliable (centrée) —— */
.mini-map{
  margin-top:10px;
  text-align:center; /* centre le summary et la carte */
}
.mini-map > summary{
  cursor:pointer;
  font-weight:600;
  color:#374151;
  list-style:none;
  display:inline-flex; /* pour centrer dans la ligne */
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  background:#f8fafc;
  border:1px solid rgba(0,0,0,.06);
}
.mini-map > summary::marker{ content:"" }
.mini-map[open] > summary{ background:#eef6f2 }
.map-wrap{
  margin-top:10px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 6px 18px rgba(0,0,0,.06);
}
.map-wrap iframe{ display:block; width:100%; height:260px; border:0 }

/* —— NOTE CARD —— */
.note-card{
  text-align:center;
  padding:24px 20px;
  border-radius:20px;
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 10px 24px rgba(31,41,55,.06);
  background-image:
    radial-gradient(140% 120% at 0% 100%, #fff5f8 0%, rgba(255,245,248,0) 55%),
    radial-gradient(120% 120% at 100% 0%, #f0fff4 0%, rgba(240,255,244,0) 55%);
}
.note-card .subtitle{ margin-bottom:6px }

/* —— Card + Google Form —— */
.card{
  background:#fff; border:1px solid rgba(0,0,0,.06);
  border-radius:var(--radius); padding:16px;
  box-shadow:0 8px 28px rgba(0,0,0,.05);
}
.note{ color:var(--muted); margin:0 0 10px }
.gform{ width:100%; border:0; height:1100px; border-radius:12px; background:var(--surface) }
@media (max-width:600px){ .gform{ height:1400px } }

/* —— Footer —— */
.footer{
  text-align:center; color:var(--muted);
  padding:28px 0 36px; border-top:1px solid rgba(0,0,0,.06);
  background:#fff;
}

/* —— MINI-JEU —— */
.game-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius:20px;
  box-shadow:0 10px 24px rgba(31,41,55,.06);
  padding:16px;
}
.game-head{text-align:center;margin-bottom:10px}

.game-toolbar{
  display:flex; align-items:center; justify-content:center;
  gap:10px; flex-wrap:wrap; margin:8px 0 12px;
}
.game-btn{
  background:var(--accent); color:#fff; border:0; border-radius:999px;
  padding:10px 16px; font-weight:700; cursor:pointer;
  box-shadow:0 8px 18px rgba(183,110,121,.28);
}
.game-btn:hover{ background:var(--accent-2) }
.game-hint{ color:var(--muted); font-size:14px }

.game-canvas-wrap{
  position:relative; overflow:hidden; border-radius:16px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.6);
}

.game-status{
  text-align:center; margin:10px 0 0; font-weight:600; color:var(--ink);
}

/* Canvas responsive (conserve le ratio) */
#game{ width:100%; height:auto; display:block; }

@media (max-width: 640px){
  #game { max-height: 380px; }
}

/* Centrage cross-browser de la ligne d’intro du mini-jeu */
.game-lead{
  display:block;                 /* Safari aime bien l'explicite */
  max-width: 42ch;               /* largeur lisible, évite les retours bizarres */
  margin: 0 auto 10px;           /* centre horizontalement */
  text-align: center;
  line-height: 1.45;

  /* robustesse sur Safari/iOS pour les retours à la ligne */
  -webkit-hyphens: auto;
  hyphens: auto;
  overflow-wrap: anywhere;
}

