/* 
 * UrbanPlaces Modern Theme 
 */

:root {
  --primary-color: #4f46e5;       /* Indigo 600 */
  --primary-hover: #4338ca;       /* Indigo 700 */
  --bg-soft: #f8fafc;             /* Slate 50 */
  --text-main: #334155;           /* Slate 700 */
  --card-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --card-shadow-hover: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
}

body {
  font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  color: var(--text-main);
  background-color: var(--bg-soft);
}

/* Navbar Glassmorphism */
.navbar {
  background-color: rgba(255, 255, 255, 0.85) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.navbar-brand img {
  border-radius: 8px;
}

/* Recreate Jumbotron for Bootstrap 5 */
.jumbotron {
  padding: 3rem 2rem;
  margin-bottom: 2rem;
  background: linear-gradient(135deg, #ffffff 0%, #f1f5f9 100%);
  border-radius: 12px;
  box-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
  border: 1px solid rgba(255, 255, 255, 0.5);
}

@media (min-width: 576px) {
  .jumbotron {
    padding: 4rem 2rem;
  }
}

/* Modernized Cards */
.card {
  border: none;
  border-radius: 12px;
  box-shadow: var(--card-shadow);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  overflow: hidden;
  background: #ffffff;
}

.card:hover {
  transform: translateY(-4px);
  box-shadow: var(--card-shadow-hover);
}

.card-img-top {
  border-top-left-radius: 12px;
  border-top-right-radius: 12px;
}

/* Override Bootstrap Outline Primary Button */
.btn-outline-primary {
  color: var(--primary-color);
  border-color: var(--primary-color);
  border-radius: 8px;
  font-weight: 500;
}

.btn-outline-primary:hover {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: #fff;
}

.btn-primary {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  border-radius: 8px;
}

.btn-primary:hover {
  background-color: var(--primary-hover);
  border-color: var(--primary-hover);
}

/* Badges */
.badge {
  font-weight: 500;
  padding: 0.4em 0.6em;
  border-radius: 6px;
}

/* Breadcrumb Modernization */
.breadcrumb {
  border-radius: 8px;
  background-color: #ffffff !important;
  padding: 0.75rem 1rem;
}

/* Footer styling */
.footer {
  background-color: #1e293b !important; /* Slate 800 */
}

/* SVG icon alignment and sizing tweaks inside headings */
h4 svg.bi {
  margin-right: 6px;
  vertical-align: text-bottom;
}

