/* —— Variables —— */
:root{
  --bg: #fffaf5;
  --card: #ffffff;
  --ink: #1f2937;
  --muted: #6b7280;
  --brand: #b88a44; /* doré Gatsby */
  --brand-ink: #5a4520;
  --ring: rgba(184,138,68,.35);
  --radius: 16px;
  --shadow: 0 10px 30px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  background: radial-gradient(1200px 800px at 10% -10%, #efe5d0 0%, transparent 60%),
              radial-gradient(800px 600px at 110% 10%, #f4ead6 0%, transparent 55%),
              var(--bg);
}
h1,h2,h3{line-height:1.2;margin:0 0 .5rem}
h1{font-size: clamp(2rem, 4vw, 3rem); text-transform:uppercase; letter-spacing:.06em}
h2{font-size: clamp(1.5rem, 3vw, 2rem)}
h2::after{content:"";display:block;width:120px;height:2px;margin:.4rem 0 0;background:linear-gradient(90deg,transparent,var(--brand),transparent)}
a{color:var(--brand);text-decoration-color: color-mix(in oklab, var(--brand), black 20%)}
.container{max-width:1000px;margin:0 auto;padding:clamp(1rem,3vw,2rem)}
.topnav{position:sticky;top:0;z-index:10;display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;background:rgba(255,255,255,.6);backdrop-filter:saturate(120%) blur(6px);padding:.4rem .6rem}
.topnav a{color:var(--ink);text-decoration:none;padding:.45rem .7rem;border-radius:999px}
.topnav a.active{background:var(--brand);color:#fff}
.site-header{position:relative;min-height:50vh;display:grid;place-items:center;color:white;
  background-image:linear-gradient(to bottom, rgba(0,0,0,.45), rgba(0,0,0,.45)), url('assets/hero-moulin-rouge-optimise.jpg');
  background-size:cover;background-position:center}
.hero{text-align:center;padding:1.2rem}
.card{background:var(--card);border:1px solid #ead9c2;border-radius:var(--radius);box-shadow:var(--shadow);
  padding:clamp(1rem,2.5vw,2rem);margin:clamp(1rem,2vw,1.5rem) 0;position:relative}
.card::before{content:"";position:absolute;inset:10px;border:1px solid #ead9c2;border-radius:12px;pointer-events:none}
.btn{display:inline-block;border:none;border-radius:999px;padding:.75rem 1.1rem;background:var(--brand);
  color:white;font-weight:700;text-decoration:none;box-shadow:0 6px 20px var(--ring);cursor:pointer}
.btn--ghost{background:transparent;color:white;outline:2px solid rgba(255,255,255,.8)}
.btn--small{padding:.45rem .7rem;font-weight:600;box-shadow:none}
.grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.map{width:100%;border-radius:12px;border:1px solid #eee;display:block}
.table-wrap{overflow:auto}
.table{width:100%;border-collapse:collapse}
.table th,.table td{border-bottom:1px solid #eee;text-align:left;padding:.5rem .4rem}
.table th{font-weight:700;color:var(--brand-ink)}
.site-footer{text-align:center;color:var(--muted);padding:3rem 1rem}
.hint{color:var(--muted);font-size:.9rem}
.hidden{display:none}

/* countdown */
.countdown{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center;margin:.5rem 0}
.cd-item{background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.25);border-radius:12px;padding:.35rem .6rem;min-width:82px;text-align:center;color:#fff}
.cd-item span{font-weight:800;font-size:clamp(1.2rem,3.5vw,1.8rem);display:block;line-height:1.1}
.cd-item small{opacity:.9;font-size:.8rem}

/* apports */
.apports-banner{width:100%;height:auto;display:block;border-radius:12px;margin-bottom:.75rem}
.apports-filters{display:flex;gap:.5rem;flex-wrap:wrap;margin:.25rem 0 .5rem}
.chip{border:none;border-radius:999px;padding:.45rem .8rem;background:#f3f4f6;cursor:pointer}
.chip.active{background:var(--brand);color:white}
.apports-list li{list-style:none;position:relative;padding-left:2rem}
.apports-list li::before{content:"🎁";position:absolute;left:0;top:0.1rem}
.apports-list li[data-cat="Manger"]::before{content:"🍴"}
.apports-list li[data-cat="Alcool"]::before{content:"🍷"}
.apports-list li[data-cat="Soft"]::before{content:"🥤"}
.apports-actions{display:flex;justify-content:flex-end;margin:.25rem 0}

/* guests filter */
.guests-filters{display:flex;gap:.5rem;align-items:center;margin:.5rem 0}

/* planning filters */
.planning-filters{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin:.5rem 0}
.quick-dates{display:flex;gap:.35rem}

/* —— a11y —— */
.visually-hidden{position:absolute!important;clip:rect(1px,1px,1px,1px);padding:0;border:0;height:1px;width:1px;overflow:hidden;white-space:nowrap}

/* —— Theme switcher layout —— */
.topnav{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;position:sticky;top:0}
.topnav .nav-left{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}
.topnav .nav-right{margin-left:auto}

/* —— Theme palettes —— */
:root[data-theme="classic"]{
  --bg:#fffaf5; --card:#ffffff; --ink:#1f2937; --muted:#6b7280; --brand:#b88a44; --brand-ink:#5a4520; --ring:rgba(184,138,68,.35);
}
:root[data-theme="noir-or"]{
  --bg:#0b0b0d; --card:#121218; --ink:#f1eadf; --muted:#b7b3ab; --brand:#d4af37; --brand-ink:#f2d98b; --ring:rgba(212,175,55,.35);
}
:root[data-theme="creme-bordeaux"]{
  --bg:#fff7f0; --card:#ffffff; --ink:#2b1920; --muted:#7b5b66; --brand:#7a2844; --brand-ink:#4b1629; --ring:rgba(122,40,68,.25);
}
:root[data-theme="nuit-champagne"]{
  --bg:#0f172a; --card:#111827; --ink:#f5f5f5; --muted:#b8c1d1; --brand:#e7c888; --brand-ink:#fff3cf; --ring:rgba(231,200,136,.28);
}
:root[data-theme="emeraude"]{
  --bg:#f0fbf6; --card:#ffffff; --ink:#0f2f28; --muted:#4f6a63; --brand:#0aa37f; --brand-ink:#035b47; --ring:rgba(10,163,127,.28);
}

/* Adapt background image tinting to theme */
.site-header{color:white;background-image:linear-gradient(to bottom, rgba(0,0,0,.45), rgba(0,0,0,.45)), url('assets/hero-moulin-rouge-optimise.jpg')}
:root[data-theme="classic"] .site-header{background-image:linear-gradient(to bottom, rgba(0,0,0,.45), rgba(0,0,0,.45)), url('assets/hero-moulin-rouge-optimise.jpg')}
:root[data-theme="noir-or"] .site-header{background-image:linear-gradient(to bottom, rgba(0,0,0,.55), rgba(0,0,0,.65)), url('assets/hero-moulin-rouge-optimise.jpg')}
:root[data-theme="nuit-champagne"] .site-header{background-image:linear-gradient(to bottom, rgba(2,6,23,.65), rgba(2,6,23,.75)), url('assets/hero-moulin-rouge-optimise.jpg')}
:root[data-theme="creme-bordeaux"] .site-header{background-image:linear-gradient(to bottom, rgba(80,24,41,.45), rgba(80,24,41,.55)), url('assets/hero-moulin-rouge-optimise.jpg')}
:root[data-theme="emeraude"] .site-header{background-image:linear-gradient(to bottom, rgba(3,91,71,.45), rgba(3,91,71,.55)), url('assets/hero-moulin-rouge-optimise.jpg')}

/* Dropdown basic style */
#theme-select{border:1px solid #ead9c2;border-radius:999px;padding:.4rem .6rem;background:#fff;min-width:180px}
:root[data-theme="noir-or"] #theme-select,
:root[data-theme="nuit-champagne"] #theme-select{background:#1d2535;color:#fff;border-color:#30394d}

/* —— Fancy Theme Picker —— */
.theme-picker{position:relative; display:inline-block;}
.theme-picker__btn{
  display:flex; align-items:center; gap:.5rem;
  border:1px solid #ead9c2; border-radius:999px; padding:.45rem .75rem;
  background:#ffffff; cursor:pointer; box-shadow:0 4px 14px var(--ring);
}
:root[data-theme="noir-or"] .theme-picker__btn,
:root[data-theme="nuit-champagne"] .theme-picker__btn{ background:#1d2535; color:#fff; border-color:#30394d }

.theme-picker__chev{ opacity:.7 }
.theme-picker__list{
  position:absolute; right:0; top:calc(100% + 8px); min-width:230px; z-index:20;
  background:var(--card); border:1px solid #ead9c2; border-radius:12px; box-shadow:0 24px 60px rgba(0,0,0,.16);
  padding:.35rem; display:grid; gap:.25rem;
  transform-origin: 100% 0; transform: scale(.96) translateY(-6px); opacity:0; pointer-events:none;
  transition: transform .18s ease, opacity .18s ease;
}
.theme-picker__list.is-open{ transform: scale(1) translateY(0); opacity:1; pointer-events:auto; }
.theme-picker__item{
  display:flex; align-items:center; gap:.6rem; width:100%;
  background:transparent; border:none; border-radius:10px; padding:.5rem .6rem; cursor:pointer; text-align:left;
}
.theme-picker__item:hover{ background:rgba(184,138,68,.10) }
.theme-picker__item.is-active{ outline:2px solid var(--brand) }
.theme-picker__swatch{
  width:28px; height:28px; border-radius:50%;
  background: conic-gradient(from 220deg, var(--c1), var(--c2), var(--c3));
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.6), 0 2px 8px rgba(0,0,0,.15);
}
.theme-picker__name{ font-weight:600 }

/* Home YES counter */
.bigcount{font-size:clamp(1.1rem, 2.5vw, 1.25rem);}
.bigcount #home-yes-count{font-size:clamp(2rem, 6vw, 3rem); font-weight:900; line-height:1; display:inline-block; margin-right:.25rem}

/* Rotating festive/philosophical notes */
.philo-rot, .philo-note{font-style:italic; color:var(--muted); margin:.25rem 0 .5rem}
.philo-note{display:block}


/* Style mode (Pro ↔ Fun) */
:root{ --radius: 16px; --shadow: 0 10px 30px rgba(0,0,0,.08); --motion: 1 }
:root[data-style="pro"]{ --radius: 8px; --shadow: 0 6px 16px rgba(0,0,0,.06); --motion: 0 }
:root[data-style="pro"] .card{ border-color:#e8e5de }
:root[data-style="pro"] .card::before{ border-color:#eae7e0 }
:root[data-style="pro"] .card--artdeco::after{ opacity:.5 }
:root[data-style="pro"] .chip{ box-shadow:none }
:root[data-style="pro"] .btn{ box-shadow:none }
:root[data-style="pro"] .slideshow{ box-shadow: 0 8px 20px rgba(0,0,0,.08) }
:root[data-style="pro"] .card, :root[data-style="pro"] .slideshow, :root[data-style="pro"] .theme-picker__btn{ border-radius: 8px }
.nav-style{ margin-left:.5rem }
.style-switch{ display:inline-flex; background:rgba(255,255,255,.6); border:1px solid #ead9c2; border-radius:999px; padding:3px; gap:2px }
.style-btn{ border:0; border-radius:999px; padding:.35rem .7rem; cursor:pointer; background:transparent; color:inherit; opacity:.8 }
.style-btn.is-active{ background:var(--brand); color:white; opacity:1 }


/* —— Cards Grid —— */
.cards-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-top:1rem}
@media (max-width: 1100px){ .cards-grid{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media (max-width: 720px){ .cards-grid{grid-template-columns:1fr} }

.card-mini{background:var(--card);border:1px solid rgba(212,175,55,.35);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow);position:relative}
.card-mini .row{display:flex;align-items:center;gap:.8rem}
.avatar{width:46px;height:46px;border-radius:50%;display:inline-grid;place-items:center;font-weight:800;background:linear-gradient(135deg,var(--brand),var(--brand-ink));color:#fff;box-shadow:0 6px 14px var(--ring)}
.badge{display:inline-flex;align-items:center;gap:.35rem;border-radius:999px;padding:.2rem .55rem;font-weight:600;font-size:.85rem}
.badge.yes{background:rgba(16,185,129,.15);color:#047857}
.badge.maybe{background:rgba(245,158,11,.15);color:#92400e}
.badge.no{background:rgba(239,68,68,.15);color:#991b1b}
.meta{color:var(--muted);font-size:.9rem}

/* Icons for apports */
.icon{font-size:1.1rem}
.cat-food{background:rgba(234,179,8,.15);color:#7c2d12}
.cat-alcool{background:rgba(244,63,94,.15);color:#9f1239}
.cat-soft{background:rgba(59,130,246,.15);color:#1e3a8a}
.cat-autre{background:rgba(107,114,128,.15);color:#111827}

.card-mini .title{font-weight:700}
.card-mini .qty{font-weight:700}

/* —— Quotes (Livre d’or) —— */
.quotes-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-top:1rem}
@media (max-width: 900px){ .quotes-grid{grid-template-columns:1fr} }
.quote{background:var(--card);border:1px solid rgba(212,175,55,.35);border-radius:var(--radius);padding:1rem 1.25rem;box-shadow:var(--shadow);position:relative}
.quote::before{content:"“";position:absolute;left:.6rem;top:-.6rem;font-size:3rem;opacity:.25}
.quote .author{display:flex;align-items:center;gap:.6rem;margin-top:.6rem;color:var(--muted);font-size:.9rem}

/* —— Timeline (Planning) —— */
.timeline{position:relative;margin-top:1rem;padding-left:1.5rem}
.timeline::before{content:"";position:absolute;left:.5rem;top:0;bottom:0;width:2px;background:linear-gradient(var(--brand), rgba(212,175,55,.3))}
.t-item{position:relative;margin-bottom:1rem;padding-left:.75rem}
.t-time{font-weight:800}
.t-dot{position:absolute;left:-.05rem;top:.3rem;width:10px;height:10px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 3px rgba(212,175,55,.25)}
.t-card{margin-top:.35rem;background:var(--card);border:1px solid rgba(212,175,55,.35);border-radius:var(--radius);padding:.6rem .8rem;box-shadow:var(--shadow)}

/* —— Progress (Checklist) —— */
.progress{position:relative;height:14px;background:rgba(212,175,55,.15);border-radius:999px;margin:1rem 0}
.progress .bar{position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(135deg,#ffe083,#d4af37);border-radius:999px;transition:width .3s}
.progress .label{text-align:right;font-weight:700;font-size:.9rem;margin-top:.35rem;color:var(--muted)}
