/* === MYGALERIE — Module RDV — Styles luxe/chic === */
:root{
  --noir:#0e0e0e;
  --blanc:#ffffff;
  --creme:#faf8f5;
  --or:#b08d57;
  --or-clair:#d4b585;
  --gris:#7a7a7a;
  --gris-clair:#e8e4dd;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden}
body{
  font-family:'Inter',-apple-system,system-ui,sans-serif;
  font-size:16px;
  line-height:1.6;
  color:var(--noir);
  background:var(--creme);
}
h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:400;line-height:1.2}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

/* HEADER */
header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 40px;
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--gris-clair);
}
header .logo{font-family:'Cormorant Garamond',serif;font-size:1.6rem;letter-spacing:3px}
header .logo span{color:var(--or)}
header nav ul{display:flex;list-style:none;gap:32px}
header nav a{font-size:.85rem;letter-spacing:2px;text-transform:uppercase;color:#444}
header nav a:hover,header nav a.active{color:var(--or)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer}
.hamburger span{width:26px;height:1.5px;background:var(--noir)}

/* MAIN */
main{padding:120px 20px 60px;min-height:80vh}
.container{max-width:900px;margin:0 auto}

.overline{
  display:block;font-size:.75rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--or);margin-bottom:16px;
}
h1.page-title{
  font-size:clamp(2.2rem,5vw,3.6rem);
  margin-bottom:18px;
  text-align:center;
}
.page-intro{
  text-align:center;max-width:600px;margin:0 auto 50px;
  color:var(--gris);font-size:1.05rem;
}

/* FORM */
.rdv-card{
  background:var(--blanc);
  padding:48px 40px;
  border-radius:4px;
  box-shadow:0 4px 30px rgba(0,0,0,0.05);
  border:1px solid var(--gris-clair);
}
.step{display:none}
.step.active{display:block;animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.step-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.8rem;margin-bottom:8px;
}
.step-sub{color:var(--gris);margin-bottom:30px;font-size:.95rem}

.step-bar{
  display:flex;justify-content:center;gap:8px;margin-bottom:36px;
}
.step-dot{
  width:36px;height:3px;background:var(--gris-clair);border-radius:2px;
  transition:background .3s;
}
.step-dot.done{background:var(--or)}

/* Types RDV */
.types-grid{display:flex;flex-direction:column;gap:14px}
.type-option{
  padding:20px 22px;
  border:1px solid var(--gris-clair);
  border-radius:4px;cursor:pointer;
  transition:all .25s;background:var(--blanc);
  display:flex;align-items:center;gap:18px;
}
.type-option:hover{border-color:var(--or);transform:translateY(-1px)}
.type-option.selected{border-color:var(--or);background:#fcf9f4}
.type-option .ico{
  width:44px;height:44px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--or);color:var(--or);border-radius:50%;
}
.type-option .ico svg{width:22px;height:22px}
.type-option h3{font-size:1.15rem;margin-bottom:2px}
.type-option p{font-size:.85rem;color:var(--gris)}

/* Calendar */
.cal-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:20px;
}
.cal-head h3{font-size:1.4rem}
.cal-nav{display:flex;gap:8px}
.cal-nav button{
  width:38px;height:38px;border:1px solid var(--gris-clair);
  background:var(--blanc);cursor:pointer;border-radius:50%;
  font-size:1rem;transition:all .2s;
}
.cal-nav button:hover:not(:disabled){border-color:var(--or);color:var(--or)}
.cal-nav button:disabled{opacity:.3;cursor:not-allowed}
.cal-grid{
  display:grid;grid-template-columns:repeat(7,1fr);gap:6px;
}
.cal-dow{
  text-align:center;font-size:.75rem;color:var(--gris);
  letter-spacing:2px;padding:8px 0;text-transform:uppercase;
}
.cal-day{
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  border:1px solid transparent;cursor:pointer;border-radius:4px;
  font-size:.95rem;transition:all .2s;background:var(--creme);
}
.cal-day:hover:not(.disabled):not(.empty){border-color:var(--or)}
.cal-day.disabled{opacity:.25;cursor:not-allowed;background:transparent}
.cal-day.empty{cursor:default;background:transparent}
.cal-day.selected{background:var(--or);color:var(--blanc)}
.cal-day.today{font-weight:600}

.creneaux-wrap{margin-top:30px}
.creneaux-title{font-size:.9rem;color:var(--gris);margin-bottom:14px;letter-spacing:1px}
.creneaux-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px}
.creneau{
  padding:12px;border:1px solid var(--gris-clair);background:var(--blanc);
  text-align:center;cursor:pointer;border-radius:4px;
  font-size:.95rem;transition:all .2s;
}
.creneau:hover:not(.taken){border-color:var(--or);color:var(--or)}
.creneau.selected{background:var(--or);color:var(--blanc);border-color:var(--or)}
.creneau.taken{opacity:.3;cursor:not-allowed;text-decoration:line-through}

/* Form inputs */
.field{margin-bottom:20px}
.field label{
  display:block;font-size:.85rem;letter-spacing:1px;
  text-transform:uppercase;color:var(--gris);margin-bottom:8px;
}
.field input,.field textarea{
  width:100%;padding:14px 16px;font-size:16px;
  border:1px solid var(--gris-clair);background:var(--creme);
  border-radius:4px;font-family:inherit;color:var(--noir);
  transition:border-color .2s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--or)}
.field textarea{min-height:110px;resize:vertical}

/* Récap */
.recap{
  background:var(--creme);padding:24px;border-radius:4px;
  border-left:3px solid var(--or);margin-bottom:24px;
}
.recap-line{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--gris-clair);font-size:.95rem}
.recap-line:last-child{border-bottom:none}
.recap-line span:first-child{color:var(--gris);text-transform:uppercase;letter-spacing:1px;font-size:.78rem}

/* Buttons */
.actions{display:flex;justify-content:space-between;gap:14px;margin-top:30px}
.btn{
  padding:14px 28px;font-size:.85rem;letter-spacing:2px;
  text-transform:uppercase;cursor:pointer;border:none;border-radius:0;
  transition:all .25s;font-family:inherit;
}
.btn-dark{background:var(--noir);color:var(--blanc)}
.btn-dark:hover{background:var(--or)}
.btn-ghost{background:transparent;color:var(--noir);border:1px solid var(--gris-clair)}
.btn-ghost:hover{border-color:var(--noir)}
.btn:disabled{opacity:.4;cursor:not-allowed}

/* Success */
.success-box{text-align:center;padding:30px 0}
.success-box .check{
  width:80px;height:80px;margin:0 auto 24px;
  border-radius:50%;background:#e8f5e9;color:#2e7d32;
  display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;
}
.success-box h2{font-size:2.2rem;margin-bottom:12px}
.success-box p{color:var(--gris);margin-bottom:24px;max-width:480px;margin-left:auto;margin-right:auto}

/* Errors */
.alert{
  padding:14px 18px;border-radius:4px;margin-bottom:20px;
  background:#fde8e8;color:#c81e1e;font-size:.92rem;
}

/* FOOTER */
footer{
  background:var(--noir);color:#aaa;padding:40px 20px;text-align:center;
  font-size:.85rem;letter-spacing:1px;
}
footer a{color:var(--or-clair)}

/* MOBILE */
@media (max-width:768px){
  header{padding:16px 20px}
  header nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--blanc);padding:20px;border-bottom:1px solid var(--gris-clair)}
  header nav.open{display:block}
  header nav ul{flex-direction:column;gap:18px}
  .hamburger{display:flex}
  main{padding:100px 16px 40px}
  .rdv-card{padding:30px 22px}
  .step-title{font-size:1.5rem}
  .actions{flex-direction:column-reverse}
  .actions .btn{width:100%}
  .cal-day{font-size:.85rem}
  .type-option{padding:16px}
}

/* ADMIN */
.admin-wrap{max-width:1100px;margin:0 auto}
.admin-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:30px;flex-wrap:wrap;gap:14px;
}
.admin-head h1{font-size:2.2rem}
.admin-actions-bar{display:flex;gap:10px;flex-wrap:wrap}
.admin-actions-bar a{
  font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase;
  padding:10px 18px;border:1px solid var(--gris-clair);background:var(--blanc);
  transition:all .2s;
}
.admin-actions-bar a:hover{border-color:var(--or);color:var(--or)}
.admin-actions-bar a.danger{color:#c81e1e}

.stats{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:14px;margin-bottom:30px;
}
.stat-card{
  background:var(--blanc);padding:22px;border:1px solid var(--gris-clair);
  border-radius:4px;text-align:center;
}
.stat-card .num{font-family:'Cormorant Garamond',serif;font-size:2.4rem;color:var(--or)}
.stat-card .lbl{font-size:.78rem;letter-spacing:2px;text-transform:uppercase;color:var(--gris);margin-top:4px}

.filters{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.filter-btn{
  padding:8px 16px;font-size:.78rem;letter-spacing:1.5px;
  text-transform:uppercase;border:1px solid var(--gris-clair);
  background:var(--blanc);cursor:pointer;border-radius:30px;transition:all .2s;
}
.filter-btn:hover{border-color:var(--or)}
.filter-btn.active{background:var(--noir);color:var(--blanc);border-color:var(--noir)}

.rdv-list{display:flex;flex-direction:column;gap:12px}
.rdv-item{
  background:var(--blanc);padding:20px 24px;border:1px solid var(--gris-clair);
  border-radius:4px;display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;
}
.rdv-item .date-block{
  text-align:center;min-width:80px;padding-right:18px;border-right:1px solid var(--gris-clair);
}
.rdv-item .date-block .jour{font-family:'Cormorant Garamond',serif;font-size:1.8rem;line-height:1;color:var(--noir)}
.rdv-item .date-block .mois{font-size:.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--or);margin-top:4px}
.rdv-item .date-block .heure{font-size:.85rem;color:var(--gris);margin-top:6px}
.rdv-item .info h3{font-family:'Inter',sans-serif;font-size:1rem;font-weight:500;margin-bottom:4px}
.rdv-item .info .sub{font-size:.85rem;color:var(--gris)}
.rdv-item .info .meta{font-size:.78rem;color:var(--or);margin-top:6px;letter-spacing:1px;text-transform:uppercase}
.rdv-item .info .msg{font-size:.85rem;color:#555;margin-top:8px;padding-top:8px;border-top:1px dashed var(--gris-clair)}
.rdv-item .actions-btns{display:flex;flex-direction:column;gap:6px}
.rdv-item .actions-btns button,.rdv-item .actions-btns a{
  padding:6px 14px;font-size:.72rem;letter-spacing:1px;text-transform:uppercase;
  border:1px solid var(--gris-clair);background:var(--blanc);cursor:pointer;
  text-align:center;transition:all .2s;
}
.btn-confirm{color:#2e7d32;border-color:#a5d6a7!important}
.btn-confirm:hover{background:#e8f5e9}
.btn-refuse{color:#c81e1e;border-color:#ef9a9a!important}
.btn-refuse:hover{background:#fde8e8}
.statut-badge{
  display:inline-block;padding:3px 10px;font-size:.7rem;letter-spacing:1.5px;
  text-transform:uppercase;border-radius:30px;margin-left:6px;
}
.statut-en_attente{background:#fff3cd;color:#856404}
.statut-confirme{background:#d4edda;color:#155724}
.statut-refuse{background:#f8d7da;color:#721c24}

.empty-state{
  text-align:center;padding:60px 20px;color:var(--gris);
}
.empty-state svg{width:60px;height:60px;margin-bottom:14px;opacity:.4}

/* Login */
.login-box{
  max-width:400px;margin:80px auto;background:var(--blanc);
  padding:40px 32px;border:1px solid var(--gris-clair);border-radius:4px;
}
.login-box h1{font-size:2rem;text-align:center;margin-bottom:8px}
.login-box .sub{text-align:center;color:var(--gris);margin-bottom:28px;font-size:.9rem}
.login-box .btn{width:100%}

@media (max-width:640px){
  .rdv-item{grid-template-columns:1fr;gap:12px}
  .rdv-item .date-block{border-right:none;border-bottom:1px solid var(--gris-clair);padding:0 0 12px 0;display:flex;gap:16px;align-items:center;justify-content:flex-start}
  .rdv-item .actions-btns{flex-direction:row}
}
