/* Koru Invest - Brand CSS */
:root {
  --koru-blue: #2D3F93;
  --koru-blue-dark: #1e2d6e;
  --koru-blue-light: #3a50b0;
  --koru-brown: #A36A3A;
  --koru-brown-light: #c4874f;
  --koru-brown-dark: #7d5128;
  --koru-dark: #1a1a2e;
  --koru-bg: #f8f9fc;
  --koru-text: #2c2c3e;
  --koru-gray: #6b7280;
  --koru-border: #e5e7eb;
  --koru-pattern-blue: #2D3F93;
}

/* Pattern backgrounds */
.koru-pattern-blue {
  background-color: #2D3F93;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpolygon points='0,0 30,0 0,30' fill='%23253582' opacity='0.5'/%3E%3Cpolygon points='30,0 60,0 60,30' fill='%23253582' opacity='0.5'/%3E%3Cpolygon points='0,30 0,60 30,60' fill='%23253582' opacity='0.5'/%3E%3Cpolygon points='30,60 60,60 60,30' fill='%23253582' opacity='0.5'/%3E%3Cpolygon points='30,0 60,30 30,60 0,30' fill='%23253582' opacity='0.3'/%3E%3C/svg%3E");
}

.koru-pattern-brown {
  background-color: #5A4032;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpolygon points='0,0 30,0 0,30' fill='%234a3328' opacity='0.5'/%3E%3Cpolygon points='30,0 60,0 60,30' fill='%234a3328' opacity='0.5'/%3E%3Cpolygon points='0,30 0,60 30,60' fill='%234a3328' opacity='0.5'/%3E%3Cpolygon points='30,60 60,60 60,30' fill='%234a3328' opacity='0.5'/%3E%3Cpolygon points='30,0 60,30 30,60 0,30' fill='%234a3328' opacity='0.3'/%3E%3C/svg%3E");
}

/* Custom scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: #f1f1f1; }
::-webkit-scrollbar-thumb { background: var(--koru-blue); border-radius: 3px; }

/* Smooth scroll */
html { scroll-behavior: smooth; }

/* Navbar */
.navbar-glass {
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 2px 20px rgba(45,63,147,0.1);
}

/* Hero Slider */
.hero-slider-wrapper {
  position: relative;
  width: 100%;
  overflow: hidden;
  height: 100vh;
  min-height: 560px;
}
.hero-slide {
  opacity: 0;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  pointer-events: none;
  transition: opacity 0.9s ease;
  z-index: 1;
}
.hero-slide.active {
  opacity: 1;
  pointer-events: auto;
  z-index: 2;
}
.hero-slide.transitioning {
  opacity: 0;
  z-index: 1;
}
@keyframes fadeSlide {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* Slider arrows & dots must be above slides */
#slider-prev, #slider-next,
.slide-dot, .hero-slider-wrapper > .absolute.bottom-6 {
  z-index: 10 !important;
  position: relative;
}

/* Cards */
.property-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.property-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 50px rgba(45,63,147,0.15);
}

/* Badges */
.badge-exclusive {
  background: linear-gradient(135deg, var(--koru-brown), var(--koru-brown-light));
  color: white;
}
.badge-corporate {
  background: linear-gradient(135deg, var(--koru-blue), var(--koru-blue-light));
  color: white;
}

/* Buttons */
.btn-primary {
  background: linear-gradient(135deg, var(--koru-blue), var(--koru-blue-light));
  color: white;
  transition: all 0.3s ease;
}
.btn-primary:hover {
  background: linear-gradient(135deg, var(--koru-blue-dark), var(--koru-blue));
  transform: translateY(-1px);
  box-shadow: 0 8px 25px rgba(45,63,147,0.3);
}
.btn-gold {
  background: linear-gradient(135deg, var(--koru-brown), var(--koru-brown-light));
  color: white;
  transition: all 0.3s ease;
}
.btn-gold:hover {
  background: linear-gradient(135deg, var(--koru-brown-dark), var(--koru-brown));
  transform: translateY(-1px);
  box-shadow: 0 8px 25px rgba(163,106,58,0.3);
}

/* Price tag */
.price-tag {
  background: linear-gradient(135deg, var(--koru-blue), var(--koru-blue-light));
  color: white;
  padding: 4px 12px;
  border-radius: 20px;
  font-weight: 700;
}

/* Filter bar */
.filter-bar {
  background: white;
  border-radius: 16px;
  box-shadow: 0 10px 40px rgba(45,63,147,0.15);
}

/* Section titles */
.section-title::after {
  content: '';
  display: block;
  width: 60px;
  height: 3px;
  background: linear-gradient(135deg, var(--koru-brown), var(--koru-brown-light));
  margin-top: 8px;
}

/* Map container */
#property-map, #region-map { border-radius: 12px; overflow: hidden; }

/* Admin sidebar */
.admin-sidebar {
  background: linear-gradient(180deg, var(--koru-dark) 0%, var(--koru-blue-dark) 100%);
}

/* Stats cards */
.stat-card {
  background: white;
  border-radius: 12px;
  border-left: 4px solid var(--koru-blue);
  transition: transform 0.2s ease;
}
.stat-card:hover { transform: translateY(-3px); }
.stat-card.gold { border-left-color: var(--koru-brown); }

/* Form styles */
.form-input {
  border: 2px solid var(--koru-border);
  border-radius: 8px;
  padding: 10px 14px;
  transition: border-color 0.3s ease;
  width: 100%;
}
.form-input:focus {
  outline: none;
  border-color: var(--koru-blue);
  box-shadow: 0 0 0 3px rgba(45,63,147,0.1);
}

/* Image gallery */
.gallery-thumb {
  cursor: pointer;
  transition: transform 0.2s ease, opacity 0.2s ease;
  border-radius: 8px;
  overflow: hidden;
}
.gallery-thumb:hover { transform: scale(1.03); opacity: 0.85; }

/* Lightbox */
#lightbox {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.92);
  z-index: 9999;
  align-items: center;
  justify-content: center;
}
#lightbox.active { display: flex; }

/* Toast */
.toast {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9998;
  padding: 14px 22px;
  border-radius: 10px;
  color: white;
  font-weight: 600;
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
  animation: slideUp 0.4s ease;
}
.toast.success { background: #059669; }
.toast.error { background: #dc2626; }
@keyframes slideUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

/* Responsive */
@media (max-width: 768px) {
  .hero-title { font-size: 1.8rem !important; }
  .filter-bar { border-radius: 12px; }
}

/* Language switcher */
.lang-btn { transition: all 0.2s ease; }
.lang-btn.active {
  background: var(--koru-blue);
  color: white;
}

/* Mobile menu */
#mobile-menu {
  display: none;
  background: white;
  box-shadow: 0 10px 30px rgba(0,0,0,0.15);
}
#mobile-menu.open { display: block; }

/* Tabs */
.tab-btn { transition: all 0.2s ease; border-bottom: 3px solid transparent; }
.tab-btn.active {
  color: var(--koru-blue);
  border-bottom-color: var(--koru-blue);
  font-weight: 700;
}

/* Progress bar for page load */
#progress-bar {
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--koru-blue), var(--koru-brown));
  z-index: 10000;
  transition: width 0.3s ease;
}

/* Segment cards */
.segment-card {
  transition: all 0.3s ease;
  border: 2px solid transparent;
}
.segment-card:hover {
  border-color: var(--koru-blue);
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(45,63,147,0.12);
}

/* Region cards */
.region-card {
  transition: all 0.3s ease;
  overflow: hidden;
}
.region-card:hover { transform: translateY(-4px); }
.region-card .overlay {
  background: linear-gradient(to top, rgba(45,63,147,0.9), transparent);
}

/* Admin table */
.admin-table tr:hover { background: rgba(45,63,147,0.04); }

/* Breadcrumb */
.breadcrumb-item + .breadcrumb-item::before {
  content: '›';
  margin: 0 8px;
  color: var(--koru-gray);
}

/* ── CMS Content Styles ─────────────────────────────────── */
.cms-content h1, .cms-content h2, .cms-content h3 { color: #1e293b; font-weight: 700; margin: 1.5em 0 0.75em; }
.cms-content h1 { font-size: 2em; }
.cms-content h2 { font-size: 1.5em; }
.cms-content h3 { font-size: 1.25em; }
.cms-content p { margin: 0.75em 0; line-height: 1.75; }
.cms-content a { color: var(--koru-blue); text-decoration: underline; }
.cms-content ul, .cms-content ol { padding-left: 1.75em; margin: 0.75em 0; }
.cms-content li { margin: 0.35em 0; }
.cms-content blockquote { border-left: 4px solid var(--koru-blue); padding: 0.75em 1.25em; margin: 1em 0; background: #f0f4ff; border-radius: 0 8px 8px 0; }
.cms-content img { max-width: 100%; border-radius: 12px; margin: 1em 0; }
.cms-content iframe, .cms-content video { max-width: 100%; border-radius: 12px; margin: 1em 0; aspect-ratio: 16/9; width: 100%; }
.cms-content pre { background: #1e293b; color: #e2e8f0; padding: 1em 1.25em; border-radius: 10px; overflow-x: auto; font-size: 0.9em; }
.cms-content code { background: #f1f5f9; padding: 0.1em 0.4em; border-radius: 4px; font-size: 0.9em; }
.cms-content table { width: 100%; border-collapse: collapse; margin: 1em 0; }
.cms-content th, .cms-content td { border: 1px solid #e2e8f0; padding: 0.75em 1em; }
.cms-content th { background: #f8fafc; font-weight: 600; }

/* Quill override */
.ql-toolbar.ql-snow { border-radius: 0; border-bottom: 1px solid #e5e7eb; background: #f9fafb; }
.ql-container.ql-snow { border: none; font-family: inherit; }
.ql-editor { min-height: 400px; font-size: 15px; line-height: 1.75; }

/* Media card hover */
.media-card { transition: box-shadow 0.2s, transform 0.2s; }
.media-card:hover { transform: translateY(-2px); }
