/* =====================================================
   NAMIREMBE GUESTHOUSE -- REUSABLE COMPONENTS
   Buttons, cards, modals, forms, badges, tabs, etc.
   ===================================================== */

/* ******************************************************
   BUTTONS
   ****************************************************** */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.75rem 1.5rem;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  border-radius: var(--radius-sm);
  border: 1.5px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: var(--transition-base);
  text-decoration: none;
  position: relative;
  overflow: hidden;
  min-height: 44px;
}

.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0);
  transition: background var(--duration-fast) var(--ease-out);
}

.btn:hover::after {
  background: rgba(255,255,255,0.08);
}

.btn:active {
  transform: translateY(1px);
}

/* Primary -- Gold */
.btn-primary {
  background: var(--gradient-gold);
  color: var(--color-white);
  border-color: var(--color-ochre-dark);
  box-shadow: var(--shadow-gold);
}

.btn-primary:hover {
  box-shadow: 0 6px 24px rgba(193, 127, 36, 0.45);
  transform: translateY(-1px);
  color: var(--color-white);
}

/* Secondary -- Forest Green */
.btn-secondary {
  background: var(--color-forest);
  color: var(--color-ivory-pale);
  border-color: var(--color-forest-mid);
}

.btn-secondary:hover {
  background: var(--color-forest-mid);
  color: var(--color-ivory);
  transform: translateY(-1px);
}

/* Outline -- Gold border */
.btn-outline {
  background: transparent;
  color: var(--color-ochre-dark);
  border-color: var(--color-ochre);
}

.btn-outline:hover {
  background: var(--color-ochre-pale);
  color: var(--color-ochre-dark);
}

/* Ghost -- for dark backgrounds */
.btn-ghost {
  background: var(--glass-btn-bg);
  color: var(--color-ivory);
  border-color: var(--glass-text-dim);
  backdrop-filter: blur(8px);
}

.btn-ghost:hover {
  background: var(--glass-btn-hover);
  border-color: var(--glass-text);
  color: var(--color-ivory);
}

/* Danger */
.btn-danger {
  background: var(--color-rust);
  color: var(--color-white);
  border-color: var(--color-rust);
}

.btn-danger:hover {
  background: var(--color-rust-light);
  color: var(--color-white);
}

/* Sizes */
.btn-sm {
  padding: 0.5rem 1rem;
  font-size: var(--text-xs);
  min-height: 36px;
}

.btn-lg {
  padding: 1rem 2rem;
  font-size: var(--text-md);
  min-height: 52px;
}

.btn-xl {
  padding: 1.25rem 2.5rem;
  font-size: var(--text-lg);
  min-height: 60px;
}

/* Full width */
.btn-block {
  width: 100%;
  justify-content: center;
}

/* Icon only */
.btn-icon {
  padding: 0.625rem;
  min-width: 44px;
  min-height: 44px;
}

/* Loading state */
.btn.is-loading {
  pointer-events: none;
  opacity: 0.8;
}

.btn.is-loading::before {
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid rgba(255,255,255,0.4);
  border-top-color: white;
  border-radius: 50%;
  animation: btn-spin 0.7s linear infinite;
  margin-right: var(--space-2);
}

@keyframes btn-spin {
  to { transform: rotate(360deg); }
}

/* Disabled */
.btn:disabled,
.btn.is-disabled {
  opacity: 0.45;
  pointer-events: none;
  cursor: not-allowed;
}

/* ******************************************************
   CARDS
   ****************************************************** */

.card {
  background: var(--color-ivory-warm);
  border: var(--border-thin);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: var(--transition-slow);
  position: relative;
}

.card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
  border-color: transparent;
}

.card__image {
  position: relative;
  overflow: hidden;
}

.card__image img {
  width: 100%;
  height: 240px;
  object-fit: cover;
  transition: transform var(--duration-slower) var(--ease-out);
}

.card:hover .card__image img {
  transform: scale(1.05);
}

.card__badge {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  z-index: var(--z-raised);
}

.card__body {
  padding: var(--space-6);
}

.card__body--compact {
  padding: var(--space-4);
}

.card__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
  color: var(--color-earth-light);
  margin-bottom: var(--space-2);
  flex-wrap: wrap;
}

.card__title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--weight-normal);
  line-height: var(--leading-snug);
  color: var(--color-earth);
  margin-bottom: var(--space-2);
}

.card__desc {
  font-size: var(--text-sm);
  color: var(--color-earth-mid);
  line-height: var(--leading-relaxed);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  border-top: var(--border-thin);
  gap: var(--space-4);
}

/* Room card variant */
.room-card .card__image img {
  height: 280px;
}

/* Flat card (no hover lift) */
.card--flat {
  transition: border-color var(--duration-fast);
}

.card--flat:hover {
  transform: none;
  box-shadow: var(--shadow-sm);
  border-color: var(--color-ochre);
}

/* ******************************************************
   BADGES & TAGS
   ****************************************************** */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0.2rem 0.6rem;
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  border-radius: var(--radius-full);
  white-space: nowrap;
  line-height: 1;
}

.badge-gold    { background: var(--color-ochre-pale); color: var(--color-ochre-dark); border: 1px solid rgba(214,99,193,0.3); }
.badge-forest  { background: var(--color-forest-pale); color: var(--color-forest); border: 1px solid rgba(30,58,47,0.2); }
.badge-rust    { background: var(--color-rust-pale); color: var(--color-rust); border: 1px solid rgba(166,61,47,0.2); }
.badge-success { background: var(--color-success-pale); color: var(--color-success); }
.badge-warning { background: var(--color-warning-pale); color: var(--color-warning); }
.badge-danger  { background: var(--color-danger-pale); color: var(--color-danger); }
.badge-info    { background: var(--color-info-pale); color: var(--color-info); }
.badge-neutral { background: var(--color-ivory-dark); color: var(--color-earth-mid); }
.badge-dark    { background: var(--color-earth); color: var(--color-ivory); }

/* Status badges */
.badge-status-pending     { background: var(--status-pending-bg); color: var(--status-pending-text); }
.badge-status-confirmed   { background: var(--status-confirmed-bg); color: var(--status-confirmed-text); }
.badge-status-checked_in  { background: var(--status-checkin-bg); color: var(--status-checkin-text); }
.badge-status-checked_out { background: var(--status-checkout-bg); color: var(--status-checkout-text); }
.badge-status-cancelled   { background: var(--status-cancelled-bg); color: var(--status-cancelled-text); }
.badge-status-placed      { background: var(--status-placed-bg); color: var(--status-placed-text); }
.badge-status-preparing   { background: var(--status-preparing-bg); color: var(--status-preparing-text); }
.badge-status-ready       { background: var(--status-ready-bg); color: var(--status-ready-text); }
.badge-status-delivered   { background: var(--status-delivered-bg); color: var(--status-delivered-text); }

/* Tag pill */
.tag {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.75rem;
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  background: var(--color-ivory-dark);
  color: var(--color-earth-mid);
  border-radius: var(--radius-full);
  transition: var(--transition-fast);
  cursor: default;
}

.tag:hover {
  background: var(--color-ochre-pale);
  color: var(--color-ochre-dark);
}

.tag--active {
  background: var(--color-ochre);
  color: var(--color-white);
}

/* ******************************************************
   FORMS
   ****************************************************** */

.form-group {
  margin-bottom: var(--space-5);
}

.form-label {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-earth);
  margin-bottom: var(--space-2);
}

.form-label .required {
  color: var(--color-rust);
  margin-left: 3px;
}

.form-control {
  width: 100%;
  padding: 0.75rem 1rem;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-earth);
  background: var(--bg-surface);
  border: 1.5px solid var(--color-ivory-dark);
  border-radius: var(--radius-md);
  transition: border-color var(--duration-fast), box-shadow var(--duration-fast);
  min-height: 44px;
}

.form-control::placeholder {
  color: var(--color-mist);
}

.form-control:hover {
  border-color: var(--color-cloud);
}

.form-control:focus {
  border-color: var(--color-ochre);
  box-shadow: 0 0 0 3px rgba(193, 127, 36, 0.15);
  outline: none;
}

.form-control.is-error {
  border-color: var(--color-rust);
}

.form-control.is-error:focus {
  box-shadow: 0 0 0 3px rgba(166, 61, 47, 0.15);
}

.form-control.is-success {
  border-color: var(--color-success);
}

textarea.form-control {
  resize: vertical;
  min-height: 120px;
  line-height: var(--leading-relaxed);
}

select.form-control {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238B6550' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
  cursor: pointer;
}

/* Input with icon */
.form-control-wrap {
  position: relative;
}

.form-control-wrap .form-control {
  padding-left: 2.75rem;
}

.form-control-wrap .form-control.has-suffix {
  padding-right: 2.75rem;
}

.form-control-icon {
  position: absolute;
  top: 50%;
  left: 0.875rem;
  transform: translateY(-50%);
  color: var(--color-mist);
  pointer-events: none;
  width: 18px;
  height: 18px;
}

.form-control-suffix {
  position: absolute;
  top: 50%;
  right: 0.875rem;
  transform: translateY(-50%);
  color: var(--color-earth-light);
  cursor: pointer;
}

/* Form hint */
.form-hint {
  font-size: var(--text-xs);
  color: var(--color-earth-light);
  margin-top: var(--space-2);
  line-height: var(--leading-normal);
}

.form-error {
  font-size: var(--text-xs);
  color: var(--color-rust);
  margin-top: var(--space-2);
  display: flex;
  align-items: center;
  gap: 4px;
}

/* Checkbox & Radio */
.form-check {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  cursor: pointer;
}

.form-check input[type="checkbox"],
.form-check input[type="radio"] {
  width: 18px;
  height: 18px;
  min-width: 18px;
  accent-color: var(--color-ochre);
  margin-top: 2px;
  cursor: pointer;
}

.form-check-label {
  font-size: var(--text-sm);
  color: var(--color-earth-mid);
  line-height: var(--leading-relaxed);
  cursor: pointer;
}

/* Toggle switch */
.toggle {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  cursor: pointer;
}

.toggle__track {
  position: relative;
  width: 44px;
  height: 24px;
  background: var(--color-cloud);
  border-radius: var(--radius-full);
  transition: background var(--duration-base);
}

.toggle__thumb {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  background: var(--bg-surface);
  border-radius: 50%;
  box-shadow: var(--shadow-xs);
  transition: transform var(--duration-base) var(--ease-spring);
}

.toggle input:checked ~ .toggle__track {
  background: var(--color-ochre);
}

.toggle input:checked ~ .toggle__track .toggle__thumb {
  transform: translateX(20px);
}

.toggle input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

/* Password strength */
.password-strength {
  margin-top: var(--space-2);
}

.password-strength__bar {
  height: 4px;
  background: var(--color-ivory-dark);
  border-radius: var(--radius-full);
  overflow: hidden;
  margin-bottom: 6px;
}

.password-strength__fill {
  height: 100%;
  border-radius: var(--radius-full);
  transition: width var(--duration-slow), background var(--duration-slow);
  width: 0%;
}

.password-strength__fill[data-strength="1"] { width: 25%; background: var(--color-rust); }
.password-strength__fill[data-strength="2"] { width: 50%; background: var(--color-warn); }
.password-strength__fill[data-strength="3"] { width: 75%; background: var(--color-warning); }
.password-strength__fill[data-strength="4"] { width: 100%; background: var(--color-success); }

.password-strength__label {
  font-size: var(--text-xs);
  color: var(--color-earth-light);
}

/* ******************************************************
   MODALS
   ****************************************************** */

.modal-overlay {
  position: fixed;
  inset: 0;
  background: var(--bg-overlay);
  backdrop-filter: blur(4px);
  z-index: var(--z-modal-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-base) var(--ease-out);
}

.modal-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}

.modal {
  background: var(--color-ivory-warm);
  border-radius: var(--radius-xl);
  width: 100%;
  max-width: 560px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: var(--shadow-2xl);
  transform: scale(0.95) translateY(16px);
  transition: transform var(--duration-slow) var(--ease-spring),
              opacity var(--duration-slow) var(--ease-out);
  opacity: 0;
}

.modal-overlay.is-open .modal {
  transform: scale(1) translateY(0);
  opacity: 1;
}

.modal--lg { max-width: 760px; }
.modal--xl { max-width: 960px; }
.modal--sm { max-width: 400px; }

.modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-6) var(--space-6) var(--space-4);
  border-bottom: var(--border-thin);
}

.modal__title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--weight-normal);
  color: var(--color-earth);
}

.modal__close {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  color: var(--color-earth-light);
  transition: var(--transition-fast);
}

.modal__close:hover {
  background: var(--color-ivory-dark);
  color: var(--color-earth);
}

.modal__body {
  padding: var(--space-6);
}

.modal__footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-6) var(--space-6);
  border-top: var(--border-thin);
}

/* ******************************************************
   TABS
   ****************************************************** */

.tabs {
  border-bottom: var(--border-thin);
  margin-bottom: var(--space-8);
}

.tabs__list {
  display: flex;
  gap: var(--space-1);
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.tabs__list::-webkit-scrollbar { display: none; }

.tabs__btn {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-earth-light);
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: var(--transition-fast);
  margin-bottom: -1px;
}

.tabs__btn:hover {
  color: var(--color-ochre);
}

.tabs__btn.is-active {
  color: var(--color-ochre-dark);
  border-bottom-color: var(--color-ochre);
}

.tab-panel {
  display: none;
}

.tab-panel.is-active {
  display: block;
  animation: tab-enter var(--duration-base) var(--ease-out) forwards;
}

@keyframes tab-enter {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Menu category tabs variant */
.menu-tabs {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-8);
}

.menu-tab {
  padding: var(--space-2) var(--space-5);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-earth-mid);
  background: var(--color-ivory-dark);
  border-radius: var(--radius-full);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: var(--transition-fast);
  min-height: 44px;
}

.menu-tab:hover {
  background: var(--color-ochre-pale);
  color: var(--color-ochre-dark);
}

.menu-tab.is-active {
  background: var(--color-ochre);
  color: var(--color-white);
  border-color: var(--color-ochre-dark);
}

/* ******************************************************
   ALERTS / INFO PANELS
   ****************************************************** */

.alert {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  border: 1px solid;
  line-height: var(--leading-relaxed);
}

.alert-icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin-top: 1px;
}

.alert-title {
  font-weight: var(--weight-semibold);
  margin-bottom: 2px;
}

.alert-success { background: var(--color-success-pale); color: var(--color-success); border-color: var(--color-ok-border); }
.alert-warning { background: var(--color-warning-pale); color: var(--color-warning); border-color: var(--color-warn-border); }
.alert-danger  { background: var(--color-danger-pale);  color: var(--color-danger);  border-color: var(--color-error-border); }
.alert-info    { background: var(--color-info-pale);    color: var(--color-info);    border-color: var(--color-info-blue-border); }

/* ******************************************************
   DROPDOWN
   ****************************************************** */

.dropdown {
  position: relative;
  display: inline-block;
}

.dropdown__menu {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  min-width: 200px;
  background: var(--bg-surface);
  border: var(--border-thin);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  z-index: var(--z-dropdown);
  padding: var(--space-2);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-8px) scale(0.97);
  transform-origin: top right;
  transition: opacity var(--duration-base), transform var(--duration-base) var(--ease-spring);
}

.dropdown__menu.is-open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.dropdown__item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-earth);
  border-radius: var(--radius-md);
  transition: var(--transition-fast);
  cursor: pointer;
}

.dropdown__item:hover {
  background: var(--color-ochre-pale);
  color: var(--color-ochre-dark);
}

.dropdown__item--danger:hover {
  background: var(--color-rust-pale);
  color: var(--color-rust);
}

.dropdown__divider {
  border: none;
  border-top: var(--border-thin);
  margin: var(--space-2) 0;
}

/* ******************************************************
   TOOLTIPS
   ****************************************************** */

[data-tooltip] {
  position: relative;
}

[data-tooltip]::before {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  background: var(--color-earth);
  color: var(--color-ivory);
  font-size: var(--text-xs);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-md);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--duration-fast);
  z-index: var(--z-tooltip);
}

[data-tooltip]:hover::before {
  opacity: 1;
}

/* ******************************************************
   PROGRESS BAR
   ****************************************************** */

.progress {
  height: 6px;
  background: var(--color-ivory-dark);
  border-radius: var(--radius-full);
  overflow: hidden;
}

.progress__bar {
  height: 100%;
  background: var(--gradient-gold);
  border-radius: var(--radius-full);
  transition: width var(--duration-slow) var(--ease-out);
}

/* ******************************************************
   BOOKING SUMMARY PANEL
   ****************************************************** */

.booking-summary {
  background: var(--color-ivory-warm);
  border: var(--border-thin);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}

.booking-summary__title {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-4);
  border-bottom: var(--border-thin);
}

.booking-summary__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block: var(--space-2);
  font-size: var(--text-sm);
}

.booking-summary__row--total {
  border-top: var(--border-gold);
  margin-top: var(--space-3);
  padding-top: var(--space-4);
  font-weight: var(--weight-semibold);
  font-size: var(--text-base);
}

.booking-summary__key {
  color: var(--color-earth-mid);
}

.booking-summary__val {
  color: var(--color-earth);
  font-weight: var(--weight-medium);
}

.booking-summary__val--price {
  font-family: var(--font-price);
  color: var(--color-ochre-dark);
  font-size: var(--text-xl);
}

/* ******************************************************
   NOTIFICATION BELL / BADGE
   ****************************************************** */

.notif-wrap {
  position: relative;
}

.notif-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  width: 18px;
  height: 18px;
  background: var(--color-rust);
  color: var(--color-white);
  font-size: 10px;
  font-weight: var(--weight-bold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--color-white);
  pointer-events: none;
}

/* ******************************************************
   STEPS / BOOKING PROGRESS
   ****************************************************** */

.steps {
  display: flex;
  align-items: center;
  margin-bottom: var(--space-10);
}

.step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  flex: 1;
  position: relative;
}

.step::before {
  content: '';
  position: absolute;
  top: 16px;
  left: 50%;
  width: 100%;
  height: 2px;
  background: var(--color-ivory-dark);
  z-index: 0;
}

.step:last-child::before {
  display: none;
}

.step__num {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--color-ivory-dark);
  color: var(--color-earth-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  position: relative;
  z-index: var(--z-raised);
  transition: var(--transition-base);
}

.step__label {
  font-size: var(--text-xs);
  color: var(--color-earth-light);
  text-align: center;
  transition: var(--transition-color);
}

.step.is-active .step__num {
  background: var(--color-ochre);
  color: var(--color-white);
  box-shadow: var(--shadow-gold);
}

.step.is-active .step__label {
  color: var(--color-ochre-dark);
  font-weight: var(--weight-medium);
}

.step.is-done .step__num {
  background: var(--color-success);
  color: var(--color-white);
}

.step.is-done::before {
  background: var(--color-success);
  opacity: 0.4;
}

/* ******************************************************
   TABLE
   ****************************************************** */

.table-wrap {
  width: 100%;
  overflow-x: auto;
  border: var(--border-thin);
  border-radius: var(--radius-lg);
}

.table {
  width: 100%;
  font-size: var(--text-sm);
  border-collapse: collapse;
}

.table thead tr {
  background: var(--color-ivory-dark);
}

.table th {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  font-weight: var(--weight-semibold);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-earth-light);
  white-space: nowrap;
}

.table td {
  padding: var(--space-3) var(--space-4);
  color: var(--color-earth);
  border-bottom: var(--border-thin);
  vertical-align: middle;
}

.table tbody tr:last-child td {
  border-bottom: none;
}

.table tbody tr:hover td {
  background: rgba(193, 127, 36, 0.03);
}

/* ******************************************************
   PAGINATION
   ****************************************************** */

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  margin-top: var(--space-8);
  flex-wrap: wrap;
}

.page-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-earth-mid);
  background: var(--color-ivory-warm);
  border: var(--border-thin);
  transition: var(--transition-fast);
  cursor: pointer;
}

.page-btn:hover {
  background: var(--color-ochre-pale);
  color: var(--color-ochre-dark);
  border-color: var(--color-ochre);
}

.page-btn.is-active {
  background: var(--color-ochre);
  color: var(--color-white);
  border-color: var(--color-ochre);
}

.page-btn:disabled {
  opacity: 0.4;
  pointer-events: none;
}

/* ******************************************************
   AVATAR
   ****************************************************** */

.avatar {
  border-radius: 50%;
  object-fit: cover;
  display: block;
  flex-shrink: 0;
}

.avatar--sm  { width: 32px; height: 32px; }
.avatar--md  { width: 44px; height: 44px; }
.avatar--lg  { width: 64px; height: 64px; }
.avatar--xl  { width: 96px; height: 96px; }
.avatar--2xl { width: 128px; height: 128px; }

.avatar-placeholder {
  border-radius: 50%;
  background: var(--gradient-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--color-white);
  font-weight: var(--weight-semibold);
}

/* ******************************************************
   SEARCH BAR
   ****************************************************** */

.search-bar {
  position: relative;
  flex: 1;
}

.search-bar input {
  width: 100%;
  padding: 0.625rem 1rem 0.625rem 2.75rem;
  background: var(--bg-surface);
  border: var(--border-thin);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  color: var(--color-earth);
  transition: var(--transition-fast);
}

.search-bar input:focus {
  border-color: var(--color-ochre);
  box-shadow: 0 0 0 3px rgba(193, 127, 36, 0.15);
  outline: none;
}

.search-bar__icon {
  position: absolute;
  top: 50%;
  left: 1rem;
  transform: translateY(-50%);
  color: var(--color-mist);
  width: 16px;
  height: 16px;
  pointer-events: none;
}

/* ******************************************************
   CART BADGE
   ****************************************************** */

.cart-btn {
  position: relative;
}

.cart-count {
  position: absolute;
  top: -6px;
  right: -6px;
  min-width: 20px;
  height: 20px;
  padding: 0 4px;
  background: var(--color-rust);
  color: var(--color-white);
  font-size: 10px;
  font-weight: var(--weight-bold);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--color-white);
  transform: scale(0);
  transition: transform var(--duration-base) var(--ease-spring);
}

.cart-count.is-visible {
  transform: scale(1);
}

/* ******************************************************
   AMENITY CHIPS
   ****************************************************** */

.amenities-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.amenity-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: var(--color-ivory-warm);
  border: var(--border-thin);
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
  color: var(--color-earth-mid);
}

.amenity-chip svg {
  width: 14px;
  height: 14px;
  color: var(--color-ochre);
  flex-shrink: 0;
}

/* ******************************************************
   ORDER TRACKER STEPS
   ****************************************************** */

.order-track {
  display: flex;
  justify-content: space-between;
  position: relative;
  padding-bottom: var(--space-6);
}

.order-track::before {
  content: '';
  position: absolute;
  top: 20px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--color-ivory-dark);
  z-index: 0;
}

.order-track__progress {
  position: absolute;
  top: 20px;
  left: 0;
  height: 2px;
  background: var(--gradient-gold);
  z-index: 1;
  transition: width var(--duration-slower) var(--ease-out);
}

.track-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  flex: 1;
  position: relative;
  z-index: var(--z-raised);
}

.track-step__dot {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--color-ivory-dark);
  border: 2px solid var(--color-cloud);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-mist);
  transition: var(--transition-base);
}

.track-step.is-done .track-step__dot {
  background: var(--color-success);
  border-color: var(--color-success);
  color: var(--color-white);
}

.track-step.is-active .track-step__dot {
  background: var(--color-ochre);
  border-color: var(--color-ochre-dark);
  color: var(--color-white);
  box-shadow: var(--shadow-gold);
  animation: pulse-dot 1.5s ease-in-out infinite;
}

@keyframes pulse-dot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(214,99,193,0.5); }
  50%       { box-shadow: 0 0 0 8px rgba(214,99,193,0); }
}

.track-step__label {
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: var(--color-earth-light);
  text-align: center;
}

.track-step.is-active .track-step__label,
.track-step.is-done .track-step__label {
  color: var(--color-earth);
}

/* P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%
   INFO CARD
   P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P%P% */

.info-card {
  background: var(--bg-surface);
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.info-card--center {
  text-align: center;
}

.info-card__title {
  margin-bottom: var(--space-2);
  color: var(--color-ochre-dark);
}

.info-card--spacing-lg .info-card__title {
  margin-bottom: var(--space-4);
}

.info-card__text {
  font-size: var(--text-sm);
}

.info-card__list {
  list-style: none;
  padding: 0;
}

.info-card__list-item {
  margin-bottom: var(--space-2);
}

}

/* ====================================================
   DARK MODE AUDIT — PILLS, BADGES, CHIPS & TAGS
   All pill-style elements must maintain readable contrast
   in dark mode. In dark mode surfaces are deep plum so
   all badges/tags need translucent dark backgrounds with
   appropriately light text colours.
   ==================================================== */

.theme-dark .badge-gold,
:root.dark-mode .badge-gold {
  background: rgba(214, 99, 193, 0.18);
  color: #D688E7;
  border-color: rgba(214, 99, 193, 0.35);
}

.theme-dark .badge-forest,
:root.dark-mode .badge-forest {
  background: rgba(39, 14, 46, 0.6);
  color: #BA6ECB;
  border-color: rgba(186, 110, 203, 0.3);
}

.theme-dark .badge-rust,
:root.dark-mode .badge-rust {
  background: rgba(166, 61, 47, 0.22);
  color: #F87171;
  border-color: rgba(248, 113, 113, 0.35);
}

.theme-dark .badge-success,
:root.dark-mode .badge-success {
  background: rgba(52, 211, 153, 0.18);
  color: #6EE7B7;
}

.theme-dark .badge-warning,
:root.dark-mode .badge-warning {
  background: rgba(245, 158, 11, 0.18);
  color: #FCD34D;
}

.theme-dark .badge-danger,
:root.dark-mode .badge-danger {
  background: rgba(248, 113, 113, 0.18);
  color: #FCA5A5;
}

.theme-dark .badge-info,
:root.dark-mode .badge-info {
  background: rgba(96, 165, 250, 0.18);
  color: #93C5FD;
}

.theme-dark .badge-neutral,
:root.dark-mode .badge-neutral {
  background: rgba(42, 18, 40, 0.8);
  color: #C8B4C4;
  border-color: rgba(214, 99, 193, 0.2);
}

.theme-dark .badge-dark,
:root.dark-mode .badge-dark {
  background: #FDF8FC;
  color: #1E0D1A;
}

/* Tag pills */
.theme-dark .tag,
:root.dark-mode .tag {
  background: rgba(42, 18, 40, 0.8);
  color: #C8B4C4;
}

.theme-dark .tag:hover,
:root.dark-mode .tag:hover {
  background: rgba(214, 99, 193, 0.22);
  color: #D688E7;
}

/* Menu category tab pills */
.theme-dark .menu-tab,
:root.dark-mode .menu-tab {
  background: rgba(34, 17, 34, 0.85);
  color: #C8B4C4;
  border-color: rgba(214, 99, 193, 0.2);
}

.theme-dark .menu-tab:hover,
:root.dark-mode .menu-tab:hover {
  background: rgba(214, 99, 193, 0.18);
  color: #D688E7;
}

.theme-dark .menu-tab.is-active,
:root.dark-mode .menu-tab.is-active {
  background: var(--color-ochre);
  color: #fff;
  border-color: var(--color-ochre-dark);
}

/* Room filter chips */
.theme-dark .filter-chip,
:root.dark-mode .filter-chip {
  color: #C8B4C4;
  border-color: rgba(214, 99, 193, 0.25);
}

.theme-dark .filter-chip:hover,
:root.dark-mode .filter-chip:hover {
  border-color: var(--color-ochre);
  color: #D688E7;
}

.theme-dark .filter-chip.active,
:root.dark-mode .filter-chip.active {
  background: var(--color-ochre);
  border-color: var(--color-ochre);
  color: #fff;
}

/* Amenity chips */
.theme-dark .amenity-chip,
:root.dark-mode .amenity-chip {
  background: rgba(34, 17, 34, 0.8);
  color: #C8B4C4;
  border-color: rgba(214, 99, 193, 0.18);
}

/* Avatar booking status badges — hardcoded light-mode colours overridden */
.theme-dark .avatar-booking-item__badge--confirmed,
:root.dark-mode .avatar-booking-item__badge--confirmed   { background: rgba(10,34,24,0.9); color: #4ADE80; }

.theme-dark .avatar-booking-item__badge--checked-in,
:root.dark-mode .avatar-booking-item__badge--checked-in  { background: rgba(13,28,53,0.9); color: #60A5FA; }

.theme-dark .avatar-booking-item__badge--checked-out,
:root.dark-mode .avatar-booking-item__badge--checked-out { background: rgba(30,30,30,0.9); color: #9CA3AF; }

.theme-dark .avatar-booking-item__badge--pending,
:root.dark-mode .avatar-booking-item__badge--pending     { background: rgba(44,35,10,0.9); color: #FCD34D; }

.theme-dark .avatar-booking-item__badge--cancelled,
:root.dark-mode .avatar-booking-item__badge--cancelled   { background: rgba(45,10,10,0.9); color: #F87171; }

/* Alert panels */
.theme-dark .alert-success, :root.dark-mode .alert-success { background: rgba(52,211,153,0.12); color: #6EE7B7; }
.theme-dark .alert-warning, :root.dark-mode .alert-warning { background: rgba(245,158,11,0.12); color: #FDE68A; }
.theme-dark .alert-danger,  :root.dark-mode .alert-danger  { background: rgba(248,113,113,0.12); color: #FCA5A5; }
.theme-dark .alert-info,    :root.dark-mode .alert-info    { background: rgba(96,165,250,0.12);  color: #93C5FD; }

/* System-preference (OS dark mode) fallback */
@media (prefers-color-scheme: dark) {
  :root:not(.theme-light) .badge-gold    { background: rgba(214,99,193,0.18); color: #D688E7; border-color: rgba(214,99,193,0.35); }
  :root:not(.theme-light) .badge-forest  { background: rgba(39,14,46,0.6);    color: #BA6ECB; border-color: rgba(186,110,203,0.3); }
  :root:not(.theme-light) .badge-rust    { background: rgba(166,61,47,0.22);  color: #F87171; border-color: rgba(248,113,113,0.35); }
  :root:not(.theme-light) .badge-success { background: rgba(52,211,153,0.18); color: #6EE7B7; }
  :root:not(.theme-light) .badge-warning { background: rgba(245,158,11,0.18); color: #FCD34D; }
  :root:not(.theme-light) .badge-danger  { background: rgba(248,113,113,0.18); color: #FCA5A5; }
  :root:not(.theme-light) .badge-info    { background: rgba(96,165,250,0.18); color: #93C5FD; }
  :root:not(.theme-light) .badge-neutral { background: rgba(42,18,40,0.8);    color: #C8B4C4; }
  :root:not(.theme-light) .tag           { background: rgba(42,18,40,0.8);    color: #C8B4C4; }
  :root:not(.theme-light) .menu-tab      { background: rgba(34,17,34,0.85);   color: #C8B4C4; border-color: rgba(214,99,193,0.2); }
  :root:not(.theme-light) .filter-chip   { color: #C8B4C4; border-color: rgba(214,99,193,0.25); }
  :root:not(.theme-light) .amenity-chip  { background: rgba(34,17,34,0.8);    color: #C8B4C4; border-color: rgba(214,99,193,0.18); }
  :root:not(.theme-light) .alert-success { background: rgba(52,211,153,0.12); color: #6EE7B7; }
  :root:not(.theme-light) .alert-warning { background: rgba(245,158,11,0.12); color: #FDE68A; }
  :root:not(.theme-light) .alert-danger  { background: rgba(248,113,113,0.12); color: #FCA5A5; }
  :root:not(.theme-light) .alert-info    { background: rgba(96,165,250,0.12); color: #93C5FD; }
}




