:root{
  --bg:#fbf8f3;
  --paper:#ffffff;
  --ink:#111111;
  --muted:#5f5f5f;
  --line:rgba(0,0,0,.18);
  --line-strong:rgba(0,0,0,.45);
  --shadow:0 18px 55px rgba(0,0,0,.10);

  --serif: ui-serif, Georgia, "Times New Roman", Times, serif;
  --sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans";
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
html{ scroll-behavior:smooth; }

body{
  margin:0;
  color:var(--ink);
  font-family:var(--sans);
  background:
    linear-gradient(180deg, rgba(0,0,0,.03) 0 1px, transparent 1px),
    repeating-linear-gradient(90deg, rgba(0,0,0,.018) 0 1px, transparent 1px 28px),
    var(--bg);
}



.container{
  width:min(1100px, calc(100% - 48px));
  margin:0 auto;
  padding:28px 0 60px;
}

/* ===== Header global ===== */
.site-header{
  position: sticky;
  top:0;
  z-index:50;
  background: color-mix(in srgb, var(--bg) 80%, white 20%);
  border-bottom:1px solid var(--line);
  backdrop-filter: blur(6px);
}

.header-inner{
  width:min(1100px, calc(100% - 48px));
  margin:0 auto;
  padding:14px 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:inherit;
  min-width: 220px;
}

.logo{
  width:38px;
  height:38px;
  border:2px solid var(--ink);
  display:grid;
  place-items:center;
  font-family:var(--serif);
  font-weight:900;
  letter-spacing:-.05em;
  line-height:1;
}

.brand-meta{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.brand-meta .top{
  font-family:var(--serif);
  font-weight:900;
  letter-spacing:-.03em;
  font-size:16px;
}
.brand-meta .bottom{
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
}

.nav{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.nav a{
  text-decoration:none;
  color:inherit;
  border:1px solid var(--line);
  padding:10px 12px;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  background: rgba(255,255,255,.55);
}
.nav a:hover{
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.nav .active{
  border-color: var(--line-strong);
  background: rgba(255,255,255,.85);
}

/* ===== Hero ===== */
.hero{
  padding:30px 0 12px;
  text-align:center;
  position:relative;
}

.kicker{
  margin:0 0 14px;
  font-size:16px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--muted);
}

.h1{
  margin:0;
  font-family:var(--serif);
  font-weight:900;
  letter-spacing:-.045em;
  font-size: clamp(40px, 5vw, 68px);
  line-height:1.02;
}

.sub{
  margin:14px 0 0;
  color:var(--muted);
  font-size: clamp(14px, 2vw, 16px);
}

/* ===== Paper helpers ===== */
.paper{
  background: var(--paper);
  border:1px solid var(--line);
}

/* ===== Countdown ===== */
.countdown{
  margin:18px auto 0;
  width:min(840px, 100%);
  border:1px solid var(--line);
  background: rgba(255,255,255,.7);
  padding:14px 14px 12px;
}

.countdown-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:10px;
}

.countdown-title{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
}

.pills{ display:flex; gap:8px; flex-wrap:wrap; }
.pill{
  border:1px solid var(--line);
  background: rgba(255,255,255,.75);
  padding:8px 10px;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
}

.timer{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:10px;
}
@media (max-width: 560px){
  .timer{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}

.unit{
  border:1px solid var(--line);
  background: rgba(255,255,255,.85);
  padding:12px 10px;
  text-align:center;
}
.unit .num{
  font-family:var(--serif);
  font-weight:900;
  font-size:28px;
  letter-spacing:-.03em;
  line-height:1;
}
.unit .lab{
  margin-top:8px;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
}

/* ===== Divider ink ===== */
.divider-ink{
  margin:18px 0;
  height:1px;
  background: var(--line);
  position:relative;
}
.divider-ink::after{
  content:"";
  position:absolute;
  left:0;
  top:-2px;
  width:110px;
  height:5px;
  background: var(--ink);
}

/* ===== Accueil: cards carrées ===== */
.grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:18px;
  margin-top:20px;
}
@media (max-width: 860px){
  .grid{ grid-template-columns:1fr; }
}

.card{
  display:block;
  text-decoration:none;
  color:inherit;
  border:1px solid var(--line);
  background: var(--paper);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
  overflow:hidden;
}
.card:hover{
  transform: translateY(-4px);
  border-color: var(--line-strong);
  box-shadow: var(--shadow);
}

.card-square{
  aspect-ratio: 1 / 1;
  display:flex;
  flex-direction:column;
}

.card-visual{
  flex: 1 1 auto;
  border-bottom:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  /*background: linear-gradient(180deg, rgba(0,0,0,.03), transparent 70%);*/
}
.card-visual img{
  width: 92%;
  max-width:520px;
  height:auto;
  display:block;
}

.card-body{ padding:16px 16px 14px; }

/* FIX: garder card-body visible sur les cards carrées */
.card-square{
  display:grid;
  grid-template-rows: 1fr auto; /* visuel prend le reste, body garde sa place */
}

.card-body{
  min-height: 112px;           /* réserve une zone lisible */
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:6px;
}

/* optionnel: éviter que l’image soit trop grande */
.card-visual{
  min-height: 0;               /* important avec grid */
}

.card-visual img{
  max-height: 100%;
  object-fit: contain;         /* garde le dessin entier sans le couper */
}


.badge{
  display:inline-block;
  /*padding:8px 10px;
  border:1px solid var(--line);*/
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
  background: rgba(255,255,255,.75);
}

.card-title{
  margin:12px 0 6px;
  font-family:var(--serif);
  font-weight:900;
  letter-spacing:-.02em;
  font-size:18px;
}
.card-meta{ margin:0; color:var(--muted); }

/* ===== Pages journées ===== */
.day-wrap{
  margin-top:18px;
  padding:22px;
}

.day-head{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  align-items:stretch;
}
@media (max-width: 860px){
  .day-head{ grid-template-columns:1fr; }
}

.day-card{
  border:1px solid var(--line);
  background: rgba(255,255,255,.7);
  overflow:hidden;
}

.day-card .visual{
  display:flex;
  justify-content:center;
  padding:18px;
  border-bottom:1px solid var(--line);
  background: linear-gradient(180deg, rgba(0,0,0,.03), transparent 70%);
}
.day-card img{
  width:92%;
  max-width:520px;
  height:auto;
  display:block;
}
.day-card .info{ padding:14px 14px 16px; }

.h2{
  margin:0 0 8px;
  font-family:var(--serif);
  font-weight:900;
  letter-spacing:-.02em;
  font-size:22px;
}

.list{
  margin:0;
  padding:0;
  list-style:none;
  color:var(--muted);
}
.list li{
  padding:8px 0;
  border-top:1px solid var(--line);
}
.list li:first-child{ border-top:none; }

.cols{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  margin-top:18px;
}
@media (max-width: 860px){
  .cols{ grid-template-columns:1fr; }
}

.block{
  border:1px solid var(--line);
  background: rgba(255,255,255,.75);
  padding:16px;
  position:relative;
}
.block h3{
  margin:0 0 10px;
  font-family:var(--serif);
  font-weight:900;
  letter-spacing:-.02em;
  font-size:18px;
}
.block p, .block ul{ margin:0; color:var(--muted); }
.block ul{ padding-left:18px; margin-top:8px; }
.block li{ margin:6px 0; }

/* ===== Logements list ===== */
.lodging{
  margin-top:10px;
  border-top:1px solid var(--line);
  padding-top:10px;
  display:grid;
  gap:10px;
}
.lodge{
  border:1px solid var(--line);
  background: rgba(255,255,255,.85);
  padding:12px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.lodge .name{
  font-weight:800;
  color:var(--ink);
}
.lodge .meta{
  font-size:13px;
  color:var(--muted);
  margin-top:4px;
}
.lodge a{
  border:1px solid var(--line);
  padding:10px 12px;
  text-decoration:none;
  color:inherit;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  background: rgba(255,255,255,.75);
  white-space:nowrap;
}
.lodge a:hover{
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}

.footer{
  margin-top:26px;
  text-align:center;
  color:var(--muted);
  font-size:13px;
}

.icon{ width:16px; height:16px; display:inline-block; }

/* ===== Motifs photos N&B (habillage discret) =====
   Tu peux remplacer les URLs par d'autres images (Unsplash / Pexels / etc.)
*/
:root{
  --m-bouquet: url("assets/bouquet.png");
  --m-chairs:  url("https://source.unsplash.com/FHLFSMOMmdg/700x900");
  --m-dress:   url("https://source.unsplash.com/gwmYCyXPGNA/700x900");
}

.motifs{ position:relative; }

.motif{
  position:absolute;
  width:170px;
  height:220px;
  border:1px solid var(--line);
  background-size:cover;
  background-position:center;
  filter: grayscale(1) contrast(1.06);
  opacity:.22;
  mix-blend-mode:multiply;
  pointer-events:none;
}

.motif.bouquet{ background-image: var(--m-bouquet); }
.motif.chairs{  background-image: var(--m-chairs); }
.motif.dress{   background-image: var(--m-dress); }

.motif.tl{ top:-10px; left:-10px; }
.motif.tr{ top:10px; right:-10px; }
.motif.bl{ bottom:-20px; left:10px; }
.motif.br{ bottom:-20px; right:10px; }

@media (max-width: 860px){
  .motif{ display:none; }
}
.minifig{
  width: 92px;      /* ajuste */
  height: auto;
  color: var(--ink);
  opacity: .22;     /* discret */
  display:block;
}

/* Variante “sticker” plus visible */
.minifig.sticker{
  opacity: .34;
  width: 110px;
}

/* Exemple: placer un minifig dans le hero */
.hero.motifs .minifig-pin{
  position:absolute;
  right: -6px;
  bottom: -18px;
  pointer-events:none;
}


/* ===============================
   COEUR J & F — composant animé
   =============================== */

.heart-jf{
  width:72px;                 /* taille par défaut */
  height:auto;
  display:block;
  color: var(--ink);
}

/* Trait du coeur */
.heart-stroke{
  fill:none;
  stroke:currentColor;
  stroke-width:8;
  stroke-linecap:square;
  stroke-linejoin:miter;

  /* animation tracé */
  stroke-dasharray: 420;
  stroke-dashoffset: 420;
  animation: heart-draw 1.4s ease-out forwards;
}

/* Lettres J & F */
.jf-letter{
  fill:none;
  stroke:currentColor;
  stroke-width:6;
  stroke-linecap:square;
  stroke-linejoin:miter;

  opacity:0;
  animation: jf-fade 0.6s ease-out forwards;
  animation-delay: 1.1s;
}


:root{
  --m-couple: url("assets/couple-mariage.svg");
}

/* Bloc illustration (cadre N&B) */
.illus{
  border:1px solid var(--line);
  background: rgba(255,255,255,.7);
  padding:14px;
  margin:18px auto 0;
  width:min(900px, 100%);
}

.illus img{
  width:100%;
  height:auto;
  display:block;
  filter: grayscale(1) contrast(1.05);
}

/* Version "motif" en background discret (si tu préfères) */
.motif.couple{ background-image: var(--m-couple); }

/* ===== Formulaire RSVP ===== */

.form-head{
  max-width: 860px;
  margin: 0 auto 14px;
}

.form-sub{
  margin:0;
  color:var(--muted);
  line-height:1.5;
}

.rsvp-form{
  max-width: 860px;
  margin: 0 auto;
}

.form-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px 16px;
}
@media (max-width: 860px){
  .form-grid{ grid-template-columns: 1fr; }
}

.field{ display:flex; flex-direction:column; gap:8px; }
.field.full{ 
  grid-column: 1 / -1;     
  margin-top: 8px;}
.field.full textarea{ 
    grid-column: 1 / -1; 
      width: 100%;
}
.field label{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
}
.req{ color:var(--ink); font-weight:900; }

.field input, .field textarea{
  border:1px solid var(--line);
  background: rgba(255,255,255,.75);
  padding:12px 12px;
  font: inherit;
  color:var(--ink);
  outline:none;
}
.field input:focus{
  border-color: var(--line-strong);
  background: rgba(255,255,255,.9);
}

.error{
  min-height: 16px;
  font-size:13px;
  color: var(--ink);
  opacity:.75;
}

/* Blocs */
.form-block{
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid var(--line);
}

.h3{
  margin:0 0 10px;
  font-family:var(--serif);
  font-weight:900;
  letter-spacing:-.02em;
  font-size:18px;
}
.day-intro {
    text-align: center;
    margin: 1rem 0rem 1.5rem 0rem;
    line-height: 24px;
}
/*.reserve {
    color: var(--muted);
    font-style: italic;
    font-size: 0.85rem;
}*/
.reserve {
    color: var(--muted);
    font-style: italic;
    font-size: 0.85rem;
    display: block;
    width: 70%;
    margin: 0 auto;
    padding-top: 1rem;
    line-height: 1rem;
}
/* Choix */
.choices {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px 18px;
    margin: 3rem 0;
}
@media (max-width: 860px){
  .choices{ grid-template-columns: 1fr; }
}

.choices > * > label {
    font-weight: 800;
    margin: 8px 0;
    font-family: var(--serif);
    display: block;
}

.segmented > div {
  display:flex;
  border:1px solid var(--line);
  background: rgba(255,255,255,.65);
}

.segmented .form-item {
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 12px;
  /*cursor:pointer;*/
  user-select:none;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
  border-right:1px solid var(--line);
}
.segmented .form-item:last-child{ border-right:none; }

.segmented .form-item input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.segmented label {
  cursor: pointer;
}

/* état sélectionné */
.segmented .form-radio:checked + label{
  color: var(--bg);
  background: var(--ink);
  display:block;
}
.segmented .form-radio + label{
  padding:6px 12px;
}

/* Actions */
.form-actions {
    margin-top: 18px;
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    justify-content: center;
}
.form-hint{
  margin:0;
  color:var(--muted);
}

.button  {
    display: inline-block;
    border: 1px solid var(--line);
    padding: 10px 12px;
    text-decoration: none;
    color: inherit;
    font-size: 12px;
    letter-spacing: .12em;
    text-transform: uppercase;
    background: rgba(255, 255, 255, .75);
}
.full label {
    margin-bottom: 8px;
    display: block;
}
.button:hover {
    border-color: #000000;
    background-color: #fcfcfc;
}
.segmented .form-item:hover {
    background-color: #fcfcfc;
}
.messages.messages--status {
    font-family: var(--serif);
    text-align: center;
    background: var(--paper);
    border: 1px solid var(--line);
}

/* --- Timeline --- */
/* ===== Timeline clean (noir & blanc) ===== */

.timeline-clean{
  margin-top: 1.5rem;
}

/* Ligne centrale */
.timeline{
  position: relative;
  margin-top: 1rem;
  padding-left: 2rem;
}
.timeline::before{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  left:1rem;
  width:2px;
  background:#000;
  opacity:.2;
}

/* Élément */
.tl-item{
  position: relative;
  margin-bottom: 1.2rem;
}

/* Point + icône */
.tl-dot{
  position:absolute;
  top:1rem;
  left:1rem;
  transform:translateX(-50%);
  width:32px;
  height:32px;
  border-radius:50%;
  background:#fff;
  border:2px solid #000;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.9rem;
}

/* Carte */
.tl-content{
  background:#fff;
  border:1px solid rgba(0,0,0,.15);
  border-radius:14px;
  padding:.9rem 1rem;
  margin-left:1.8rem;
}

.tl-title{
  font-weight:700;
  display:flex;
  align-items:center;
  gap:.5rem;
  flex-wrap:wrap;
}

.tl-text{
  margin-top:.25rem;
  line-height:1.45;
  opacity:.9;
}

/* Badge optionnel */
.badge-optional{
  font-size:.65rem;
  text-transform:uppercase;
  letter-spacing:.05em;
  padding:.15rem .45rem;
  border-radius:999px;
  border:1px dashed rgba(0,0,0,.4);
  opacity:.7;
}

/* Optionnel : point en pointillé */
.tl-optional .tl-dot{
  border-style:dashed;
}

/* ===== Desktop : 2 colonnes parfaitement centrées ===== */
@media (min-width: 900px){
  .timeline{
    padding-left:0;
  }
  .timeline::before{
    left:50%;
    transform:translateX(-50%);
  }

  .tl-item{
    width:50%;
  }

  .tl-item:nth-child(odd){
    padding-right:2rem;
  }
  .tl-item:nth-child(even){
    margin-left:50%;
    padding-left:2rem;
  }

  /* 🔑 Point TOUJOURS centré sur la ligne */
  .tl-dot{
    left:50%;
    transform:translateX(-50%);
  }

  .tl-content{
    margin-left:0;
  }

.tl-dot.td-right{
  left: 100% !important;
}
}


  .tl-dot.td-right{
     left: -15px;
  }
  .tl-dot.td-left{
     left: -15px;
  }
  a.ext {
    color: #ff9200;
}