/* ===== GENERIC UTILITY PAGES (signin/message/bookings/etc.) ===== */
.utility-page {
  min-height: 100vh;
  background: linear-gradient(180deg, #f8f9ff 0%, #ffffff 60%);
  padding: 110px 0 70px;
}

.utility-shell {
  max-width: 960px;
  margin: 0 auto;
}

.utility-hero {
  background: linear-gradient(135deg, #10162f 0%, #18264d 50%, #0f3460 100%);
  color: #fff;
  border-radius: 24px;
  padding: 34px 30px;
  margin-bottom: 22px;
  box-shadow: 0 18px 40px rgba(16, 22, 47, 0.2);
}

.utility-hero h1 {
  font-size: 2rem;
  margin-bottom: 8px;
}

.utility-hero p {
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.7;
}

.utility-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.utility-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 18px;
  padding: 22px;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06);
}

.utility-card h3 {
  margin-bottom: 10px;
  font-size: 1.1rem;
}

.utility-card p,
.utility-card li {
  color: #6b7280;
  line-height: 1.7;
}

.utility-list {
  margin-left: 18px;
}

.utility-actions {
  margin-top: 16px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.utility-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(108, 99, 255, 0.1);
  color: #4f46e5;
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 0.84rem;
  font-weight: 600;
}

@media (max-width: 768px) {
  .utility-grid {
    grid-template-columns: 1fr;
  }

  .utility-hero {
    padding: 26px 20px;
  }

  .utility-hero h1 {
    font-size: 1.6rem;
  }
}
