/* Front Theme: clean and modern while keeping existing color palette
   Assumptions: Bootstrap 5 is loaded. We layer styles without breaking markup.
*/
:root {
  /* Keep existing brand colors if set via Tailwind utility classes like bg-company-white, else define sane defaults. */
  --brand-primary: #0d6efd; /* Bootstrap primary */
  --brand-secondary: #6c757d;
  --brand-success: #198754;
  --brand-warning: #ffc107;
  --brand-info: #0dcaf0;
  --brand-danger: #dc3545;
  --brand-light: #f8f9fa;
  --brand-dark: #212529;

  --surface: #ffffff;
  --surface-2: #f5f7fb;
  --text: #1f2937;
  --muted: #6b7280;
  --ring: rgba(13, 110, 253, 0.35);
  --shadow: 0 8px 24px rgba(0,0,0,0.08);
  --shadow-lg: 0 16px 40px rgba(0,0,0,0.10);
  --radius: 14px;

  --grad-primary: linear-gradient(135deg, var(--brand-primary), #4f8cff);
}

html, body {
  scroll-behavior: smooth;
  color: var(--text);
}

/* Typography refinements */
h1, .h1 { letter-spacing: -0.02em; }
h2, .h2 { letter-spacing: -0.02em; }
h1, h2, h3, h4, h5 { color: var(--text); }
.text-muted { color: var(--muted) !important; }

/* Motion safety */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
}

/* Utility helpers */
.rounded-xl { border-radius: var(--radius) !important; }
.shadow-soft { box-shadow: var(--shadow) !important; }
.shadow-soft-lg { box-shadow: var(--shadow-lg) !important; }
.glass {
  background: rgba(255,255,255,0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* Modern nav */
.nav-modern { position: sticky; top: 0; z-index: 1030; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); transition: background-color .2s ease, box-shadow .2s ease; }
.nav-modern.is-scrolled { background: rgba(255,255,255,0.75); box-shadow: var(--shadow); }
.nav-modern .brand { display: inline-flex; align-items: center; gap: .5rem; font-weight: 800; }
.nav-modern .navlink { position: relative; display: inline-flex; align-items: center; gap: .35rem; padding: .5rem .25rem; font-weight: 600; text-decoration: none; color: #fff; }
.nav-modern .navlink::after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 2px; background: #fff; transform: scaleX(0); transform-origin: left; transition: transform .2s ease; opacity: .85; }
.nav-modern .navlink:hover::after, .nav-modern .navlink.active::after { transform: scaleX(1); }

/* Buttons */
.btn { border-radius: 999px; padding: 0.6rem 1.1rem; }
.btn-primary {
  background: var(--grad-primary);
  border: none;
}
.btn-primary:hover { filter: brightness(0.95); }
.btn-outline-primary { border-color: var(--brand-primary); color: var(--brand-primary); }
.btn-outline-primary:hover { background: var(--brand-primary); color: #fff; }

/* Forms */
.form-control, .form-select, textarea {
  border-radius: 12px;
  border-color: #e5e7eb;
  padding: 0.65rem 0.9rem;
}
.form-control:focus, .form-select:focus, textarea:focus { box-shadow: 0 0 0 0.25rem var(--ring); border-color: var(--brand-primary); }

/* Cards */
.card { border: 0; border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; transition: transform .2s ease, box-shadow .2s ease; }
.card .card-title { font-weight: 700; }
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }

/* Badges */
.badge { border-radius: 999px; padding: 0.5em 0.75em; font-weight: 600; }
.badge.bg-primary { background: var(--brand-primary) !important; }
.badge.bg-warning { color: #111827; }

/* Navigation/header spacing (Bootstrap navs) */
.navbar { border-bottom: 1px solid rgba(0,0,0,0.06); }

/* Hero section for homepage */
.hero {
  position: relative;
  border-radius: calc(var(--radius) + 6px);
  background: radial-gradient(1200px 400px at 10% 0%, rgba(13,110,253,0.08), transparent 60%),
              radial-gradient(1000px 400px at 90% 0%, rgba(13,110,253,0.06), transparent 60%),
              linear-gradient(180deg, var(--surface-2), #fff);
}
.hero .hero-inner { padding: 3rem 1.25rem; }
@media (min-width: 992px){ .hero .hero-inner { padding: 4.5rem 3rem; } }

/* Property cards grid */
.property-card .card-img-top { height: 220px; object-fit: cover; transition: filter .2s ease, transform .2s ease; }
.property-card .meta { color: var(--muted); font-size: 0.95rem; }
.property-card .price { color: var(--brand-primary); font-weight: 800; font-size: 1.1rem; }
.property-card .card-footer { background: #fff; }
.property-card:hover .card-img-top { filter: saturate(1.05); transform: scale(1.01); }

/* Thumbnails */
.thumb { border-radius: 10px; overflow: hidden; }
.thumb img { display: block; transition: transform .2s ease; }
.thumb:hover img { transform: scale(1.02); }

/* Sticky sidebar on detail */
@media (min-width: 992px){
  .sticky-lg { position: sticky; top: 90px; }
}

/* Empty state */
.empty-state { border: 1px dashed #e5e7eb; border-radius: var(--radius); padding: 2rem; text-align: center; color: var(--muted); }

/* Pagination */
.page-link { border-radius: 10px !important; }

/* Focus visible */
:focus-visible { outline: 3px solid var(--ring); outline-offset: 2px; }

/* Micro animations */
@keyframes fadeInUp { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
.fade-in-up { animation: fadeInUp .35s ease forwards; }
