/* Réservation Restopour — styles dédiés */

.resa-wrap{
  max-width:760px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:32px;
}

.resa-step{
  background:rgba(255,255,255,.02);
  border:1px solid rgba(201,169,110,.18);
  border-radius:16px;
  padding:28px 22px;
}

.step-head{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:20px;
}
.step-num{
  width:34px;height:34px;border-radius:50%;
  background:var(--gold-2,#c9a96e);
  color:#0d0d12;
  font-weight:600;
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;
  font-size:1.05rem;
  flex-shrink:0;
}
.step-head h2{
  font-size:1.4rem;
  margin:0;
}

/* Calendrier */
.cal-controls{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;
  gap:10px;
}
.cal-nav{
  width:36px;height:36px;
  border-radius:8px;
  background:rgba(201,169,110,.1);
  border:1px solid rgba(201,169,110,.25);
  color:var(--gold-2,#c9a96e);
  font-size:1.3rem;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-family:inherit;
}
.cal-nav:hover{background:rgba(201,169,110,.18);}
.cal-title{
  font-family:'Playfair Display',serif;
  font-size:1.15rem;
  color:#fff;
  text-transform:capitalize;
}
.cal-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:6px;
}
.cal-head span{
  text-align:center;
  font-size:.72rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--muted,#888);
  padding:6px 0;
}
.cal-day{
  aspect-ratio:1;
  border:1px solid rgba(201,169,110,.12);
  background:transparent;
  color:#ddd;
  border-radius:8px;
  font-size:.92rem;
  cursor:pointer;
  font-family:inherit;
  padding:0;
  transition:.15s;
}
.cal-day.cal-empty{border:none;cursor:default;background:transparent;}
.cal-day.cal-closed{
  color:#444;
  background:rgba(255,255,255,.015);
  border-color:rgba(255,255,255,.04);
  cursor:not-allowed;
}
.cal-day.cal-open:hover{
  background:rgba(201,169,110,.15);
  border-color:rgba(201,169,110,.4);
  color:#fff;
}
.cal-day.cal-selected{
  background:var(--gold-2,#c9a96e)!important;
  color:#0d0d12!important;
  border-color:var(--gold-2,#c9a96e)!important;
  font-weight:600;
}
.cal-legend{
  margin-top:14px;
  font-size:.78rem;
  color:var(--muted,#888);
  display:flex;gap:14px;flex-wrap:wrap;
}
.dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px;vertical-align:-1px;}
.dot-open{background:rgba(201,169,110,.4);}
.dot-closed{background:#333;}
.dot-selected{background:var(--gold-2,#c9a96e);}

/* Créneaux */
.slot-sub{
  color:var(--muted,#888);
  margin-bottom:18px;
  font-size:.95rem;
}
.slots-section{margin-bottom:18px;}
.slots-section h4{
  font-size:.78rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--gold-2,#c9a96e);
  margin-bottom:10px;
  font-weight:500;
}
.slot-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(82px,1fr));
  gap:8px;
}
.slot-btn{
  padding:10px 6px;
  border-radius:8px;
  border:1px solid rgba(201,169,110,.25);
  background:rgba(201,169,110,.06);
  color:#fff;
  font-family:inherit;
  font-size:.92rem;
  cursor:pointer;
  transition:.15s;
}
.slot-btn:hover{background:rgba(201,169,110,.18);border-color:rgba(201,169,110,.5);}
.slot-btn.slot-active{
  background:var(--gold-2,#c9a96e);
  color:#0d0d12;
  border-color:var(--gold-2,#c9a96e);
  font-weight:600;
}
.slot-btn.slot-full{
  text-decoration:line-through;
  opacity:.4;
  cursor:not-allowed;
  background:transparent;
}
.slot-loading{color:var(--muted,#888);font-size:.9rem;}

/* Formulaire */
.recap{
  background:rgba(201,169,110,.08);
  border:1px solid rgba(201,169,110,.25);
  color:var(--gold-2,#c9a96e);
  padding:12px 16px;
  border-radius:10px;
  font-size:.95rem;
  margin-bottom:20px;
  text-align:center;
  font-family:'Playfair Display',serif;
}
#resa-form label{
  display:block;
  margin-bottom:16px;
}
#resa-form label > span{
  display:block;
  font-size:.78rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted,#888);
  margin-bottom:6px;
}
#resa-form input,
#resa-form textarea{
  width:100%;
  padding:12px 14px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(201,169,110,.2);
  border-radius:10px;
  color:#fff;
  font-family:inherit;
  font-size:16px;
  outline:none;
  transition:.15s;
}
#resa-form input:focus,
#resa-form textarea:focus{
  border-color:var(--gold-2,#c9a96e);
  background:rgba(255,255,255,.05);
}
#resa-form textarea{resize:vertical;min-height:80px;}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.form-actions{
  display:flex;gap:12px;justify-content:flex-end;
  margin-top:10px;
  flex-wrap:wrap;
}
.form-actions .btn{padding:10px 18px;font-size:.92rem;}
.form-err{
  margin-top:12px;
  color:#e07474;
  font-size:.9rem;
  text-align:center;
}

/* Confirmation */
.done-card{
  text-align:center;
  padding:14px 0;
}
.done-icon{
  width:72px;height:72px;
  margin:0 auto 18px;
  border-radius:50%;
  background:rgba(201,169,110,.12);
  border:1px solid var(--gold-2,#c9a96e);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-2,#c9a96e);
}
.done-icon svg{width:34px;height:34px;}
.done-card h2{font-size:1.6rem;margin-bottom:14px;}
.done-card p{color:#ddd;line-height:1.6;}
.done-note{color:var(--muted,#888)!important;font-size:.9rem;margin-top:14px;}

@media (max-width:640px){
  .resa-step{padding:22px 16px;}
  .form-row{grid-template-columns:1fr;}
  .form-actions{justify-content:stretch;}
  .form-actions .btn{flex:1;}
  .cal-day{font-size:.85rem;}
  .step-head h2{font-size:1.2rem;}
}

/* Bloc admin reservations */
.admin-resa-block{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(201,169,110,.2);
  border-radius:14px;
  padding:22px;
  margin-bottom:22px;
}
.admin-resa-block h3{
  color:var(--gold-2,#c9a96e);
  font-size:1.05rem;
  margin-bottom:14px;
}
.resa-table{
  width:100%;
  border-collapse:collapse;
  font-size:.88rem;
}
.resa-table th,.resa-table td{
  text-align:left;
  padding:10px 8px;
  border-bottom:1px solid rgba(201,169,110,.12);
}
.resa-table th{
  color:var(--muted,#888);
  text-transform:uppercase;
  font-size:.7rem;
  letter-spacing:.08em;
  font-weight:500;
}
.resa-table tr.cancelled{opacity:.45;text-decoration:line-through;}
.btn-mini{
  padding:5px 10px;
  font-size:.78rem;
  background:rgba(224,116,116,.12);
  border:1px solid rgba(224,116,116,.4);
  color:#e07474;
  border-radius:6px;
  cursor:pointer;
  font-family:inherit;
}
.btn-mini:hover{background:rgba(224,116,116,.22);}
.btn-mini.btn-del{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.15);color:#aaa;}
.resa-empty{color:var(--muted,#888);text-align:center;padding:20px;font-style:italic;}
.resa-scroll{overflow-x:auto;}
