/* ===================================
   DAFNE MTZ REAL ESTATE - CSS Global
   =================================== */
:root {
  --gold: #C9A96E;
  --gold-light: #E8D5A3;
  --gold-dark: #8B6914;
  --black: #0A0A0A;
  --black2: #111111;
  --black3: #1A1A1A;
  --gray: #2A2A2A;
  --gray2: #3A3A3A;
  --text-muted: #888;
  --text-light: #CCC;
  --font-serif: 'Cormorant Garamond', serif;
  --font-sans: 'Jost', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { background: var(--black); color: var(--text-light); font-family: var(--font-sans); font-weight: 300; overflow-x: hidden; }
.text-gold { color: var(--gold) !important; }
.text-gold-muted { color: rgba(201,169,110,0.4); }
.bg-black2 { background: var(--black2); }
.bg-black3 { background: var(--black3); }

/* NAVBAR */
#mainNav { background: rgba(10,10,10,0.95); backdrop-filter: blur(12px); border-bottom: 1px solid rgba(201,169,110,0.15); padding: 1.2rem 0; transition: all 0.3s; }
.navbar-brand { display: flex; flex-direction: column; line-height: 1; text-decoration: none; }
.brand-name { font-family: var(--font-serif); font-size: 1.1rem; font-weight: 600; letter-spacing: 0.35em; color: var(--gold); text-transform: uppercase; }
.brand-sub { font-size: 0.5rem; letter-spacing: 0.6em; color: var(--text-muted); font-family: var(--font-sans); text-transform: uppercase; margin-top: 2px; }
.nav-link { color: var(--text-muted) !important; font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; transition: color 0.3s !important; }
.nav-link:hover { color: var(--gold) !important; }
.btn-gold-outline { background: transparent; border: 1px solid var(--gold); color: var(--gold) !important; font-family: var(--font-sans); font-size: 0.65rem; letter-spacing: 0.25em; text-transform: uppercase; padding: 0.55rem 1.5rem; transition: all 0.3s; text-decoration: none; }
.btn-gold-outline:hover { background: var(--gold); color: var(--black) !important; }
.btn-gold { background: var(--gold); border: 1px solid var(--gold); color: var(--black) !important; font-family: var(--font-sans); font-size: 0.65rem; letter-spacing: 0.25em; text-transform: uppercase; padding: 0.9rem 2.5rem; transition: all 0.3s; text-decoration: none; display: inline-block; cursor: pointer; border-radius: 0; }
.btn-gold:hover { background: var(--gold-light); border-color: var(--gold-light); }

/* SECTION COMMON */
section, .section-pad { padding: 5rem 0; }
.eyebrow { font-size: 0.6rem; letter-spacing: 0.45em; color: var(--gold); text-transform: uppercase; display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; }
.eyebrow::before { content: ''; display: inline-block; width: 30px; height: 1px; background: var(--gold); }
.section-title { font-family: var(--font-serif); font-size: clamp(2rem, 3.5vw, 3rem); font-weight: 300; color: #FFF; line-height: 1.1; }
.gold-divider { width: 60px; height: 1px; background: var(--gold); margin: 1.5rem 0; }

/* HERO */
.hero-section { min-height: 100vh; padding-top: 90px; background: var(--black); display: flex; align-items: center; position: relative; overflow: hidden; }
.hero-bg-accent { position: absolute; right: 0; top: 0; width: 50%; height: 100%; background: linear-gradient(160deg, #1E1A10 0%, #0D0D0D 100%); z-index: 0; }
.hero-content { position: relative; z-index: 2; }
.hero-tag { font-size: 0.6rem; letter-spacing: 0.5em; color: var(--gold); text-transform: uppercase; display: flex; align-items: center; gap: 1rem; margin-bottom: 2rem; }
.hero-tag::before { content: ''; display: inline-block; width: 40px; height: 1px; background: var(--gold); }
.hero-title { font-family: var(--font-serif); font-size: clamp(3rem, 5vw, 5rem); font-weight: 300; line-height: 1.05; color: #FFF; margin-bottom: 1.5rem; }
.hero-title em { font-style: italic; color: var(--gold); }
.hero-subtitle { font-size: 0.82rem; letter-spacing: 0.1em; color: var(--text-muted); line-height: 1.9; margin-bottom: 2.5rem; }
.hero-stat-num { font-family: var(--font-serif); font-size: 2.2rem; font-weight: 300; color: var(--gold); display: block; }
.hero-stat-label { font-size: 0.58rem; letter-spacing: 0.3em; color: var(--text-muted); text-transform: uppercase; }
.hero-stats { border-top: 1px solid rgba(201,169,110,0.15); padding-top: 2.5rem; margin-top: 3rem; display: flex; gap: 3rem; }
.hero-featured-card { background: linear-gradient(160deg, #1E1A10, #111); height: 500px; position: relative; overflow: hidden; display: flex; align-items: flex-end; padding: 2.5rem; }
.hero-featured-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.1) 60%); }
.hero-featured-content { position: relative; z-index: 2; width: 100%; }

/* SEARCH BAR */
.search-section { background: var(--black2); border-top: 1px solid rgba(201,169,110,0.1); border-bottom: 1px solid rgba(201,169,110,0.1); padding: 2.5rem 0; }
.search-bar { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr auto; background: var(--black3); border: 1px solid rgba(201,169,110,0.2); }
.search-field { padding: 1rem 1.5rem; border-right: 1px solid rgba(201,169,110,0.12); }
.search-field:last-of-type { border-right: none; }
.search-field label { display: block; font-size: 0.52rem; letter-spacing: 0.3em; color: var(--gold); text-transform: uppercase; margin-bottom: 6px; }
.search-field select, .search-field input { background: transparent; border: none; color: #FFF; font-family: var(--font-sans); font-size: 0.85rem; width: 100%; outline: none; appearance: none; }
.search-field select option { background: var(--black3); }
.search-submit { background: var(--gold); border: none; padding: 0 2rem; font-family: var(--font-sans); font-size: 0.62rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--black); font-weight: 500; cursor: pointer; white-space: nowrap; transition: background 0.3s; }
.search-submit:hover { background: var(--gold-light); }

/* PROPERTY CARDS */
.prop-card { background: var(--black2); overflow: hidden; transition: transform 0.3s, box-shadow 0.3s; cursor: pointer; height: 100%; }
.prop-card:hover { transform: translateY(-4px); box-shadow: 0 20px 60px rgba(0,0,0,0.4); }
.prop-img { height: 220px; background: linear-gradient(135deg, #1E1A10, #111); position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.prop-img-inner { color: rgba(201,169,110,0.15); font-size: 4rem; }
.badge-tipo { position: absolute; top: 1rem; left: 1rem; font-size: 0.5rem; letter-spacing: 0.2em; padding: 5px 14px; text-transform: uppercase; font-weight: 500; border-radius: 0; }
.badge-venta { background: var(--gold); color: var(--black); }
.badge-renta { background: rgba(201,169,110,0.15); color: var(--gold); border: 1px solid rgba(201,169,110,0.3); }
.badge-destacada { position: absolute; top: 1rem; right: 1rem; background: rgba(0,0,0,0.7); color: var(--gold); font-size: 0.5rem; letter-spacing: 0.2em; padding: 4px 10px; text-transform: uppercase; border: 1px solid rgba(201,169,110,0.3); }
.prop-info { padding: 1.5rem; }
.prop-price { font-family: var(--font-serif); font-size: 1.6rem; font-weight: 300; color: var(--gold); margin-bottom: 0.4rem; }
.prop-price small { font-family: var(--font-sans); font-size: 0.75rem; color: var(--text-muted); }
.prop-title { font-size: 0.88rem; color: #FFF; margin-bottom: 0.3rem; }
.prop-location { font-size: 0.68rem; color: var(--text-muted); letter-spacing: 0.1em; margin-bottom: 1rem; }
.prop-features { display: flex; gap: 1.2rem; padding-top: 1rem; border-top: 1px solid rgba(201,169,110,0.1); flex-wrap: wrap; }
.prop-feat { font-size: 0.65rem; color: var(--text-muted); }
.prop-feat strong { color: var(--text-light); font-weight: 400; }

/* AGENTS */
.agent-card { border: 1px solid rgba(201,169,110,0.12); padding: 2.5rem 2rem; text-align: center; transition: border-color 0.3s, background 0.3s; }
.agent-card:hover { border-color: rgba(201,169,110,0.4); background: rgba(201,169,110,0.03); }
.agent-avatar { width: 90px; height: 90px; border-radius: 50%; background: linear-gradient(135deg, #2A2A1A, #1A1A1A); border: 2px solid rgba(201,169,110,0.3); margin: 0 auto 1.5rem; display: flex; align-items: center; justify-content: center; font-family: var(--font-serif); font-size: 1.8rem; font-weight: 300; color: var(--gold); overflow: hidden; }
.agent-avatar img { width: 100%; height: 100%; object-fit: cover; }
.agent-name { font-family: var(--font-serif); font-size: 1.3rem; font-weight: 400; color: #FFF; margin-bottom: 0.3rem; }
.agent-role { font-size: 0.6rem; letter-spacing: 0.3em; color: var(--gold); text-transform: uppercase; margin-bottom: 1.2rem; }

/* TESTIMONIALS */
.test-card { padding: 2.5rem; border: 1px solid rgba(201,169,110,0.1); }
.test-stars { color: var(--gold); letter-spacing: 0.1em; margin-bottom: 1rem; }
.test-quote { font-family: var(--font-serif); font-size: 1.05rem; font-weight: 300; font-style: italic; color: var(--text-light); line-height: 1.7; margin-bottom: 1.5rem; }
.test-avatar { width: 42px; height: 42px; border-radius: 50%; background: rgba(201,169,110,0.15); display: flex; align-items: center; justify-content: center; font-family: var(--font-serif); color: var(--gold); font-size: 1rem; }

/* CONTACT */
.form-gold label { font-size: 0.55rem; letter-spacing: 0.3em; color: var(--gold); text-transform: uppercase; margin-bottom: 6px; display: block; }
.form-gold input, .form-gold textarea, .form-gold select {
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid rgba(201,169,110,0.2) !important;
  border-radius: 0 !important;
  color: #FFF !important;
  font-family: var(--font-sans) !important;
  font-size: 0.85rem !important;
  padding: 0.9rem 1.2rem !important;
  transition: border-color 0.3s !important;
  width: 100%;
}
.form-gold input:focus, .form-gold textarea:focus, .form-gold select:focus {
  border-color: rgba(201,169,110,0.6) !important;
  box-shadow: none !important;
  outline: none;
}
.form-gold select option { background: var(--black3); color: #FFF; }
.contact-detail-icon { width: 42px; height: 42px; border: 1px solid rgba(201,169,110,0.3); display: flex; align-items: center; justify-content: center; color: var(--gold); flex-shrink: 0; }
.contact-detail-label { font-size: 0.52rem; letter-spacing: 0.3em; color: var(--gold); text-transform: uppercase; margin-bottom: 3px; }

/* ABOUT */
.about-img-accent { position: absolute; bottom: -2rem; right: -1rem; width: 160px; height: 160px; background: var(--gold); display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 4px; }
.accent-num { font-family: var(--font-serif); font-size: 3rem; font-weight: 300; color: var(--black); line-height: 1; }
.accent-txt { font-size: 0.52rem; letter-spacing: 0.18em; color: rgba(0,0,0,0.7); text-transform: uppercase; text-align: center; padding: 0 0.5rem; }
.about-value { border-left: 2px solid var(--gold); padding-left: 1rem; margin-bottom: 0.5rem; }
.about-value-title { font-size: 0.65rem; letter-spacing: 0.2em; color: var(--gold); text-transform: uppercase; margin-bottom: 4px; }
.about-value-text { font-size: 0.75rem; color: var(--text-muted); }

/* FOOTER */
.site-footer { background: var(--black); border-top: 1px solid rgba(201,169,110,0.1); padding-top: 5rem; margin-top: 0; }
.footer-logo { font-family: var(--font-serif); font-size: 1.1rem; font-weight: 600; letter-spacing: 0.35em; color: var(--gold); text-transform: uppercase; }
.footer-logo span { display: block; font-size: 0.5rem; font-weight: 300; letter-spacing: 0.6em; color: var(--text-muted); font-family: var(--font-sans); margin-top: 2px; }
.footer-desc { font-size: 0.75rem; color: var(--text-muted); line-height: 1.9; }
.footer-heading { font-size: 0.6rem; letter-spacing: 0.35em; color: var(--gold); text-transform: uppercase; margin-bottom: 1.5rem; }
.footer-links { list-style: none; padding: 0; }
.footer-links li { margin-bottom: 0.7rem; font-size: 0.75rem; color: var(--text-muted); }
.footer-links a { color: var(--text-muted); text-decoration: none; transition: color 0.3s; }
.footer-links a:hover { color: var(--gold); }
.footer-social { display: flex; gap: 0.8rem; }
.social-icon { width: 36px; height: 36px; border: 1px solid rgba(201,169,110,0.25); display: flex; align-items: center; justify-content: center; color: var(--text-muted); font-size: 0.85rem; text-decoration: none; transition: all 0.3s; }
.social-icon:hover { border-color: var(--gold); color: var(--gold); }
.footer-bottom { border-top: 1px solid rgba(201,169,110,0.1); padding: 2rem 0; display: flex; justify-content: space-between; align-items: center; font-size: 0.65rem; color: var(--text-muted); }
.whatsapp-float { position: fixed; bottom: 2rem; right: 2rem; width: 56px; height: 56px; background: #25D366; border-radius: 50%; display: flex; align-items: center; justify-content: center; text-decoration: none; z-index: 999; box-shadow: 0 4px 20px rgba(37,211,102,0.3); color: white; font-size: 1.5rem; transition: transform 0.3s; }
.whatsapp-float:hover { transform: scale(1.1); color: white; }

/* ADMIN */
.admin-sidebar { width: 260px; min-height: 100vh; background: var(--black2); border-right: 1px solid rgba(201,169,110,0.1); position: fixed; left: 0; top: 0; z-index: 100; display: flex; flex-direction: column; }
.admin-logo { padding: 1.8rem 1.5rem; border-bottom: 1px solid rgba(201,169,110,0.1); }
.admin-nav { padding: 1.5rem 0; flex: 1; }
.admin-nav-item { display: flex; align-items: center; gap: 0.8rem; padding: 0.85rem 1.5rem; color: var(--text-muted); text-decoration: none; font-size: 0.75rem; letter-spacing: 0.1em; transition: all 0.2s; border-left: 3px solid transparent; }
.admin-nav-item:hover, .admin-nav-item.active { color: var(--gold); background: rgba(201,169,110,0.05); border-left-color: var(--gold); }
.admin-nav-item i { font-size: 1.1rem; }
.admin-content { margin-left: 260px; min-height: 100vh; background: var(--black3); }
.admin-topbar { background: var(--black2); border-bottom: 1px solid rgba(201,169,110,0.1); padding: 1rem 2rem; display: flex; justify-content: space-between; align-items: center; }
.admin-main { padding: 2rem; }
.admin-card { background: var(--black2); border: 1px solid rgba(201,169,110,0.1); padding: 1.5rem; }
.stat-card { background: var(--black2); border: 1px solid rgba(201,169,110,0.12); padding: 1.5rem; }
.stat-num { font-family: var(--font-serif); font-size: 2.5rem; font-weight: 300; color: var(--gold); display: block; }
.stat-label { font-size: 0.62rem; letter-spacing: 0.25em; color: var(--text-muted); text-transform: uppercase; }
.admin-table { width: 100%; border-collapse: collapse; font-size: 0.82rem; }
.admin-table th { font-size: 0.58rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold); padding: 1rem; border-bottom: 1px solid rgba(201,169,110,0.15); text-align: left; font-weight: 400; }
.admin-table td { padding: 0.9rem 1rem; border-bottom: 1px solid rgba(255,255,255,0.04); color: var(--text-light); vertical-align: middle; }
.admin-table tr:hover td { background: rgba(201,169,110,0.03); }
.badge-status { font-size: 0.55rem; letter-spacing: 0.15em; padding: 4px 10px; text-transform: uppercase; border-radius: 0; }
.badge-disponible { background: rgba(40,167,69,0.15); color: #5cb85c; border: 1px solid rgba(40,167,69,0.3); }
.badge-vendida { background: rgba(201,169,110,0.15); color: var(--gold); border: 1px solid rgba(201,169,110,0.3); }
.badge-rentada { background: rgba(23,162,184,0.15); color: #5bc0de; border: 1px solid rgba(23,162,184,0.3); }
.btn-admin-sm { font-size: 0.6rem; letter-spacing: 0.15em; padding: 5px 12px; border-radius: 0; text-transform: uppercase; }

/* MAP */
.map-container { background: var(--black3); border: 1px solid rgba(201,169,110,0.15); height: 260px; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 0.8rem; }
.map-container iframe { width: 100%; height: 100%; border: 0; }

/* DETAIL PAGE */
.prop-gallery { position: relative; }
.prop-gallery-main { height: 480px; background: linear-gradient(135deg, #1E1A10, #111); overflow: hidden; }
.prop-gallery-main img { width: 100%; height: 100%; object-fit: cover; }
.prop-gallery-thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px; margin-top: 4px; }
.prop-gallery-thumb { height: 100px; background: var(--black3); overflow: hidden; cursor: pointer; opacity: 0.7; transition: opacity 0.2s; }
.prop-gallery-thumb:hover { opacity: 1; }
.prop-gallery-thumb img { width: 100%; height: 100%; object-fit: cover; }

/* ALERTS */
.alert-gold { background: rgba(201,169,110,0.1); border: 1px solid rgba(201,169,110,0.3); color: var(--gold); border-radius: 0; font-size: 0.82rem; }

/* PAGINATION */
.pagination .page-link { background: var(--black2); border: 1px solid rgba(201,169,110,0.15); color: var(--text-muted); border-radius: 0; font-size: 0.75rem; }
.pagination .page-link:hover { background: rgba(201,169,110,0.1); color: var(--gold); border-color: rgba(201,169,110,0.3); }
.pagination .page-item.active .page-link { background: var(--gold); border-color: var(--gold); color: var(--black); }

/* RESPONSIVE */
@media (max-width: 768px) {
  .search-bar { grid-template-columns: 1fr 1fr; }
  .hero-stats { gap: 1.5rem; flex-wrap: wrap; }
  .admin-sidebar { transform: translateX(-100%); transition: transform 0.3s; }
  .admin-sidebar.show { transform: translateX(0); }
  .admin-content { margin-left: 0; }
  .about-img-accent { position: static; width: 100%; margin-top: 1rem; height: 80px; flex-direction: row; gap: 1rem; }
}
