/*
 * Hotel Orchid Imphal — Custom CSS
 * Supplements Tailwind CDN utilities
 */

/* ── Reset ────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'DM Sans', system-ui, sans-serif;
  background: #FAF7F3;
  color: #1C1410;
  -webkit-font-smoothing: antialiased;
}
.font-display { font-family: 'Playfair Display', Georgia, serif; }

/* ── Scrollbar ────────────────────────────────────────────── */
::-webkit-scrollbar       { width: 5px; }
::-webkit-scrollbar-track { background: #F0E8DF; }
::-webkit-scrollbar-thumb { background: #C4962A; border-radius: 3px; }

/* ── HTMX ─────────────────────────────────────────────────── */
.htmx-indicator               { opacity: 0; transition: opacity 150ms ease; }
.htmx-request .htmx-indicator,
.htmx-request.htmx-indicator  { opacity: 1; }
.htmx-added { animation: fadeUp .3s ease both; }
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Alpine ───────────────────────────────────────────────── */
[x-cloak] { display: none !important; }

/* ── Progress bar ─────────────────────────────────────────── */
#nprogress {
  position: fixed; top: 0; left: 0;
  width: 0%; height: 2px;
  background: #C4962A; z-index: 9999;
  transition: width .3s ease, opacity .3s ease;
  opacity: 0;
}

/* ── Nav underline ────────────────────────────────────────── */
.nav-link { position: relative; }
.nav-link::after {
  content: ''; position: absolute;
  bottom: -2px; left: 0; width: 0; height: 1.5px;
  background: #C4962A; transition: width .2s ease;
}
.nav-link:hover::after { width: 100%; }
.nav-active::after     { width: 100% !important; }

/* ── Form fields ──────────────────────────────────────────── */
.field-label {
  display: block; font-size: 11px; letter-spacing: .1em;
  text-transform: uppercase; color: #7A6A5A;
  font-weight: 600; margin-bottom: 6px;
}
.field-input {
  width: 100%; background: #FAF7F3;
  border: 1px solid rgba(107,79,58,.15); border-radius: 3px;
  padding: .625rem .85rem; font-size: .9rem; color: #1C1410;
  font-family: inherit; transition: border-color .15s ease, box-shadow .15s ease;
}
.field-input:focus {
  outline: none; border-color: #C4962A;
  box-shadow: 0 0 0 2px rgba(196,150,42,.15);
}
.field-input::placeholder { color: #D4C5A9; }
input[type="date"]::-webkit-calendar-picker-indicator { opacity: .4; cursor: pointer; }
input[type="date"]::-webkit-calendar-picker-indicator:hover { opacity: .85; }

/* ── Buttons ──────────────────────────────────────────────── */
.btn-gold {
  background: #C4962A; color: #1C1410; font-weight: 700;
  font-size: .875rem; border-radius: 3px; padding: .75rem 1.5rem;
  border: none; cursor: pointer; transition: background .2s ease;
}
.btn-gold:hover    { background: #a87d20; }
.btn-gold:disabled { opacity: .5; cursor: not-allowed; }

.btn-orchid {
  background: #6B4F3A; color: #FAF7F3; font-weight: 600;
  font-size: .875rem; border-radius: 3px; padding: .65rem 1.25rem;
  border: none; cursor: pointer; transition: background .2s ease;
}
.btn-orchid:hover { background: #4A3327; }

/* ── Cards ────────────────────────────────────────────────── */
.card {
  background: white; border-radius: 4px;
  border: 1px solid rgba(107,79,58,.1);
  box-shadow: 0 2px 12px rgba(28,20,16,.06);
  transition: box-shadow .3s ease, transform .3s ease;
}
.card:hover {
  box-shadow: 0 8px 28px rgba(28,20,16,.13);
  transform: translateY(-2px);
}

/* ── Badge ────────────────────────────────────────────────── */
.badge-gold {
  display: inline-block; background: #C4962A; color: #1C1410;
  font-size: 10px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; padding: .25rem .625rem; border-radius: 2px;
}
.badge-orchid {
  display: inline-block; background: #6B4F3A; color: white;
  font-size: 10px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; padding: .25rem .625rem; border-radius: 2px;
}

/* ── Spinner ──────────────────────────────────────────────── */
.spinner {
  display: inline-block; width: 1.25rem; height: 1.25rem;
  border: 2px solid rgba(28,20,16,.15); border-top-color: #1C1410;
  border-radius: 50%; animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Print (confirmation page) ────────────────────────────── */
@media print {
  header, footer, a[href="/book"], .no-print { display: none !important; }
  body { background: white; }
  .card { box-shadow: none; border: 1px solid #ddd; }
}
