/* =========================================================
   GIANT HOME LOUNGE — FORMS & PAGES CSS
   ========================================================= */

/* --- Reservation Page --- */
.reservation-inner { gap: var(--spacing-2xl); align-items: start; }
.reservation-info h2 { font-size: var(--fs-2xl); }
.reservation-features { display: flex; flex-direction: column; gap: var(--spacing-md); }
.reservation-feature { display: flex; align-items: flex-start; gap: var(--spacing-md); }
.reservation-feature__icon { flex-shrink: 0; margin-top: 0.1rem; }
.reservation-feature__title { font-size: var(--fs-base); margin-bottom: 0.2rem; }
.reservation-feature__desc { font-size: var(--fs-sm); margin: 0; }

.reservation-hours table { width: 100%; border-collapse: collapse; }
.reservation-hours td { padding: 0.5rem 0; border-bottom: 1px solid rgba(255,255,255,0.05); font-size: var(--fs-sm); }
.reservation-hours td:last-child { text-align: right; font-weight: 600; }

.hours-table { width: 100%; border-collapse: collapse; }
.hours-table td { padding: 0.6rem 0; border-bottom: 1px solid rgba(201,168,76,0.1); font-size: var(--fs-sm); }
.hours-table tr:last-child td { border-bottom: none; }
.hours-table td:last-child { text-align: right; font-weight: 700; }

.reservation-form-card { border-radius: var(--radius-lg); }
.reservation-form-card__title { font-size: var(--fs-xl); }

.form-row { gap: var(--spacing-md); }
.form-success { padding: var(--spacing-xl) 0; }
.form-success__icon svg { stroke: var(--color-gold); }
.form-error { padding: 0.5rem 0; }
.form-disclaimer { font-size: var(--fs-xs); }

/* --- Policy Section --- */
.reservation-policy { border-top: var(--border-gold); }
.policy-grid { gap: var(--spacing-lg); text-align: left; }
.policy-item { padding: var(--spacing-md); background: var(--color-bg-card); border: var(--border-gold); border-radius: var(--radius-md); }
.policy-item__title { margin-bottom: 0.5rem; }

/* --- Location Page --- */
.location-inner { gap: var(--spacing-2xl); align-items: start; }
.location-card { margin-bottom: var(--spacing-md); border-radius: var(--radius-md); }
.location-card:hover { transform: none; box-shadow: var(--shadow-card); }
.location-card__header { display: flex; align-items: center; gap: var(--spacing-sm); margin-bottom: var(--spacing-sm); }
.location-card__icon { flex-shrink: 0; }
.location-card__title { font-size: var(--fs-base); margin: 0; }
.location-card__address { color: var(--color-grey-mid); font-size: var(--fs-sm); line-height: var(--lh-normal); }
.location-contact-link { color: var(--color-gold); display: inline-flex; align-items: center; gap: 0.4rem; font-size: var(--fs-sm); font-weight: 600; transition: color var(--transition-base); }
.location-contact-link:hover { color: var(--color-white); }
.location-transport-list { list-style: none; }
.location-transport-list li { padding: 0.35rem 0; font-size: var(--fs-sm); color: var(--color-grey-mid); border-bottom: 1px solid rgba(255,255,255,0.04); }
.location-transport-list li:last-child { border: none; }

.location-map { border-radius: var(--radius-lg); overflow: hidden; border: var(--border-gold); min-height: 500px; }
.location-map iframe { display: block; }

/* --- Contact Page --- */
.contact-inner { gap: var(--spacing-2xl); align-items: start; }
.contact-details { display: flex; flex-direction: column; gap: var(--spacing-md); }
.contact-detail-item { display: flex; align-items: flex-start; gap: var(--spacing-md); padding: var(--spacing-md); background: var(--color-bg-card); border: var(--border-gold); border-radius: var(--radius-md); transition: all var(--transition-base); }
.contact-detail-item:hover { border-color: var(--color-gold); }
.contact-detail-item__icon { flex-shrink: 0; margin-top: 0.2rem; }
.contact-detail-item__content { flex: 1; }
.contact-detail-item__label { display: block; margin-bottom: 0.2rem; }
.contact-detail-item__value { display: block; font-size: var(--fs-base); color: var(--color-white); font-weight: 500; }
.contact-detail-item__value a { color: var(--color-white); transition: color var(--transition-base); }
.contact-detail-item__value a:hover { color: var(--color-gold); }

.contact-social-links { flex-wrap: wrap; }
.contact-social-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 1.2rem;
  border: var(--border-gold);
  border-radius: var(--radius-full);
  color: var(--color-grey-light);
  font-size: var(--fs-sm);
  font-weight: 600;
  text-decoration: none;
  transition: all var(--transition-base);
}
.contact-social-btn:hover { background: var(--color-gold); border-color: var(--color-gold); color: var(--color-bg-primary); }

.contact-mini-map { border-radius: var(--radius-md); overflow: hidden; border: var(--border-gold); }
.contact-form-card { border-radius: var(--radius-lg); }

/* --- Order Page --- */
.order-layout { gap: var(--spacing-2xl); align-items: start; }
.order-menu-browse h2 { font-size: var(--fs-2xl); }
.order-tabs { flex-wrap: wrap; }
.order-tab {
  padding: 0.5rem 1.2rem;
  border: var(--border-gold);
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--color-grey-light);
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-base);
}
.order-tab:hover { border-color: var(--color-gold); color: var(--color-gold); }
.order-tab--active, .order-tab.active { background: var(--color-gold); border-color: var(--color-gold); color: var(--color-bg-primary); }

.order-menu-group__title { display: flex; align-items: center; gap: 0.5rem; font-size: var(--fs-lg); }

.order-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--color-bg-card);
  border: var(--border-gold);
  border-radius: var(--radius-md);
  margin-bottom: 0.6rem;
  transition: all var(--transition-base);
}
.order-item:hover { border-color: var(--color-gold); }
.order-item.has-selection { border-color: var(--color-gold); background: var(--color-gold-muted); }
.order-item__info { flex: 1; min-width: 0; }
.order-item__header { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 0.2rem; }
.order-item__name { font-size: var(--fs-sm); font-weight: 700; margin: 0; }
.order-item__desc { font-size: var(--fs-xs); color: var(--color-grey-mid); margin: 0; }
.order-item__cat { display: block; margin-top: 0.2rem; }
.order-item__actions { display: flex; flex-direction: column; align-items: flex-end; gap: 0.4rem; flex-shrink: 0; }
.order-item__price { font-family: var(--font-heading); font-size: var(--fs-base); font-weight: 700; white-space: nowrap; }

.order-item__qty-control { display: flex; align-items: center; gap: 0.3rem; }
.qty-btn {
  width: 28px;
  height: 28px;
  border: 1px solid var(--color-gold-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg-secondary);
  color: var(--color-gold);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.qty-btn:hover { background: var(--color-gold); color: var(--color-bg-primary); border-color: var(--color-gold); }
.qty-input {
  width: 36px;
  text-align: center;
  background: transparent;
  border: none;
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 700;
  padding: 0;
}
.qty-input::-webkit-outer-spin-button, .qty-input::-webkit-inner-spin-button { -webkit-appearance: none; }

/* Order Summary */
.order-summary-card { position: sticky; top: 6rem; border-radius: var(--radius-lg); }
.order-summary__title { font-size: var(--fs-xl); }
.order-empty-state { padding: var(--spacing-lg) 0; color: var(--color-grey-mid); }
.order-items-list { list-style: none; max-height: 280px; overflow-y: auto; padding-right: 0.25rem; }
.order-items-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(201,168,76,0.1);
  font-size: var(--fs-sm);
}
.order-items-list li:last-child { border: none; }
.order-items-list .item-name { color: var(--color-white); flex: 1; }
.order-items-list .item-qty { color: var(--color-gold); margin-inline: 0.5rem; font-weight: 700; }
.order-items-list .item-subtotal { color: var(--color-gold); font-weight: 700; }
.order-total { display: flex; justify-content: space-between; align-items: center; padding-top: var(--spacing-sm); border-top: var(--border-gold-bright); margin-top: var(--spacing-sm); }
.order-total__label { font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-grey-mid); }
.order-total__amount { font-family: var(--font-heading); font-size: var(--fs-xl); font-weight: 700; }

.order-success__icon svg { stroke: var(--color-gold); }
.order-success__ref { font-family: var(--font-heading); font-size: var(--fs-lg); }
.order-help-callout { border-radius: var(--radius-md); }
.order-table-badge { margin-bottom: var(--spacing-sm); }

/* Order menu items hidden filter */
.order-menu-group { display: block; }
.order-menu-group.hidden { display: none; }
.order-item.hidden { display: none; }

/* Responsive */
@media (max-width: 1024px) {
  .order-layout { grid-template-columns: 1fr; }
  .order-summary-card { position: static; }
  .location-inner { grid-template-columns: 1fr; }
  .contact-inner { grid-template-columns: 1fr; }
  .reservation-inner { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .form-row { grid-template-columns: 1fr; }
  .order-item { flex-wrap: wrap; }
  .order-item__actions { flex-direction: row; align-items: center; justify-content: space-between; width: 100%; }
  .policy-grid { grid-template-columns: 1fr; }
}
