/* Inline availability results */
.result-box{
  background:#fff;
  border:1px solid #e8dfd6;
  border-radius:14px;
  padding:18px;
  margin:14px 0;
  box-shadow: var(--shadow, 0 8px 24px rgba(0,0,0,0.06));
}

/* Status helpers */
.ok{ color:#1a7f37; }
.no{ color:#b42318; }
.muted{ color:var(--muted, #6b7280); }

/* availability.css */
#availability .contact-form { margin-bottom: 1rem; }
#availability-result { margin-top: 0.75rem; }

/* Cards */
.avail-card{
  border-radius:14px;
  padding:1rem 1.125rem;
  border:1px solid rgba(0,0,0,0.06);
  box-shadow:0 8px 24px rgba(0,0,0,0.08);
  background:#fff; /* default; variants override */
}
.avail-card + .avail-card { margin-top:0.75rem; }

.avail-title{
  font-weight:600;
  margin-bottom:0.25rem;
}

/* Variants */
.avail-ok{
  background:#f3fff5;
  border-color:#d6f5db;
}
.avail-bad{
  background:#fff4f4;
  border-color:#ffd9d9;
}
.avail-warn{
  background:#fffaf0;
  border-color:#ffe6b3;
}
.avail-neutral{
  background:#f7f9fc;
  border-color:#e6ebf5;
}

/* CTA button (non-breaking if .btn already exists) */
.btn.primary.request-to-book{
  margin-top:0.5rem;
  display:inline-block;
  padding:0.65rem 1rem;
  border-radius:999px;
  border:none;
  cursor:pointer;
  font-weight:600;
}
.btn.primary.request-to-book:focus-visible{
  outline:2px solid #1a7f37;
  outline-offset:2px;
}
