/* KODU — Estilos compartidos entre páginas. Incluir después de kodu-styles.css */

/* =============================================
   PAGE HERO (desarrollos, inmuebles, nosotros, insights)
   ============================================= */
.page-hero {
  padding: 140px 2rem 80px;
  background: linear-gradient(to bottom, var(--off-white), var(--white));
  border-bottom: 1px solid var(--light-gray);
  text-align: center;
}
.page-hero-label {
  font-size: 10px; font-weight: 600; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 1.2rem;
  display: flex; align-items: center; justify-content: center; gap: 12px;
}
.page-hero-label::before, .page-hero-label::after {
  content: ''; display: block; width: 32px; height: 1px; background: var(--gold); opacity: 0.6;
}
.page-hero-title {
  font-family: var(--font-serif); font-size: clamp(40px, 6vw, 68px);
  font-weight: 300; line-height: 1.1; color: var(--black); margin-bottom: 1.2rem;
}
.page-hero-title em { font-style: italic; color: var(--gold-dark); }
.page-hero-sub {
  font-size: 12px; font-weight: 300; letter-spacing: 0.15em;
  color: var(--gray); text-transform: uppercase;
}

/* =============================================
   SECTION LAYOUT
   ============================================= */
.section-inner { max-width: 1280px; margin: 0 auto; padding: 0 2rem; }

/* =============================================
   CTA BANNER (desarrollos, inmuebles, nosotros)
   ============================================= */
.cta-banner { background: var(--black); padding: 80px 2rem; text-align: center; margin-top: 80px; }
.cta-label {
  font-size: 10px; font-weight: 600; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 1.5rem;
}
.cta-title {
  font-family: var(--font-serif); font-size: clamp(30px, 4vw, 48px);
  font-weight: 300; color: var(--white); margin-bottom: 1rem; line-height: 1.2;
}
.cta-title em { font-style: italic; color: var(--gold-light); }
.cta-sub { font-size: 12px; color: var(--gray); margin-bottom: 2.5rem; letter-spacing: 0.1em; }
.btn-cta {
  font-size: 11px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase;
  padding: 16px 44px; background: var(--gold); color: white;
  text-decoration: none; display: inline-block; transition: background 0.3s;
}
.btn-cta:hover { background: var(--gold-dark); }

/* =============================================
   STAT BOXES (index, nosotros, ku27)
   ============================================= */
.stats { background: var(--off-white); padding: 80px 0; border-top: 1px solid var(--light-gray); }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; }
.stat-box { background: var(--white); padding: 2.5rem 2rem; border-left: 2px solid var(--gold); }
.stat-num { font-size: 48px; font-weight: 300; color: var(--gold-dark); line-height: 1; margin-bottom: 8px; }
.stat-label {
  font-size: 10px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--gray);
}

/* =============================================
   SEARCH BOX (desarrollos, inmuebles)
   ============================================= */
.search-box {
  background: var(--white); border: 1px solid var(--light-gray);
  padding: 1.5rem; max-width: 1280px; margin: 2.5rem auto 0;
}
.search-row { display: grid; grid-template-columns: repeat(3, 1fr) auto; gap: 8px; }
.search-select {
  background: var(--off-white); border: 1px solid var(--light-gray);
  color: var(--black); font-size: 11px; font-family: var(--font-sans);
  padding: 10px 12px; outline: none; cursor: pointer; width: 100%;
}
.search-btn {
  background: var(--gold); color: white; border: none; cursor: pointer;
  font-size: 11px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase;
  padding: 10px 24px; font-family: var(--font-sans); white-space: nowrap; transition: background 0.2s;
}
.search-btn:hover { background: var(--gold-dark); }

/* =============================================
   PROJECT/PROPERTY CARDS (desarrollos, inmuebles)
   ============================================= */
.projects-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; }
.project-card { background: var(--white); overflow: hidden; transition: box-shadow 0.3s; }
.project-card:hover { box-shadow: 0 12px 48px rgba(0,0,0,0.1); }
.card-image {
  position: relative; height: 280px; overflow: hidden;
  background: linear-gradient(135deg, #2d2519 0%, #1a1a1a 100%);
}
.card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.project-card:hover .card-image img { transform: scale(1.04); }
.card-status {
  position: absolute; top: 1.2rem; left: 1.2rem;
  font-size: 9px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; padding: 5px 14px;
}
.card-body { padding: 1.5rem; border: 1px solid var(--light-gray); border-top: none; }
.card-location {
  font-size: 10px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 0.7rem; display: flex; align-items: center; gap: 6px;
}
.card-location::before { content: ''; display: block; width: 16px; height: 1px; background: var(--gold); }
.card-name { font-size: 22px; font-weight: 400; line-height: 1.2; margin-bottom: 0.5rem; }
.card-desc { font-size: 12px; font-weight: 300; color: var(--gray); line-height: 1.7; margin-bottom: 1.5rem; }
.card-specs {
  display: flex; flex-wrap: nowrap; align-items: stretch;
  margin: 1rem -1.5rem 1.5rem;
  border-top: 1px solid var(--light-gray); border-bottom: 1px solid var(--light-gray);
}
.spec { flex: 1 1 0%; min-width: 0; padding: 1.2rem 0.3rem; text-align: center; background: var(--off-white); border-right: 1px solid var(--light-gray); overflow: hidden; }
.spec:last-child { border-right: none; }
.spec-num { font-family: var(--font-serif); font-size: 20px; font-weight: 300; color: var(--gold-dark); line-height: 1; }
.spec-label { font-size: 8px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gray); margin-top: 5px; line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.card-spec {
  background: var(--off-white); padding: 10px 12px; text-align: center;
  font-size: 11px; font-weight: 400; color: var(--gray);
}
.card-spec strong { display: block; font-size: 14px; font-weight: 400; color: var(--black); margin-bottom: 2px; }
.card-footer { display: flex; justify-content: space-between; align-items: center; padding-top: 1.5rem; border-top: 1px solid var(--light-gray); }
.card-price { font-size: 20px; font-weight: 400; color: var(--black); }
.card-price small { display: block; font-size: 10px; font-weight: 400; color: var(--gray); letter-spacing: 0.05em; }
.card-btn {
  font-size: 10px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase;
  padding: 10px 20px; background: var(--gold); color: white;
  text-decoration: none; transition: background 0.2s;
}
.card-btn:hover { background: var(--gold-dark); }

/* =============================================
   FOOTER OVERRIDES (pages that redefine footer grid)
   ============================================= */
.footer-inner { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 60px; margin-bottom: 40px; }
.footer-social {
  display: flex; gap: 1.8rem; justify-content: center; padding: 1.2rem 0;
  border-top: 1px solid #222; margin-top: 0; max-width: 1280px; margin-left: auto; margin-right: auto;
}
.footer-social a {
  font-size: 10px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(255,255,255,0.35); text-decoration: none; transition: color 0.2s;
}
.footer-social a:hover { color: var(--gold); }

/* =============================================
   CONTENT LABELS (nosotros, general)
   ============================================= */
.content-label {
  font-size: 10px; font-weight: 600; letter-spacing: 0.25em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 0.7rem; margin-top: 2.5rem;
}
.content-label:first-child { margin-top: 0; }
.content-title {
  font-size: clamp(28px, 3vw, 40px); font-weight: 300; line-height: 1.2;
  color: var(--black); margin-bottom: 1.5rem;
}
.content-title em { font-style: italic; color: var(--gold-dark); }
.content-text { font-size: 14px; font-weight: 300; line-height: 1.9; color: var(--gray); margin-bottom: 1.4rem; }

/* =============================================
   RESPONSIVE — SHARED PAGE RULES
   ============================================= */
@media (max-width: 768px) {
  .projects-grid { grid-template-columns: 1fr; }
  .search-row { grid-template-columns: 1fr 1fr; }
  .search-row .search-btn { grid-column: 1 / -1; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .footer-inner { grid-template-columns: 1fr; gap: 2rem; margin-bottom: 2rem; }
  .footer-bottom { flex-direction: column; gap: 0.5rem; font-size: 10px; }
}
