@import url("https://fonts.googleapis.com/css2?family=Exo+2:wght@500;600;700;800&family=Inter:wght@400;500;600;700&display=swap");

/* ============================================================
   Lorca Rivas — Website UI Kit styles
   ============================================================ */
/* ============================================================
   Lorca Rivas Inmobiliaria — Foundation Tokens
   Colors and typography as CSS custom properties.
   ============================================================ */

/* ---- Fonts (Google Fonts substitution — see README) ---- */
:root {
  /* --------------------------------------------------------
     BRAND PALETTE — sampled from the logo
     -------------------------------------------------------- */
  --lr-navy:        #1B2E8E;   /* "lorca" — primary deep blue */
  --lr-navy-600:    #243BA8;   /* hover / lighter navy */
  --lr-navy-800:    #13206A;   /* pressed / deeper navy */
  --lr-navy-50:     #EEF1FB;   /* tinted background */

  --lr-sky:         #2BB7E8;   /* "rivas" — bright cyan-blue */
  --lr-sky-600:     #18A2D3;   /* hover */
  --lr-sky-800:     #0F7EA8;   /* pressed / ink-on-sky */
  --lr-sky-50:      #E7F6FD;   /* tinted background */

  --lr-orange:      #F58A1F;   /* "INMOBILIARIA" — accent */
  --lr-orange-600:  #E17612;   /* hover */
  --lr-orange-800:  #B85A07;   /* pressed */
  --lr-orange-50:   #FEF1E3;   /* tinted background */

  /* --------------------------------------------------------
     NEUTRALS — warm-neutral grays (slightly blue to read with navy)
     -------------------------------------------------------- */
  --lr-ink:         #0E1430;   /* near-black, deeper than navy */
  --lr-gray-900:    #1C223A;
  --lr-gray-800:    #2E3452;
  --lr-gray-700:    #4A5070;
  --lr-gray-600:    #6C7290;
  --lr-gray-500:    #8C92AC;
  --lr-gray-400:    #B5BACC;
  --lr-gray-300:    #D7DAE5;
  --lr-gray-200:    #E8EAF1;
  --lr-gray-100:    #F3F4F9;
  --lr-gray-50:     #F9FAFC;
  --lr-white:       #FFFFFF;

  /* --------------------------------------------------------
     SEMANTIC — foreground / background / surface
     -------------------------------------------------------- */
  --fg-1: var(--lr-ink);       /* primary text */
  --fg-2: var(--lr-gray-700);  /* secondary text */
  --fg-3: var(--lr-gray-500);  /* tertiary / captions */
  --fg-on-brand: #FFFFFF;      /* text on navy / sky / orange */

  --bg-page:    var(--lr-gray-50);
  --bg-surface: #FFFFFF;
  --bg-sunken:  var(--lr-gray-100);
  --bg-navy:    var(--lr-navy);
  --bg-sky-soft:  var(--lr-sky-50);
  --bg-orange-soft: var(--lr-orange-50);

  --border-1: var(--lr-gray-200);
  --border-2: var(--lr-gray-300);
  --border-strong: var(--lr-gray-400);

  /* State colors */
  --success:  #1E9E5F;
  --warning:  #D98A1C;
  --danger:   #D93D3D;
  --info:     var(--lr-sky);

  /* --------------------------------------------------------
     RADII
     -------------------------------------------------------- */
  --radius-xs: 4px;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-xl: 20px;
  --radius-pill: 999px;

  /* --------------------------------------------------------
     SHADOWS — soft, low, professional (no drama)
     -------------------------------------------------------- */
  --shadow-xs: 0 1px 2px rgba(14, 20, 48, 0.06);
  --shadow-sm: 0 2px 6px rgba(14, 20, 48, 0.07), 0 1px 2px rgba(14, 20, 48, 0.04);
  --shadow-md: 0 8px 20px rgba(14, 20, 48, 0.08), 0 2px 6px rgba(14, 20, 48, 0.05);
  --shadow-lg: 0 20px 40px rgba(14, 20, 48, 0.12), 0 6px 14px rgba(14, 20, 48, 0.06);
  --shadow-navy: 0 12px 28px rgba(27, 46, 142, 0.28);
  --shadow-orange: 0 10px 22px rgba(245, 138, 31, 0.32);

  /* --------------------------------------------------------
     SPACING (4pt base)
     -------------------------------------------------------- */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;
  --space-24: 96px;

  /* --------------------------------------------------------
     MOTION
     -------------------------------------------------------- */
  --ease-out: cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --duration-fast: 140ms;
  --duration-base: 220ms;
  --duration-slow: 380ms;

  /* --------------------------------------------------------
     TYPOGRAPHY — stacks
     -------------------------------------------------------- */
  --font-display: "Exo 2", "Segoe UI", system-ui, -apple-system, sans-serif;
  --font-body:    "Inter", "Helvetica Neue", Arial, system-ui, -apple-system, sans-serif;
  --font-mono:    "JetBrains Mono", "SF Mono", ui-monospace, Menlo, monospace;

  /* Type scale — fluid-ish static scale */
  --fs-display-xl: 64px;   --lh-display-xl: 1.05;
  --fs-display-lg: 48px;   --lh-display-lg: 1.08;
  --fs-display-md: 36px;   --lh-display-md: 1.12;
  --fs-h1: 32px;           --lh-h1: 1.18;
  --fs-h2: 26px;           --lh-h2: 1.22;
  --fs-h3: 20px;           --lh-h3: 1.3;
  --fs-h4: 17px;           --lh-h4: 1.35;
  --fs-body-lg: 18px;      --lh-body-lg: 1.55;
  --fs-body: 16px;         --lh-body: 1.55;
  --fs-body-sm: 14px;      --lh-body-sm: 1.5;
  --fs-caption: 12px;      --lh-caption: 1.4;
  --fs-overline: 11px;     --lh-overline: 1.3;
}

/* ============================================================
   SEMANTIC TEXT CLASSES
   Use these directly or copy the values into component CSS.
   ============================================================ */

.lr-display-xl,
.lr-display-lg,
.lr-display-md {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--fg-1);
}

.lr-display-xl { font-size: var(--fs-display-xl); line-height: var(--lh-display-xl); letter-spacing: -0.02em; }
.lr-display-lg { font-size: var(--fs-display-lg); line-height: var(--lh-display-lg); letter-spacing: -0.015em; }
.lr-display-md { font-size: var(--fs-display-md); line-height: var(--lh-display-md); }

.lr-h1, .lr-h2, .lr-h3, .lr-h4 {
  font-family: var(--font-display);
  color: var(--fg-1);
  font-weight: 700;
  letter-spacing: -0.005em;
}
.lr-h1 { font-size: var(--fs-h1); line-height: var(--lh-h1); }
.lr-h2 { font-size: var(--fs-h2); line-height: var(--lh-h2); }
.lr-h3 { font-size: var(--fs-h3); line-height: var(--lh-h3); font-weight: 600; }
.lr-h4 { font-size: var(--fs-h4); line-height: var(--lh-h4); font-weight: 600; }

.lr-body-lg, .lr-body, .lr-body-sm, .lr-caption {
  font-family: var(--font-body);
  color: var(--fg-1);
  font-weight: 400;
}
.lr-body-lg { font-size: var(--fs-body-lg); line-height: var(--lh-body-lg); }
.lr-body    { font-size: var(--fs-body);    line-height: var(--lh-body); }
.lr-body-sm { font-size: var(--fs-body-sm); line-height: var(--lh-body-sm); color: var(--fg-2); }
.lr-caption { font-size: var(--fs-caption); line-height: var(--lh-caption); color: var(--fg-3); }

.lr-overline {
  font-family: var(--font-display);
  font-size: var(--fs-overline);
  line-height: var(--lh-overline);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--lr-orange);
}

.lr-eyebrow {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--lr-sky-800);
}

/* Price / numeric display — geometric, tabular */
.lr-price {
  font-family: var(--font-display);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  color: var(--lr-navy);
}

/* Native element defaults (optional, scoped via .lr-typography) */
.lr-typography h1 { font-family: var(--font-display); font-size: var(--fs-h1); line-height: var(--lh-h1); font-weight: 700; letter-spacing: -0.005em; color: var(--fg-1); }
.lr-typography h2 { font-family: var(--font-display); font-size: var(--fs-h2); line-height: var(--lh-h2); font-weight: 700; color: var(--fg-1); }
.lr-typography h3 { font-family: var(--font-display); font-size: var(--fs-h3); line-height: var(--lh-h3); font-weight: 600; color: var(--fg-1); }
.lr-typography p  { font-family: var(--font-body);    font-size: var(--fs-body); line-height: var(--lh-body); color: var(--fg-1); }
.lr-typography small { font-size: var(--fs-body-sm); color: var(--fg-2); }


* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; font-family: var(--font-body); color: var(--fg-1); background: var(--bg-page); -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; cursor: pointer; }
button { font-family: inherit; cursor: pointer; }

.lr-container { max-width: 1200px; margin: 0 auto; padding: 0 32px; }

/* ----- Buttons ----- */
.lr-btn {
  font-family: var(--font-display); font-weight: 600;
  font-size: 14px; letter-spacing: 0.01em;
  padding: 11px 20px; border-radius: var(--radius-md);
  border: 1px solid transparent;
  display: inline-flex; align-items: center; gap: 8px;
  transition: all var(--duration-base) var(--ease-out);
}
.lr-btn--lg { font-size: 15px; padding: 14px 26px; border-radius: var(--radius-lg); }
.lr-btn--primary   { background: var(--lr-navy); color: #fff; box-shadow: var(--shadow-navy); }
.lr-btn--primary:hover { background: var(--lr-navy-600); transform: translateY(-1px); }
.lr-btn--accent    { background: var(--lr-orange); color: #fff; box-shadow: var(--shadow-orange); }
.lr-btn--accent:hover { background: var(--lr-orange-600); transform: translateY(-1px); }
.lr-btn--secondary { background: #fff; color: var(--lr-navy); border-color: var(--lr-navy); }
.lr-btn--secondary:hover { background: var(--lr-navy-50); }
.lr-btn--ghost { background: transparent; color: var(--lr-navy); }

/* ----- Header ----- */
.lr-header { position: sticky; top: 0; z-index: 20; background: #fff; border-bottom: 1px solid var(--border-1); }
.lr-header__inner { display: flex; align-items: center; gap: 32px; height: 76px; }
.lr-header__logo img { height: 40px; }
.lr-header__nav { display: flex; gap: 28px; margin-left: 12px; }
.lr-header__link {
  font: 600 14px var(--font-display); color: var(--fg-1);
  padding: 6px 2px; border-bottom: 2px solid transparent;
  transition: color var(--duration-fast);
}
.lr-header__link:hover { color: var(--lr-navy); }
.lr-header__link.is-active { color: var(--lr-navy); border-bottom-color: var(--lr-orange); }
.lr-header__cta { margin-left: auto; }

/* ----- Hero ----- */
.lr-hero { position: relative; overflow: hidden; }
.lr-hero__bg { position: absolute; inset: 0; z-index: 0; }
.lr-hero__bg img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.lr-hero__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(14,20,48,0.86) 0%, rgba(14,20,48,0.72) 45%, rgba(14,20,48,0.2) 100%);
}
.lr-hero__content { position: relative; z-index: 1; padding: 96px 32px 112px; max-width: 1200px; margin: 0 auto; color: #fff; }
.lr-hero__content .lr-overline { color: var(--lr-orange); }
.lr-hero__title {
  font-family: var(--font-display); font-weight: 800; color: #fff;
  font-size: clamp(40px, 5.2vw, 64px); line-height: 1.05; letter-spacing: -0.02em;
  margin: 10px 0 18px; max-width: 14ch;
}
.lr-hero__lede { font-size: 18px; line-height: 1.55; color: rgba(255,255,255,0.85); max-width: 52ch; margin: 0 0 28px; }
.lr-hero__actions { display: flex; gap: 14px; flex-wrap: wrap; }
.lr-hero__actions .lr-btn--secondary { background: rgba(255,255,255,0.1); color: #fff; border-color: rgba(255,255,255,0.4); backdrop-filter: blur(6px); }
.lr-hero__actions .lr-btn--secondary:hover { background: rgba(255,255,255,0.2); }

/* ----- Search bar ----- */
.lr-search {
  background: #fff; padding: 12px;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  display: grid; grid-template-columns: 1.4fr 1fr 1fr auto; gap: 8px;
  max-width: 900px; margin: -40px auto 0; position: relative; z-index: 2;
}
.lr-search__field { display: flex; flex-direction: column; gap: 2px; padding: 8px 14px; border-right: 1px solid var(--border-1); }
.lr-search__field:nth-last-of-type(1) { border-right: none; }
.lr-search__field label { font: 700 10px var(--font-display); text-transform: uppercase; letter-spacing: 0.1em; color: var(--fg-3); }
.lr-search__field input,
.lr-search__field select {
  font: 600 15px var(--font-body); color: var(--fg-1); background: transparent;
  border: none; outline: none; padding: 2px 0; appearance: none;
}
.lr-search__go {
  background: var(--lr-navy); color: #fff; border: none;
  padding: 0 26px; border-radius: var(--radius-md);
  font: 700 13px var(--font-display); letter-spacing: 0.06em; text-transform: uppercase;
  display: flex; align-items: center; gap: 8px;
  transition: background var(--duration-fast);
}
.lr-search__go:hover { background: var(--lr-navy-600); }

/* ----- Sections ----- */
.lr-section { padding: 80px 0; }
.lr-section--soft { background: var(--bg-sunken); }
.lr-section__head { max-width: 720px; margin-bottom: 40px; }
.lr-section__title { font: 700 clamp(28px, 3vw, 40px)/1.1 var(--font-display); letter-spacing: -0.015em; color: var(--fg-1); margin: 6px 0 10px; }
.lr-section__lede { font-size: 17px; color: var(--fg-2); line-height: 1.55; margin: 0; }

/* ----- Services ----- */
.lr-services { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.lr-service {
  background: #fff; padding: 24px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-1);
  display: flex; flex-direction: column; gap: 10px;
  transition: transform var(--duration-base), box-shadow var(--duration-base);
}
.lr-service:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.lr-service__ico {
  width: 52px; height: 52px; border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
}
.lr-service__ico--navy   { background: var(--lr-navy-50); color: var(--lr-navy); }
.lr-service__ico--orange { background: var(--lr-orange-50); color: var(--lr-orange-800); }
.lr-service__ico--sky    { background: var(--lr-sky-50); color: var(--lr-sky-800); }
.lr-service__title { font: 700 18px var(--font-display); color: var(--fg-1); margin: 4px 0 0; }
.lr-service__desc { font-size: 14px; color: var(--fg-2); line-height: 1.55; margin: 0; flex: 1; }
.lr-service__link { font: 600 13px var(--font-display); color: var(--lr-orange); letter-spacing: 0.02em; }

/* ----- Badges ----- */
.lr-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 10px; border-radius: 4px;
  font: 700 11px var(--font-display);
  letter-spacing: 0.1em; text-transform: uppercase; line-height: 1;
}
.lr-badge--orange { background: var(--lr-orange); color: #fff; }
.lr-badge--sky    { background: var(--lr-sky); color: #fff; }
.lr-badge--soft   { background: rgba(255,255,255,0.92); color: var(--lr-navy); backdrop-filter: blur(4px); }
.lr-badge--reservada { background: #7c3aed; color: #fff; }
.lr-badge--financiacion { background: #16a34a; color: #fff; }

/* ----- Property card ----- */
.lr-props { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.lr-prop {
  background: #fff; border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-sm); transition: transform var(--duration-base), box-shadow var(--duration-base);
  display: flex; flex-direction: column;
}
.lr-prop:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.lr-prop__thumb { height: 210px; background-size: cover; background-position: center; position: relative; display: flex; gap: 8px; padding: 12px; flex-wrap: wrap; align-content: flex-start; }
.lr-prop__meta { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 6px; }
.lr-prop__loc { font: 600 11px var(--font-display); color: var(--fg-3); letter-spacing: 0.12em; text-transform: uppercase; }
.lr-prop__title { font: 700 17px/1.3 var(--font-display); color: var(--fg-1); letter-spacing: -0.005em; margin: 2px 0 4px; }
.lr-prop__price { font: 700 22px var(--font-display); color: var(--lr-navy); letter-spacing: -0.01em; }
.lr-prop__attrs { display: flex; gap: 14px; padding-top: 10px; border-top: 1px solid var(--border-1); margin-top: 6px; color: var(--fg-2); font-size: 13px; font-weight: 500; }
.lr-prop__attrs span { display: inline-flex; align-items: center; gap: 5px; }

/* ----- Listado con filtros ----- */
.lr-filters { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; }
.lr-chip {
  padding: 8px 14px; border-radius: var(--radius-pill);
  background: #fff; border: 1px solid var(--border-2);
  font: 600 13px var(--font-body); color: var(--fg-2);
}
.lr-chip.is-active { background: var(--lr-navy); color: #fff; border-color: var(--lr-navy); }
.lr-count { font: 500 14px var(--font-body); color: var(--fg-2); margin-bottom: 16px; }

/* ----- Detail ----- */
.lr-link-back { background: none; border: none; color: var(--lr-navy); font: 600 14px var(--font-display); padding: 0 0 16px; }
.lr-detail { display: grid; grid-template-columns: 1.5fr 1fr; gap: 40px; align-items: flex-start; }
.lr-detail__main { height: 440px; background-size: cover; background-position: center; border-radius: var(--radius-lg); position: relative; padding: 16px; }
.lr-detail__thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 12px; }
.lr-detail__thumb { height: 80px; background-size: cover; background-position: center; border-radius: var(--radius-sm); border: none; padding: 0; opacity: 0.7; transition: opacity var(--duration-fast); }
.lr-detail__thumb.is-active { opacity: 1; outline: 2px solid var(--lr-orange); outline-offset: 2px; }
.lr-detail__aside { background: #fff; padding: 28px; border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); display: flex; flex-direction: column; gap: 14px; position: sticky; top: 100px; }
.lr-detail__title { font: 700 26px/1.25 var(--font-display); color: var(--fg-1); margin: 4px 0 0; letter-spacing: -0.01em; }
.lr-detail__price { font: 800 32px var(--font-display); color: var(--lr-navy); letter-spacing: -0.015em; }
.lr-detail__attrs { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; padding: 16px 0; border-top: 1px solid var(--border-1); border-bottom: 1px solid var(--border-1); }
.lr-detail__attrs > div { display: flex; flex-direction: column; }
.lr-detail__attrs span { font: 500 12px var(--font-body); color: var(--fg-3); text-transform: uppercase; letter-spacing: 0.08em; }
.lr-detail__attrs strong { font: 700 20px var(--font-display); color: var(--fg-1); }
.lr-detail__desc { font-size: 14px; color: var(--fg-2); line-height: 1.6; margin: 0; }
.lr-detail__cta { justify-content: center; width: 100%; }
.lr-detail__agent { display: flex; align-items: center; gap: 12px; padding-top: 14px; border-top: 1px solid var(--border-1); }
.lr-detail__agent-avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--lr-navy); color: #fff; display: flex; align-items: center; justify-content: center; font: 700 14px var(--font-display); letter-spacing: 0.04em; }
.lr-detail__agent strong { display: block; font: 700 14px var(--font-display); color: var(--fg-1); }
.lr-detail__agent span { font-size: 12px; color: var(--fg-3); }

/* ----- Footer ----- */
.lr-footer { background: var(--lr-navy); color: rgba(255,255,255,0.85); padding: 64px 0 28px; margin-top: 40px; }
.lr-footer__grid { display: grid; grid-template-columns: 1.2fr 1fr 1.3fr; gap: 48px; padding-bottom: 40px; border-bottom: 1px solid rgba(255,255,255,0.12); }
.lr-footer__logo { height: 48px; background: #fff; padding: 8px 12px; border-radius: var(--radius-md); margin-bottom: 14px; width: auto; display: inline-block; }
.lr-footer__col p { font-size: 14px; line-height: 1.6; margin: 0 0 8px; color: rgba(255,255,255,0.78); }
.lr-footer__col h4 { font: 700 13px var(--font-display); letter-spacing: 0.12em; text-transform: uppercase; color: #fff; margin: 0 0 12px; }
.lr-footer__line { font-size: 14px; }
.lr-footer__form { display: flex; flex-direction: column; gap: 10px; }
.lr-footer__form input { padding: 12px 14px; border-radius: var(--radius-md); border: 1px solid rgba(255,255,255,0.2); background: rgba(255,255,255,0.08); color: #fff; font: 400 14px var(--font-body); }
.lr-footer__form input::placeholder { color: rgba(255,255,255,0.55); }
.lr-footer__bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 24px; font-size: 13px; color: rgba(255,255,255,0.6); }
.lr-footer__social { display: flex; gap: 10px; }
.lr-footer__social a { width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,0.08); display: flex; align-items: center; justify-content: center; color: #fff; transition: background var(--duration-fast); }
.lr-footer__social a:hover { background: rgba(255,255,255,0.2); }

/* ----- Services landing page ----- */
.lr-page-title { text-align: center; padding: 60px 0 40px; background: var(--lr-navy); color: #fff; margin-bottom: 0; }
.lr-page-title h1 { font: 800 44px var(--font-display); letter-spacing: -0.02em; margin: 8px 0 6px; }
.lr-page-title p { font-size: 17px; color: rgba(255,255,255,0.75); margin: 0; }
.lr-page-title .lr-overline { color: var(--lr-sky); }


/* ============================================================
   Home-only styles — layered on top of system/styles.css
   ============================================================ */

/* Remove the default page bottom gap under footer since we stack */
body { background: var(--bg-page); }

/* ----- Featured header row ----- */
.home-feat__head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px; margin-bottom: 32px; flex-wrap: wrap;
}
.home-feat__head .lr-section__title { margin: 6px 0 0; }
.home-feat__all {
  font: 600 14px var(--font-display); color: var(--lr-navy);
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 16px; border-radius: var(--radius-pill);
  border: 1px solid var(--border-2); background: #fff;
  transition: all var(--duration-base) var(--ease-out);
}
.home-feat__all:hover {
  border-color: var(--lr-navy); color: var(--lr-navy);
  transform: translateX(2px); box-shadow: var(--shadow-sm);
}

/* Tiny nudge: tighten first grid spacing after search bar */
.lr-section.home-feat { padding-top: 72px; }

/* ----- ServicesTrio: 3-up feature cards ----- */
.home-trio {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  align-items: stretch;
}
.home-trio__card {
  position: relative; background: #fff;
  border: 1px solid var(--border-1);
  border-radius: var(--radius-lg);
  padding: 36px 32px 32px;
  display: flex; flex-direction: column; gap: 10px;
  transition: transform var(--duration-base) var(--ease-out),
              box-shadow var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out);
  overflow: hidden;
}
.home-trio__card::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: transparent; transition: background var(--duration-base) var(--ease-out);
}
.home-trio__card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.home-trio__card--orange:hover { border-color: var(--lr-orange-200, rgba(245,138,31,0.3)); }
.home-trio__card--orange:hover::before { background: var(--lr-orange); }
.home-trio__card--sky:hover    { border-color: rgba(43,183,232,0.35); }
.home-trio__card--sky:hover::before { background: var(--lr-sky); }
.home-trio__card--navy:hover   { border-color: rgba(27,46,142,0.35); }
.home-trio__card--navy:hover::before { background: var(--lr-navy); }

.home-trio__ico {
  width: 56px; height: 56px; border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 6px;
}
.home-trio__ico--orange { background: var(--lr-orange-50); color: var(--lr-orange-800); }
.home-trio__ico--sky    { background: var(--lr-sky-50); color: var(--lr-sky-800); }
.home-trio__ico--navy   { background: var(--lr-navy-50); color: var(--lr-navy); }

.home-trio__eyebrow {
  font: 700 11px var(--font-display); letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--fg-3);
}
.home-trio__title {
  font: 700 30px var(--font-display); letter-spacing: -0.015em;
  color: var(--fg-1); margin: 2px 0 4px;
}
.home-trio__desc {
  font-size: 15px; line-height: 1.6; color: var(--fg-2);
  margin: 0 0 8px;
}
.home-trio__list {
  list-style: none; padding: 0; margin: 4px 0 20px;
  display: flex; flex-direction: column; gap: 8px;
  border-top: 1px solid var(--border-1); padding-top: 16px;
}
.home-trio__list li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 14px; color: var(--fg-2); line-height: 1.5;
}
.home-trio__card--orange .home-trio__list svg { color: var(--lr-orange); }
.home-trio__card--sky    .home-trio__list svg { color: var(--lr-sky); }
.home-trio__card--navy   .home-trio__list svg { color: var(--lr-navy); }
.home-trio__list svg { flex-shrink: 0; margin-top: 3px; }
.home-trio__link {
  margin-top: auto;
  font: 600 14px var(--font-display);
  color: var(--fg-1); letter-spacing: 0.01em;
  transition: color var(--duration-fast), transform var(--duration-fast);
  display: inline-block;
}
.home-trio__card--orange .home-trio__link { color: var(--lr-orange); }
.home-trio__card--sky    .home-trio__link { color: var(--lr-sky-800); }
.home-trio__card--navy   .home-trio__link { color: var(--lr-navy); }
.home-trio__card:hover .home-trio__link { transform: translateX(4px); }

/* ----- Trust strip ----- */
.home-trust {
  background: var(--lr-navy);
  color: #fff;
  padding: 44px 0;
  position: relative;
  overflow: hidden;
}
.home-trust::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(600px 200px at 20% 0%, rgba(43,183,232,0.25), transparent 70%),
    radial-gradient(500px 180px at 90% 100%, rgba(245,138,31,0.18), transparent 70%);
}
.home-trust__inner {
  position: relative;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
  align-items: center;
}
.home-trust__item {
  display: flex; flex-direction: column; gap: 6px;
  padding: 0 8px;
  border-left: 1px solid rgba(255,255,255,0.14);
  padding-left: 24px;
}
.home-trust__item:first-child { border-left: none; padding-left: 8px; }
.home-trust__k {
  font: 800 44px var(--font-display);
  letter-spacing: -0.025em;
  color: #fff;
  line-height: 1;
}
.home-trust__item:nth-child(2) .home-trust__k { color: var(--lr-orange); }
.home-trust__item:nth-child(3) .home-trust__k { color: var(--lr-sky); }
.home-trust__l {
  font: 500 13px/1.4 var(--font-body);
  color: rgba(255,255,255,0.72);
  white-space: pre-line;
}

/* ----- Contact CTA ----- */
.home-cta {
  position: relative;
  background:
    linear-gradient(180deg, var(--bg-sunken) 0%, #fff 100%);
  padding: 96px 0 80px;
  overflow: hidden;
}
.home-cta__bg {
  position: absolute; inset: 0; z-index: 0;
  pointer-events: none;
}
.home-cta__bg svg { width: 100%; height: 100%; }
.home-cta__inner {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1.15fr 1fr; gap: 56px;
  align-items: center;
}
.home-cta__title {
  font: 800 clamp(32px, 3.4vw, 48px)/1.1 var(--font-display);
  letter-spacing: -0.02em;
  color: var(--fg-1);
  margin: 10px 0 16px;
}
.home-cta__lede {
  font-size: 17px; line-height: 1.6; color: var(--fg-2);
  max-width: 48ch; margin: 0 0 28px;
}
.home-cta__actions { display: flex; gap: 12px; flex-wrap: wrap; }
.home-cta__ghost {
  background: #fff; color: var(--lr-navy);
  border: 1px solid var(--border-2);
}
.home-cta__ghost:hover { border-color: var(--lr-navy); transform: translateY(-1px); }

.home-cta__card {
  background: #fff;
  border: 1px solid var(--border-1);
  border-radius: var(--radius-lg);
  padding: 32px;
  box-shadow: var(--shadow-md);
  display: flex; flex-direction: column; gap: 20px;
}
.home-cta__card h3 {
  font: 700 20px var(--font-display);
  color: var(--fg-1);
  margin: 0;
  letter-spacing: -0.005em;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border-1);
}
.home-cta__dl {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px 16px;
  margin: 0;
}
.home-cta__dl > div { display: flex; flex-direction: column; gap: 4px; }
.home-cta__dl dt {
  font: 700 11px var(--font-display);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--fg-3);
}
.home-cta__dl dd {
  margin: 0;
  font: 500 14px/1.5 var(--font-body);
  color: var(--fg-1);
}
.home-cta__map {
  margin-top: 4px;
  border-radius: var(--radius-md);
  overflow: hidden;
  height: 140px;
  border: 1px solid var(--border-1);
}
.home-cta__map svg { display: block; width: 100%; height: 100%; }

/* ----- Logo sizing override ----- */
.lr-header__logo img { height: 52px; }

/* ----- WhatsApp green button variant (uses palette --success) ----- */
.lr-btn--whatsapp {
  background: var(--success);
  color: #fff;
  box-shadow: 0 6px 16px rgba(30, 158, 95, 0.28);
}
.lr-btn--whatsapp:hover {
  background: #178450; /* darker success for hover */
  transform: translateY(-1px);
}

/* ----- Search sits on top of hero nicely ----- */
.home-search-wrap {
  position: relative; z-index: 3;
  max-width: 1200px; margin: 0 auto; padding: 0 32px;
}

/* ===== Botón WhatsApp flotante ===== */
.wa-float {
  position: fixed; right: 20px; bottom: 20px; z-index: 99;
  width: 60px; height: 60px; border-radius: 50%;
  background: var(--success);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 24px rgba(30,158,95,0.4);
  transition: transform var(--duration-fast);
}
.wa-float:hover { transform: scale(1.08); }

/* ===== Placeholder para imágenes faltantes ===== */
.lr-prop__thumb {
  background-color: var(--lr-gray-300);
  background-size: cover;
}
.lr-prop__thumb::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.3) 100%);
  pointer-events: none;
}

/* ===== Listado: filtros ===== */
.lr-filtros-bloque { padding: 32px 0 16px; background: #fff; border-bottom: 1px solid var(--border-1); }

/* Filtros en 3 columnas */
.lr-filtros-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  align-items: start;
}
.lr-filtros-grupo h3 {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--fg-2);
  margin-bottom: 10px;
}
@media (max-width: 640px) {
  .lr-filtros-grid { grid-template-columns: 1fr; gap: 16px; }
}
.lr-filtros-bloque h3 { font: 700 12px var(--font-display); letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-3); margin: 16px 0 10px; }
.lr-filtros-bloque h3:first-child { margin-top: 0; }

/* ===== RESPONSIVE ===== */
@media (max-width: 980px) {
  .lr-container { padding: 0 20px; }
  .lr-header__inner { gap: 12px; height: 64px; }
  .lr-header__nav { display: none; }
  .lr-header__logo img { height: 36px; }
  .lr-hero__content { padding: 64px 20px 80px; }
  .lr-hero__title { font-size: clamp(32px, 7vw, 44px); }
  .lr-search { grid-template-columns: 1fr; gap: 4px; padding: 8px; margin-top: -28px; }
  .lr-search__field { border-right: none; border-bottom: 1px solid var(--border-1); }
  .lr-search__field:last-of-type { border-bottom: none; }
  .lr-search__go { padding: 14px; }
  .lr-section { padding: 56px 0; }
  .lr-props { grid-template-columns: 1fr; gap: 16px; }
  .home-trio { grid-template-columns: 1fr; }
  .home-trust__inner { grid-template-columns: repeat(2, 1fr); gap: 24px 16px; }
  .home-trust__item { border-left: none !important; padding-left: 8px !important; }
  .home-cta__inner { grid-template-columns: 1fr; gap: 32px; }
  .home-cta { padding: 64px 0; }
  .lr-detail { grid-template-columns: 1fr; gap: 24px; }
  .lr-detail__main { height: 280px; }
  .lr-detail__aside { position: static; }
  .lr-footer__grid { grid-template-columns: 1fr; gap: 32px; }
  .lr-footer__bottom { flex-direction: column; gap: 16px; text-align: center; }
}

@media (min-width: 600px) and (max-width: 980px) {
  .lr-props { grid-template-columns: repeat(2, 1fr); }
}
