/* Botón flotante "Tienda" */
html, body{ overflow-x:hidden; }
img, video, iframe{ max-width:100%; height:auto; }

.floating-actions{
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-end;
}

.floating-store-btn,
.floating-cart-btn,
.floating-appt-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 16px;
  border-radius: 999px;
  background: #00AE85;
  color: #013D48;
  font-weight: 800;
  letter-spacing: .3px;
  text-decoration: none;
  box-shadow: 0 14px 30px rgba(0,0,0,0.28);
  border: 2px solid rgba(255,255,255,0.18);
  transition: transform .18s ease, filter .18s ease;
  cursor: pointer;
}
.floating-store-btn:hover,
.floating-cart-btn:hover,
.floating-appt-btn:hover{
  transform: translateY(-2px);
  filter: brightness(1.03);
}
.floating-store-btn:active,
.floating-cart-btn:active,
.floating-appt-btn:active{
  transform: translateY(0);
}

.floating-cart-btn{ background: #ffffff; color: #013D48; }
.floating-appt-btn{ background: #013D48; color: #ffffff; }
.floating-appt-btn[data-soldout="1"]{ background:#2b2b2b; color:#fff; opacity:.9; cursor:not-allowed; }

.floating-badge{
  margin-left: 10px;
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 900;
  background: #FF4D6D;
  color: #fff;
}

/* Modal (citas) */
.modal{ position: fixed; inset:0; display:none; z-index:10000; }
.modal.is-open{ display:block; }
.modal__overlay{ position:absolute; inset:0; background: rgba(0,0,0,.55); }
.modal__dialog{
  position: relative;
  width: min(640px, calc(100% - 28px));
  margin: 9vh auto 0;
  background: #0B1B1F;
  color: #fff;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  box-shadow: 0 24px 60px rgba(0,0,0,.55);
  overflow:hidden;
}
.modal__header{ display:flex; align-items:flex-start; justify-content:space-between; gap:14px; padding: 16px 18px; background: rgba(255,255,255,.03); }
.modal__title{ font-weight: 1000; font-size: 18px; }
.modal__subtitle{ color: rgba(255,255,255,.65); font-size: 12px; margin-top: 2px; }
.modal__close{ background: transparent; border:0; color:#fff; font-size:18px; cursor:pointer; padding: 6px 8px; }
.modal__body{ padding: 16px 18px 18px; }

.appt-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.appt-field{ display:flex; flex-direction:column; gap: 6px; }
.appt-field span{ font-size: 12px; color: rgba(255,255,255,.65); font-weight: 700; }
.appt-field input, .appt-field select{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  border-radius: 12px;
  padding: 11px 12px;
  outline: none;
}
.appt-field input:focus, .appt-field select:focus{ border-color: rgba(0,174,133,.75); box-shadow: 0 0 0 4px rgba(0,174,133,.18); }
.appt-field--full{ grid-column: 1 / -1; }

.appt-actions{ display:flex; justify-content:flex-end; gap:10px; margin-top: 14px; flex-wrap:wrap; }
.btnPrimary{ background:#00AE85; border:0; color:#013D48; font-weight: 1000; padding: 11px 14px; border-radius: 12px; cursor:pointer; }
.btnGhost{ background: transparent; border: 1px solid rgba(255,255,255,.14); color:#fff; font-weight: 900; padding: 11px 14px; border-radius: 12px; cursor:pointer; }
.appt-status{ margin-top: 10px; font-size: 13px; color: rgba(255,255,255,.75); min-height: 18px; }
.appt-soldout{ background: rgba(255,77,109,.12); border:1px solid rgba(255,77,109,.25); padding: 12px; border-radius: 12px; }

@media (max-width: 640px){
  .appt-grid{ grid-template-columns: 1fr; }
}
