/* ==========================================================================
   Blue Hen Bites — Component Styles
   Page-specific and component-specific styles that build on design-system.css.
   Loaded by base.html after design-system.css.
   ========================================================================== */


.logo img {
  width: 100%;
  height: auto;
  object-fit: contain;
}


/* --------------------------------------------------------------------------
   CARDS — Legacy card and menu-card classes
   Used by: order_builder, menubuilder, kiosk_builder, restaurantprofile
   -------------------------------------------------------------------------- */
.card,
.menu-card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-xl);
  box-shadow: none;
  overflow: hidden;
  transition:
    box-shadow var(--transition-fast),
    border-color var(--transition-fast);
}

.card:hover,
.menu-card:hover {
  box-shadow: var(--shadow-sm);
}

.card .card-header,
.menu-card .menu-card-header {
  background: var(--white);
  color: var(--gray-900);
  border-bottom: 1px solid var(--gray-100);
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--text-sm);
}

.card .card-body,
.menu-card .menu-card-body {
  padding: var(--space-4);
  color: var(--gray-800);
}

.card .card-footer,
.menu-card .menu-card-footer {
  background: var(--gray-50);
  border-top: 1px solid var(--gray-100);
  padding: var(--space-2) var(--space-4);
  color: var(--gray-600);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
}

/* Menu card images */
.menu-card-image-wrap {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  background: var(--gray-100);
  overflow: hidden;
}

.menu-card-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#restaurantGrid.menu-grid {
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
}


/* --------------------------------------------------------------------------
   RESTAURANT PROFILE PAGE
   Used by: restaurantprofile.html
   -------------------------------------------------------------------------- */
.rp-grid {
  display: grid;
  grid-template-columns: 1.35fr 0.9fr;
  gap: var(--space-5);
}

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

.rp-section + .rp-section {
  border-top: 1px solid var(--gray-200);
}

.rp-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) 0;
}

.rp-icon {
  width: 18px;
  height: 18px;
  display: inline-block;
  color: var(--ud-blue);
}

.hours-columns {
  column-width: 320px;
  column-gap: var(--space-4);
}

.rp-hours {
  break-inside: avoid;
  display: grid;
  grid-template-columns: 110px 1fr;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) 0;
}

.rp-hours .dow {
  font-weight: 700;
  text-transform: capitalize;
  color: var(--gray-900);
}

.rp-hours .win {
  color: var(--gray-600);
  font-size: var(--text-sm);
  font-variant-numeric: tabular-nums;
}

@media (max-width: 560px) {
  .rp-hours { grid-template-columns: 92px 1fr; }
}

.social-icons {
  display: flex;
  gap: var(--space-2);
}

.social-icons a.btn-icon {
  width: 36px;
  height: 36px;
}

.muted {
  color: var(--gray-500);
}

/* --------------------------------------------------------------------------
   ORDER THANK YOU PAGE
   Used by: order_thank_you.html
   -------------------------------------------------------------------------- */
.order-details {
  background: var(--gray-50);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin: var(--space-4) 0;
}

.order-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--gray-200);
}

.order-item:last-child {
  border-bottom: none;
}

.total-row {
  font-weight: 700;
  font-size: var(--text-lg);
  color: var(--ud-blue);
  border-top: 2px solid var(--ud-blue);
  padding-top: var(--space-2);
  margin-top: var(--space-2);
}

.success-icon {
  font-size: var(--text-4xl);
  color: var(--success);
  margin-bottom: var(--space-4);
}


/* --------------------------------------------------------------------------
   MENU VIEW PAGE (category nav + item modal)
   Used by: menu-view.html
   -------------------------------------------------------------------------- */
.category-nav {
  display: flex;
  gap: var(--space-2);
  padding: var(--space-4) 0;
  overflow-x: auto;
  flex-wrap: wrap;
}

.category-btn {
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  border: 1px solid var(--gray-300);
  background: var(--white);
  color: var(--gray-700);
  font-size: var(--text-sm);
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
  white-space: nowrap;
}

.category-btn:hover {
  border-color: var(--ud-blue);
  color: var(--ud-blue);
}

.category-btn.active {
  background: var(--ud-blue);
  color: var(--white);
  border-color: var(--ud-blue);
}


/* --------------------------------------------------------------------------
   UNAVAILABLE ITEMS (Menu Builder)
   -------------------------------------------------------------------------- */
.unavailable {
  opacity: 0.55;
  filter: grayscale(40%);
}

.badge-unavail {
  background-color: var(--gray-400);
  font-size: var(--text-xs);
  margin-left: var(--space-2);
}


/* --------------------------------------------------------------------------
   RESTAURANT FORM (modal edit form)
   Used by: restaurantprofile.html, kiosk_editor.js
   -------------------------------------------------------------------------- */
#restaurantForm {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

#restaurantForm .grid-two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

#restaurantForm .col {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

#restaurantForm label {
  display: block;
  font-weight: 500;
  line-height: 1.25;
  color: var(--gray-700);
}

#restaurantForm input.form-control,
#restaurantForm textarea.form-control,
#restaurantForm select.form-control {
  width: 100%;
  box-sizing: border-box;
}

#restaurantForm textarea.form-control {
  resize: vertical;
  min-height: 40px;
}

#restaurantForm .r_hours {
  min-height: 42px;
  white-space: pre-wrap;
  font-family: inherit;
}

#restaurantForm .img-84x56 {
  display: inline-block;
  object-fit: cover;
}

@media (max-width: 900px) {
  #restaurantForm .grid-two { grid-template-columns: 1fr; }
}


/* Responsive image (used in UD header) */
.img-responsive { max-width: 100%; height: auto; }


/* ── Browse view ────────────────────────────────────────── */
.browse-tabs {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}

.browse-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-4);
}
@media (max-width: 640px) {
  .browse-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
}

.browse-card {
  position: relative;
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-xl);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: border-color .15s, box-shadow .2s, transform .15s;
}
.browse-card:hover {
  border-color: var(--ud-blue);
  box-shadow: 0 8px 24px rgba(0, 83, 159, .12);
  transform: translateY(-2px);
}

.browse-card-img {
  position: relative;
  width: 100%;
  padding-top: 56%;
  background: var(--gray-100);
  overflow: hidden;
}
.browse-card-img img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.browse-card-img--placeholder {
  background: linear-gradient(135deg, var(--ud-blue) 0%, #003d73 100%);
}
.browse-card-img-fallback {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-size: 3rem;
  font-weight: 700;
  color: var(--ud-gold);
  letter-spacing: 0;
}

.browse-card-body {
  padding: var(--space-4);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.browse-card-name {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--text-lg);
  color: var(--gray-900);
  margin: 0;
  line-height: 1.25;
}
.browse-card-desc {
  font-size: var(--text-sm);
  color: var(--gray-500);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.45;
}
.browse-card-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding-top: var(--space-3);
  margin-top: auto;
  border-top: 1px solid var(--gray-100);
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--ud-blue);
}
.browse-card-arrow {
  font-size: var(--text-lg);
  transition: transform .15s;
}
.browse-card:hover .browse-card-arrow {
  transform: translateX(4px);
}

/* Kiosk hero image on the kiosk detail page */
.browse-hero {
  position: relative;
  width: 100%;
  height: 220px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  margin-bottom: var(--space-5);
  background: var(--gray-100);
}
.browse-hero img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Building card variant — tinted header band */
.browse-card--building {
  border-top: 4px solid var(--ud-gold);
}
.browse-building-badge {
  display: inline-block;
  align-self: flex-start;
  padding: 2px var(--space-2);
  background: var(--ud-blue);
  color: var(--white);
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.05em;
  border-radius: var(--radius-sm);
}
