/* ==========================================================================
   Find Your Land — Premium Design System (v3)
   Layered over the legacy stylesheet + Bootstrap 4. Mobile-first.
   Edit tokens in :root; components below consume them.
   ========================================================================== */

/* --------------------------------------------------------------------------
   PHASE 2 TOKEN BRIDGE
   The component variables below now MAP onto the navy/gold semantic tokens
   defined in fyl-tokens.css (loaded first). This re-skins every component to
   the CBRE/JLL-style system without rewriting individual rules.
   Edit brand values in fyl-tokens.css, not here.
   -------------------------------------------------------------------------- */
:root {
  /* Brand ink → navy; accent → refined gold */
  --fyl-ink: var(--navy-950, #06101F);
  --fyl-brand-900: var(--navy-900, #0A1A2F);
  --fyl-brand-700: var(--navy-700, #143356);
  --fyl-brand: var(--navy-800, #0E2540);
  --fyl-brand-600: var(--navy-600, #1E4B7A);
  --fyl-brand-soft: var(--navy-050, #F3F6FA);
  --fyl-accent: var(--gold-500, #C2A14D);
  --fyl-accent-600: var(--gold-600, #A8883A);
  --fyl-accent-soft: var(--gold-050, #FBF6E9);
  --fyl-whatsapp: #25d366;

  /* Neutrals → charcoal/gray + clean white surfaces */
  --fyl-text: var(--color-text, #0E1726);
  --fyl-body: var(--color-body, #3D4757);
  --fyl-muted: var(--color-muted, #6B7686);
  --fyl-line: var(--color-border, #E3E7ED);
  --fyl-line-strong: var(--color-border-strong, #CDD4DE);
  --fyl-surface: var(--color-surface, #ffffff);
  --fyl-bg: var(--color-bg, #ffffff);
  --fyl-bg-alt: var(--color-surface-2, #F7F8FA);

  /* Type → Inter one-face system */
  --fyl-font-display: var(--font-display, "Inter", system-ui, sans-serif);
  --fyl-font-body: var(--font-body, "Inter", system-ui, sans-serif);

  /* Radius / shadow / spacing → new scale */
  --fyl-r-sm: var(--radius-md, 10px);
  --fyl-r: var(--radius-lg, 14px);
  --fyl-r-lg: var(--radius-xl, 20px);
  --fyl-r-pill: var(--radius-pill, 999px);
  --fyl-shadow-sm: var(--shadow-sm, 0 2px 8px rgba(10,26,47,.07));
  --fyl-shadow: var(--shadow-md, 0 8px 24px rgba(10,26,47,.10));
  --fyl-shadow-lg: var(--shadow-lg, 0 18px 44px rgba(10,26,47,.14));
  --fyl-container: var(--container, 1240px);
  --fyl-ease: var(--ease-standard, cubic-bezier(.4, 0, .2, 1));
}

/* --------------------------------------------------------------------------
   Base typography (scoped-safe global upgrades)
   -------------------------------------------------------------------------- */
body {
  font-family: var(--fyl-font-body);
  color: var(--fyl-body);
  background: var(--fyl-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-size: 16px;
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6,
.fyl-display {
  font-family: var(--fyl-font-display);
  color: var(--fyl-text);
  font-weight: 700;
  letter-spacing: -.01em;
  line-height: 1.15;
}

a { color: var(--fyl-brand); transition: color .2s var(--fyl-ease); }
a:hover { color: var(--fyl-brand-900); text-decoration: none; }

img { max-width: 100%; height: auto; }

.fyl-container {
  max-width: var(--fyl-container);
  margin-inline: auto;
  padding-inline: 20px;
}

/* Section rhythm */
.fyl-section { padding: 56px 0; }
.fyl-section--tight { padding: 36px 0; }
.fyl-section--alt { background: var(--fyl-bg-alt); }
@media (min-width: 768px) { .fyl-section { padding: 80px 0; } }

.fyl-eyebrow {
  font: 600 13px/1 var(--fyl-font-body);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fyl-brand);
  display: inline-block;
  margin-bottom: 12px;
}
.fyl-section-title { font-size: clamp(24px, 3.2vw, 36px); margin: 0 0 10px; }
.fyl-section-sub { color: var(--fyl-muted); font-size: 16px; max-width: 60ch; margin: 0 auto; }
.fyl-section-head { margin-bottom: 36px; }
.fyl-section-head--center { text-align: center; }
.fyl-flex-between { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.fyl-flex-between .fyl-section-sub { margin-left: 0; }

/* --------------------------------------------------------------------------
   Buttons
   -------------------------------------------------------------------------- */
.fyl-btn {
  --bg: var(--fyl-brand);
  --fg: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  font: 600 15px/1 var(--fyl-font-body);
  padding: 13px 22px;
  border-radius: var(--fyl-r-pill);
  border: 1px solid transparent;
  background: var(--bg);
  color: var(--fg);
  cursor: pointer;
  transition: transform .15s var(--fyl-ease), box-shadow .2s var(--fyl-ease), background .2s var(--fyl-ease);
  text-decoration: none;
  white-space: nowrap;
}
.fyl-btn:hover { color: var(--fg); transform: translateY(-1px); box-shadow: var(--fyl-shadow); }
.fyl-btn:active { transform: translateY(0); }
.fyl-btn--accent { --bg: var(--fyl-accent); --fg: #2a2300; }
.fyl-btn--dark { --bg: var(--fyl-brand-900); }
.fyl-btn--ghost { --bg: transparent; --fg: var(--fyl-brand); border-color: var(--fyl-line-strong); }
.fyl-btn--ghost:hover { background: var(--fyl-brand-soft); }
.fyl-btn--white { --bg: #fff; --fg: var(--fyl-brand-900); }
.fyl-btn--wa { --bg: var(--fyl-whatsapp); --fg: #053b1e; }
.fyl-btn--lg { padding: 16px 28px; font-size: 16px; }
.fyl-btn--sm { padding: 8px 14px; font-size: 13px; }
.fyl-btn--block { width: 100%; }

/* --------------------------------------------------------------------------
   Badges / pills
   -------------------------------------------------------------------------- */
.fyl-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font: 600 12px/1 var(--fyl-font-body);
  padding: 6px 11px; border-radius: var(--fyl-r-pill);
  background: var(--fyl-brand-soft); color: var(--fyl-brand-700);
}
.fyl-badge--accent { background: var(--fyl-accent-soft); color: #7c6310; }
.fyl-badge--verified { background: #E7ECF3; color: var(--fyl-brand-700); }
.fyl-badge--featured { background: var(--fyl-accent); color: #2a2300; }
.fyl-badge--zero { background: rgba(255,255,255,.92); color: var(--fyl-brand-700); box-shadow: var(--fyl-shadow-sm); }
.fyl-badge i { font-size: 11px; }

/* The single most important value prop — reusable everywhere */
.fyl-zero-commission {
  display: inline-flex; align-items: center; gap: 8px;
  font: 700 13px/1 var(--fyl-font-display);
  padding: 9px 14px; border-radius: var(--fyl-r-pill);
  background: linear-gradient(120deg, var(--fyl-accent-soft), #fff);
  color: #6f5800; border: 1px solid #ecdca0;
}
.fyl-zero-commission i { color: var(--fyl-accent); }

/* --------------------------------------------------------------------------
   Cards
   -------------------------------------------------------------------------- */
.fyl-card {
  background: var(--fyl-surface);
  border: 1px solid var(--fyl-line);
  border-radius: var(--fyl-r);
  box-shadow: var(--fyl-shadow-sm);
  overflow: hidden;
  transition: transform .2s var(--fyl-ease), box-shadow .25s var(--fyl-ease), border-color .2s var(--fyl-ease);
  height: 100%;
  display: flex; flex-direction: column;
}
.fyl-card:hover { transform: translateY(-4px); box-shadow: var(--fyl-shadow-lg); border-color: var(--fyl-line-strong); }

.fyl-card__media { position: relative; aspect-ratio: 4 / 3; background: var(--fyl-bg-alt); overflow: hidden; }
.fyl-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--fyl-ease); }
.fyl-card:hover .fyl-card__media img { transform: scale(1.05); }
.fyl-card__badges { position: absolute; top: 12px; left: 12px; display: flex; gap: 6px; flex-wrap: wrap; }
.fyl-card__fav {
  position: absolute; top: 12px; right: 12px; width: 38px; height: 38px;
  border-radius: 50%; background: rgba(255,255,255,.92); border: 0;
  display: grid; place-items: center; color: var(--fyl-brand-900); cursor: pointer;
  box-shadow: var(--fyl-shadow-sm);
}
.fyl-card__fav:hover { background: #fff; color: #d23b48; }
.fyl-card__body { padding: 16px 16px 18px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.fyl-card__price { font: 800 20px/1.1 var(--fyl-font-display); color: var(--fyl-text); }
.fyl-card__price small { font-size: 13px; font-weight: 600; color: var(--fyl-muted); }
.fyl-card__title { font: 600 16px/1.35 var(--fyl-font-display); margin: 0; }
.fyl-card__title a { color: var(--fyl-text); }
.fyl-card__title a:hover { color: var(--fyl-brand); }
.fyl-card__loc { color: var(--fyl-muted); font-size: 13.5px; display: flex; align-items: center; gap: 6px; }
.fyl-card__meta {
  display: flex; gap: 14px; flex-wrap: wrap;
  margin-top: auto; padding-top: 12px; border-top: 1px solid var(--fyl-line);
  color: var(--fyl-body); font-size: 13px;
}
.fyl-card__meta span { display: inline-flex; align-items: center; gap: 6px; }
.fyl-card__meta i { color: var(--fyl-brand); }
.fyl-card__builder { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--fyl-muted); }
.fyl-card__builder b { color: var(--fyl-brand-700); font-weight: 600; }
.fyl-card__builder i { color: var(--fyl-brand); }
.fyl-card__foot {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  margin-top: auto; padding-top: 12px; border-top: 1px solid var(--fyl-line);
}
.fyl-card__foot .fyl-btn { white-space: nowrap; }

/* --------------------------------------------------------------------------
   Hero + search
   -------------------------------------------------------------------------- */
.fyl-hero {
  position: relative;
  color: #fff;
  background: linear-gradient(180deg, rgba(10,26,47,.62), rgba(10,26,47,.78)),
              var(--fyl-hero-img, linear-gradient(120deg, #0A1A2F, #143356)) center/cover no-repeat;
  padding: 64px 0 120px;
}
@media (min-width: 768px) { .fyl-hero { padding: 96px 0 150px; } }
.fyl-hero__inner { max-width: 760px; }
.fyl-hero h1 {
  color: #fff; font-size: clamp(30px, 5vw, 52px); line-height: 1.08; margin: 16px 0 14px;
}
.fyl-hero p { color: rgba(255,255,255,.9); font-size: clamp(16px, 2vw, 19px); max-width: 56ch; }
.fyl-hero .fyl-zero-commission { background: rgba(255,255,255,.14); color: #fff; border-color: rgba(255,255,255,.3); }
.fyl-hero .fyl-zero-commission i { color: var(--fyl-accent); }
.fyl-hero__stats { display: flex; gap: 30px; flex-wrap: wrap; margin-top: 26px; }
.fyl-hero__stat b { display: block; font: 800 26px/1 var(--fyl-font-display); color: #fff; }
.fyl-hero__stat span { font-size: 13px; color: rgba(255,255,255,.8); }

/* Search box: overlaps hero bottom */
.fyl-searchbar {
  background: #fff; border-radius: var(--fyl-r-lg); box-shadow: var(--fyl-shadow-lg);
  padding: 14px; margin-top: 28px; position: relative; z-index: 3;
}
.fyl-search-section { margin-top: -84px; position: relative; z-index: 3; }
.fyl-search-tabs { display: flex; gap: 6px; margin-bottom: 12px; }
.fyl-search-tab {
  border: 0; background: transparent; padding: 8px 16px; border-radius: var(--fyl-r-pill);
  font: 600 14px/1 var(--fyl-font-body); color: var(--fyl-muted); cursor: pointer;
}
.fyl-search-tab.is-active { background: var(--fyl-brand); color: #fff; }
.fyl-search-row { display: grid; gap: 10px; grid-template-columns: 1fr; }
@media (min-width: 880px) { .fyl-search-row { grid-template-columns: 2fr 1.2fr 1.4fr auto; align-items: center; } }
.fyl-field { display: flex; flex-direction: column; gap: 4px; padding: 6px 12px; }
.fyl-field + .fyl-field { border-left: 1px solid var(--fyl-line); }
@media (max-width: 879px) { .fyl-field + .fyl-field { border-left: 0; border-top: 1px solid var(--fyl-line); } }
.fyl-field label { font: 600 11px/1 var(--fyl-font-body); letter-spacing: .08em; text-transform: uppercase; color: var(--fyl-muted); }
.fyl-field select, .fyl-field input {
  border: 0; padding: 4px 0; font: 500 15px/1.2 var(--fyl-font-body); color: var(--fyl-text);
  background: transparent; outline: none; width: 100%;
}

/* --------------------------------------------------------------------------
   Trust strip
   -------------------------------------------------------------------------- */
.fyl-trust { background: #fff; border-top: 1px solid var(--fyl-line); border-bottom: 1px solid var(--fyl-line); }
.fyl-trust__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; padding: 26px 0; }
@media (min-width: 768px) { .fyl-trust__grid { grid-template-columns: repeat(4, 1fr); } }
.fyl-trust__item { display: flex; align-items: center; gap: 12px; }
.fyl-trust__icon { width: 44px; height: 44px; border-radius: 12px; background: var(--fyl-brand-soft); color: var(--fyl-brand); display: grid; place-items: center; font-size: 19px; flex: none; }
.fyl-trust__item b { display: block; font: 700 16px/1.2 var(--fyl-font-display); color: var(--fyl-text); }
.fyl-trust__item span { font-size: 13px; color: var(--fyl-muted); }

/* Builder/brand logo row */
.fyl-brands { display: flex; flex-wrap: wrap; gap: 14px 28px; align-items: center; justify-content: center; }
.fyl-brands__logo {
  height: 56px; min-width: 120px; padding: 10px 18px; display: grid; place-items: center;
  background: #fff; border: 1px solid var(--fyl-line); border-radius: var(--fyl-r);
  filter: grayscale(1); opacity: .8; transition: all .25s var(--fyl-ease);
  font: 700 15px/1 var(--fyl-font-display); color: var(--fyl-brand-700);
}
.fyl-brands__logo:hover { filter: none; opacity: 1; box-shadow: var(--fyl-shadow-sm); }

/* --------------------------------------------------------------------------
   City / category tiles
   -------------------------------------------------------------------------- */
.fyl-tiles { display: grid; gap: 16px; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 768px) { .fyl-tiles { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 992px) { .fyl-tiles--5 { grid-template-columns: repeat(5, 1fr); } }
.fyl-tile { position: relative; border-radius: var(--fyl-r); overflow: hidden; aspect-ratio: 3/4; display: block; box-shadow: var(--fyl-shadow-sm); }
.fyl-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--fyl-ease); }
.fyl-tile:hover img { transform: scale(1.06); }
.fyl-tile__label { position: absolute; inset: auto 0 0 0; padding: 16px; background: linear-gradient(0deg, rgba(10,26,47,.85), transparent); color: #fff; }
.fyl-tile__label b { display: block; font: 700 17px/1.2 var(--fyl-font-display); color: #fff; }
.fyl-tile__label span { font-size: 12.5px; color: rgba(255,255,255,.85); }

.fyl-cats { display: grid; gap: 14px; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 576px) { .fyl-cats { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 992px) { .fyl-cats { grid-template-columns: repeat(6, 1fr); } }
.fyl-cat { background: #fff; border: 1px solid var(--fyl-line); border-radius: var(--fyl-r); padding: 22px 14px; text-align: center; transition: all .2s var(--fyl-ease); }
.fyl-cat:hover { border-color: var(--fyl-brand); box-shadow: var(--fyl-shadow); transform: translateY(-3px); }
.fyl-cat__icon { width: 52px; height: 52px; margin: 0 auto 10px; border-radius: 14px; background: var(--fyl-brand-soft); color: var(--fyl-brand); display: grid; place-items: center; font-size: 22px; }
.fyl-cat b { display: block; font: 600 14.5px/1.2 var(--fyl-font-display); color: var(--fyl-text); }
.fyl-cat span { font-size: 12px; color: var(--fyl-muted); }

/* --------------------------------------------------------------------------
   Process steps + testimonials + why-us
   -------------------------------------------------------------------------- */
.fyl-steps { display: grid; gap: 22px; grid-template-columns: 1fr; counter-reset: step; }
@media (min-width: 768px) { .fyl-steps { grid-template-columns: repeat(4, 1fr); } }
.fyl-step { position: relative; padding-top: 8px; }
.fyl-step__n { width: 44px; height: 44px; border-radius: 12px; background: var(--fyl-brand); color: #fff; font: 800 18px/44px var(--fyl-font-display); text-align: center; margin-bottom: 14px; }
.fyl-step b { display: block; font: 700 17px/1.3 var(--fyl-font-display); color: var(--fyl-text); margin-bottom: 6px; }
.fyl-step p { font-size: 14px; color: var(--fyl-muted); margin: 0; }

.fyl-quote { background: #fff; border: 1px solid var(--fyl-line); border-radius: var(--fyl-r); padding: 24px; box-shadow: var(--fyl-shadow-sm); height: 100%; }
.fyl-quote__stars { color: var(--fyl-accent); margin-bottom: 12px; }
.fyl-quote p { color: var(--fyl-text); font-size: 15.5px; line-height: 1.6; }
.fyl-quote__who { display: flex; align-items: center; gap: 12px; margin-top: 16px; }
.fyl-quote__who img, .fyl-quote__avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; background: var(--fyl-brand-soft); display: grid; place-items: center; color: var(--fyl-brand); font-weight: 700; }
.fyl-quote__who b { display: block; font-size: 14.5px; color: var(--fyl-text); }
.fyl-quote__who span { font-size: 12.5px; color: var(--fyl-muted); }

/* --------------------------------------------------------------------------
   Sticky conversion CTA bar + floating contact
   -------------------------------------------------------------------------- */
.fyl-sticky-cta {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 1040;
  background: var(--fyl-brand-900); color: #fff;
  display: flex; align-items: center; gap: 12px; justify-content: space-between;
  padding: 10px 16px; box-shadow: 0 -6px 24px rgba(10,26,47,.25);
  transform: translateY(110%); transition: transform .35s var(--fyl-ease);
}
.fyl-sticky-cta.is-visible { transform: translateY(0); }
.fyl-sticky-cta__text { font: 600 14px/1.3 var(--fyl-font-display); }
.fyl-sticky-cta__text small { display: block; font-weight: 500; font-size: 12px; color: var(--fyl-accent); }
.fyl-sticky-cta__actions { display: flex; gap: 8px; }
@media (min-width: 768px) { .fyl-sticky-cta { display: none; } } /* mobile-first: bar only on small screens */

.fyl-fab { position: fixed; right: 18px; bottom: 18px; z-index: 1035; display: flex; flex-direction: column; gap: 12px; }
@media (max-width: 767px) { .fyl-fab { bottom: 74px; } } /* clear the sticky bar */
.fyl-fab a {
  width: 54px; height: 54px; border-radius: 50%; display: grid; place-items: center;
  color: #fff; font-size: 24px; box-shadow: var(--fyl-shadow-lg); transition: transform .15s var(--fyl-ease);
}
.fyl-fab a:hover { transform: scale(1.08); color: #fff; }
.fyl-fab__wa { background: var(--fyl-whatsapp); }
.fyl-fab__call { background: var(--fyl-brand); }

/* --------------------------------------------------------------------------
   Forms (incl. multi-step enquiry)
   -------------------------------------------------------------------------- */
.fyl-form .fyl-input, .fyl-form select, .fyl-form textarea {
  width: 100%; border: 1px solid var(--fyl-line-strong); border-radius: var(--fyl-r-sm);
  padding: 12px 14px; font: 500 15px/1.3 var(--fyl-font-body); color: var(--fyl-text);
  background: #fff; transition: border-color .2s var(--fyl-ease), box-shadow .2s var(--fyl-ease);
}
.fyl-form .fyl-input:focus, .fyl-form select:focus, .fyl-form textarea:focus {
  outline: 0; border-color: var(--fyl-brand); box-shadow: 0 0 0 3px var(--fyl-brand-soft);
}
.fyl-form label { font: 600 13px/1 var(--fyl-font-body); color: var(--fyl-text); margin-bottom: 6px; display: block; }
.fyl-form .fyl-group { margin-bottom: 14px; }

.fyl-lead-card { background: #fff; border: 1px solid var(--fyl-line); border-radius: var(--fyl-r); box-shadow: var(--fyl-shadow); padding: 22px; }
.fyl-lead-card__head { font: 700 19px/1.2 var(--fyl-font-display); color: var(--fyl-text); margin-bottom: 4px; }
.fyl-lead-card__sub { font-size: 13.5px; color: var(--fyl-muted); margin-bottom: 16px; }

.fyl-steps-nav { display: flex; gap: 6px; margin-bottom: 18px; }
.fyl-steps-nav span { flex: 1; height: 4px; border-radius: 4px; background: var(--fyl-line); }
.fyl-steps-nav span.is-done { background: var(--fyl-brand); }
.fyl-step-pane { display: none; }
.fyl-step-pane.is-active { display: block; animation: fyl-fade .25s var(--fyl-ease); }
@keyframes fyl-fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.fyl-choice-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.fyl-choice {
  border: 1px solid var(--fyl-line-strong); border-radius: var(--fyl-r-sm); padding: 12px;
  text-align: center; cursor: pointer; font: 600 14px/1.2 var(--fyl-font-body); color: var(--fyl-body);
  background: #fff; transition: all .15s var(--fyl-ease);
}
.fyl-choice:hover { border-color: var(--fyl-brand); }
.fyl-choice.is-selected { border-color: var(--fyl-brand); background: var(--fyl-brand-soft); color: var(--fyl-brand-700); }

/* --------------------------------------------------------------------------
   Detail page bits
   -------------------------------------------------------------------------- */
.fyl-gallery { display: grid; gap: 8px; grid-template-columns: 1fr; border-radius: var(--fyl-r); overflow: hidden; }
@media (min-width: 768px) { .fyl-gallery { grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 1fr 1fr; }
  .fyl-gallery > :first-child { grid-row: 1 / span 2; } }
.fyl-gallery img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/3; }
.fyl-facts { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
@media (min-width: 576px) { .fyl-facts { grid-template-columns: repeat(4, 1fr); } }
.fyl-fact { background: var(--fyl-bg); border: 1px solid var(--fyl-line); border-radius: var(--fyl-r-sm); padding: 14px; }
.fyl-fact i { color: var(--fyl-brand); font-size: 18px; }
.fyl-fact b { display: block; font: 700 17px/1.2 var(--fyl-font-display); color: var(--fyl-text); margin-top: 6px; }
.fyl-fact span { font-size: 12.5px; color: var(--fyl-muted); }
.fyl-amenities { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
@media (min-width: 768px) { .fyl-amenities { grid-template-columns: repeat(3, 1fr); } }
.fyl-amenity { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--fyl-body); }
.fyl-amenity i { color: var(--fyl-brand); }
.fyl-sticky-aside { position: sticky; top: 90px; }

/* --------------------------------------------------------------------------
   Utilities
   -------------------------------------------------------------------------- */
.fyl-grid { display: grid; gap: 22px; }
.fyl-grid--2 { grid-template-columns: 1fr; }
.fyl-grid--3 { grid-template-columns: 1fr; }
.fyl-grid--4 { grid-template-columns: repeat(2, 1fr); }
@media (min-width: 576px) { .fyl-grid--3 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 768px) { .fyl-grid--2 { grid-template-columns: repeat(2, 1fr); } .fyl-grid--4 { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 992px) { .fyl-grid--3 { grid-template-columns: repeat(3, 1fr); } }
.fyl-mt-0 { margin-top: 0 !important; }
.fyl-text-center { text-align: center; }
.fyl-skeleton { background: linear-gradient(90deg, #eef3f1 25%, #e3eae7 37%, #eef3f1 63%); background-size: 400% 100%; animation: fyl-shimmer 1.4s ease infinite; }
@keyframes fyl-shimmer { 0% { background-position: 100% 0; } 100% { background-position: 0 0; } }

:focus-visible { outline: 3px solid var(--fyl-accent); outline-offset: 2px; border-radius: 4px; }
.fyl-visually-hidden { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }

/* ==========================================================================
   Header / nav / top bar  (v3)
   ========================================================================== */
.fyl-topbar { background: var(--fyl-brand-900); color: rgba(255,255,255,.85); font-size: 13px; }
.fyl-topbar__inner { display: flex; align-items: center; justify-content: space-between; padding: 8px 20px; }
.fyl-topbar__right { display: flex; align-items: center; gap: 20px; }
.fyl-topbar a { color: rgba(255,255,255,.85); display: inline-flex; align-items: center; gap: 6px; }
.fyl-topbar a:hover { color: #fff; }
.fyl-topbar .fyl-zero-commission { background: rgba(255,255,255,.1); color: #fff; border-color: rgba(255,255,255,.18); padding: 5px 12px; }

.fyl-header { position: relative; z-index: 1020; background: #fff; border-bottom: 1px solid var(--fyl-line); }
.fyl-header[data-sticky-header] .fyl-header__bar { position: sticky; top: 0; }
.fyl-header.is-stuck { box-shadow: var(--fyl-shadow); }
.fyl-header__bar { background: #fff; z-index: 1020; }
.fyl-header__inner { display: flex; align-items: center; gap: 18px; min-height: 84px; }
.fyl-header__brand { display: inline-flex; align-items: center; flex: none; margin-right: 8px; }
.fyl-header__brand img { height: 64px; width: auto; display: block; }
@media (max-width: 575px) { .fyl-header__brand img { height: 52px; } }
.fyl-header__wordmark { font: 800 22px/1 var(--fyl-font-display); color: var(--fyl-brand-900); }
.fyl-header__nav { flex: 1; }
.fyl-header__cta { gap: 10px; flex: none; margin-left: auto; }
.fyl-header__toggle { display: inline-flex; margin-left: auto; border: 1px solid var(--fyl-line-strong); background: #fff; border-radius: 10px; width: 44px; height: 44px; font-size: 18px; color: var(--fyl-brand-900); align-items: center; justify-content: center; }

/* Desktop menu */
.fyl-menu { display: flex; flex-direction: row; flex-wrap: wrap; align-items: center; gap: 4px; list-style: none; margin: 0; padding: 0; }
.fyl-menu li { position: relative; }
.fyl-menu a { display: block; padding: 10px 14px; font: 600 15px/1 var(--fyl-font-body); color: var(--fyl-text); border-radius: var(--fyl-r-pill); }
.fyl-menu a:hover, .fyl-menu .active > a { color: var(--fyl-brand); background: var(--fyl-brand-soft); }
.fyl-menu .dropdown-menu, .fyl-menu ul.sub-menu { position: absolute; top: 100%; left: 0; min-width: 210px; background: #fff; border: 1px solid var(--fyl-line); border-radius: var(--fyl-r); box-shadow: var(--fyl-shadow-lg); padding: 8px; list-style: none; margin: 6px 0 0; opacity: 0; visibility: hidden; transform: translateY(6px); transition: all .18s var(--fyl-ease); z-index: 30; }
.fyl-menu li:hover > .dropdown-menu, .fyl-menu li:hover > ul.sub-menu { opacity: 1; visibility: visible; transform: none; }

@media (min-width: 992px) {
  .fyl-header__toggle { display: none !important; }
  .fyl-header__nav { display: flex !important; align-items: center; justify-content: center; position: static; width: auto; transform: none; box-shadow: none; background: transparent; overflow: visible; }
  .main-menu-content { display: flex; flex: 1; justify-content: center; }
  .main-menu-nav { display: flex; align-items: center; width: 100%; justify-content: center; }
  .fyl-menu { flex-direction: row !important; }
  .fyl-menu a { white-space: nowrap; }
}

/* Mobile off-canvas (keeps legacy toggle classes working even without JS) */
.fyl-header__nav-mobilehead { display: flex; align-items: center; justify-content: space-between; padding: 16px; border-bottom: 1px solid var(--fyl-line); font: 700 16px/1 var(--fyl-font-display); }
.fyl-header__nav-mobilehead button { border: 0; background: transparent; font-size: 22px; color: var(--fyl-muted); }
.fyl-header__mobile-extra { display: flex; flex-direction: column; gap: 4px; padding: 12px 16px; border-top: 1px solid var(--fyl-line); }
.fyl-header__mobile-extra a { padding: 10px 0; color: var(--fyl-text); display: flex; align-items: center; gap: 10px; }
@media (max-width: 991px) {
  .fyl-header__nav { position: fixed; inset: 0 0 0 auto; width: min(86vw, 340px); background: #fff; z-index: 1060; transform: translateX(100%); transition: transform .3s var(--fyl-ease); overflow-y: auto; box-shadow: var(--fyl-shadow-lg); }
  .fyl-header__nav.show, .fyl-header__nav.in { transform: translateX(0); }
  .fyl-menu { flex-direction: column; align-items: stretch; gap: 0; padding: 8px; }
  .fyl-menu a { padding: 13px 12px; border-radius: var(--fyl-r-sm); }
  .fyl-menu .dropdown-menu, .fyl-menu ul.sub-menu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border: 0; padding-left: 12px; }
  .main-menu-darken { position: fixed; inset: 0; background: rgba(10,26,47,.45); z-index: 1050; opacity: 0; visibility: hidden; transition: opacity .3s; }
  .fyl-header__nav.show ~ .main-menu-darken, .navbar-collapse.show .main-menu-darken { opacity: 1; visibility: visible; }
}

/* ==========================================================================
   Search bar — restyle legacy form classes (JS hooks preserved)
   ========================================================================== */
.fyl-searchbar .input-group { display: grid; gap: 10px; grid-template-columns: 1fr; }
@media (min-width: 880px) { .fyl-searchbar .input-group { grid-template-columns: 1.6fr 1.4fr auto auto; align-items: stretch; } }
.fyl-searchbar .keyword-input, .fyl-searchbar .location-input { position: relative; }
.fyl-searchbar .form-control { border: 0; padding: 4px 0; font: 500 15px/1.3 var(--fyl-font-body); background: transparent; box-shadow: none; height: auto; }
.fyl-searchbar .form-control:focus { box-shadow: none; outline: 0; }
.fyl-searchbar .search-button-wrapper { display: flex; align-items: center; }
.fyl-searchbar .search-button-wrapper .fyl-btn { width: 100%; }
.fyl-searchbar .fyl-field--advanced { justify-content: center; }
.fyl-searchbar .advanced-search-toggler { font: 600 14px/1 var(--fyl-font-body); color: var(--fyl-brand); display: inline-flex; align-items: center; gap: 6px; padding-top: 6px; }
.fyl-searchbar .spinner-icon { position: absolute; right: 0; top: 50%; transform: translateY(-50%); color: var(--fyl-muted); display: none; }
.fyl-searchbar .suggestion, .listsuggest { position: absolute; left: 0; right: 0; top: 100%; background: #fff; border: 1px solid var(--fyl-line); border-radius: var(--fyl-r-sm); box-shadow: var(--fyl-shadow-lg); margin-top: 8px; z-index: 40; max-height: 320px; overflow: auto; }
.fyl-searchbar .suggestion:empty, .listsuggest:empty { display: none; }
.advanced-search { position: relative; grid-column: 1 / -1; }
.advanced-search-content { display: none; background: #fff; border-top: 1px solid var(--fyl-line); margin-top: 12px; padding-top: 14px; }
.advanced-search-content.show, .advanced-search.open .property-advanced-search { display: block; }

/* ==========================================================================
   Footer (v3)
   ========================================================================== */
.fyl-footer { background: var(--fyl-brand-900); color: rgba(255,255,255,.75); }
.fyl-footer__cta { background: linear-gradient(120deg, var(--fyl-brand-700), var(--fyl-brand)); padding: 40px 0; }
.fyl-footer__cta-inner { display: flex; flex-wrap: wrap; gap: 20px; align-items: center; justify-content: space-between; }
.fyl-footer__cta h3 { color: #fff; font-size: clamp(22px, 3vw, 30px); margin: 0 0 6px; }
.fyl-footer__cta p { color: rgba(255,255,255,.85); margin: 0; }
.fyl-footer__cta .fyl-btn { flex: none; }
.fyl-footer__main { display: grid; gap: 32px; grid-template-columns: 1fr; padding: 52px 0 36px; }
@media (min-width: 768px) { .fyl-footer__main { grid-template-columns: 1.6fr 1fr 1fr 1fr; } }
.fyl-footer h4 { color: #fff; font-size: 15px; letter-spacing: .04em; text-transform: uppercase; margin: 0 0 18px; }
.fyl-footer a { color: rgba(255,255,255,.75); }
.fyl-footer a:hover { color: #fff; }
.fyl-footer ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; font-size: 14.5px; }
.fyl-footer__brand img { height: 46px; margin-bottom: 16px; }
.fyl-footer__brand p { font-size: 14.5px; line-height: 1.7; max-width: 38ch; }
.fyl-footer__social { display: flex; gap: 10px; margin-top: 18px; }
.fyl-footer__social a { width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,.1); display: grid; place-items: center; color: #fff; }
.fyl-footer__social a:hover { background: var(--fyl-accent); color: #2a2300; }
.fyl-footer__bottom { border-top: 1px solid rgba(255,255,255,.12); padding: 18px 0; font-size: 13px; display: flex; flex-wrap: wrap; gap: 10px; justify-content: space-between; }

/* --------------------------------------------------------------------------
   Homepage section components (city tiles, type cats, features, steps, contact)
   -------------------------------------------------------------------------- */

/* City tiles (replaces legacy city swiper) */
.fyl-citytiles { display: grid; gap: 20px 14px; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 576px) { .fyl-citytiles { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 768px) { .fyl-citytiles { grid-template-columns: repeat(5, 1fr); } }
.fyl-citytile { display: flex; flex-direction: column; align-items: center; gap: 10px; text-align: center; }
.fyl-citytile__img { width: 110px; height: 110px; border-radius: 50%; overflow: hidden; background: var(--fyl-brand-soft); box-shadow: var(--fyl-shadow-sm); border: 3px solid #fff; transition: transform .25s var(--fyl-ease), box-shadow .25s var(--fyl-ease); }
.fyl-citytile:hover .fyl-citytile__img { transform: translateY(-4px); box-shadow: var(--fyl-shadow-lg); }
.fyl-citytile__img img { width: 100%; height: 100%; object-fit: cover; }
.fyl-citytile__name { font: 600 14.5px/1.2 var(--fyl-font-display); color: var(--fyl-text); }
.fyl-citytile:hover .fyl-citytile__name { color: var(--fyl-brand); }

/* Property-type cat label */
.fyl-cat__label { display: block; font: 600 14.5px/1.25 var(--fyl-font-display); color: var(--fyl-text); }
.fyl-cat:hover .fyl-cat__label { color: var(--fyl-brand); }

/* Feature cards ("Everything you need") */
.fyl-feature { background: #fff; border: 1px solid var(--fyl-line); border-radius: var(--fyl-r); padding: 28px; box-shadow: var(--fyl-shadow-sm); transition: transform .2s var(--fyl-ease), box-shadow .25s var(--fyl-ease); height: 100%; }
.fyl-feature:hover { transform: translateY(-4px); box-shadow: var(--fyl-shadow-lg); }
.fyl-feature__icon { width: 56px; height: 56px; border-radius: 16px; background: var(--fyl-brand-soft); color: var(--fyl-brand); display: grid; place-items: center; font-size: 24px; margin-bottom: 16px; }
.fyl-feature h3 { font: 700 18px/1.3 var(--fyl-font-display); color: var(--fyl-text); margin: 0 0 8px; }
.fyl-feature p { font-size: 14.5px; color: var(--fyl-muted); margin: 0; line-height: 1.55; }

/* Step icon + heading (icon variant of .fyl-step) */
.fyl-step__icon { width: 56px; height: 56px; border-radius: 16px; background: linear-gradient(135deg, var(--fyl-brand), var(--fyl-brand-900)); color: #fff; display: grid; place-items: center; font-size: 23px; margin-bottom: 16px; box-shadow: var(--fyl-shadow-sm); }
.fyl-step h3 { font: 700 17px/1.3 var(--fyl-font-display); color: var(--fyl-text); margin: 0 0 6px; }

/* Contact section */
.fyl-contact { align-items: start; }
.fyl-contact__info p { color: var(--fyl-body); font-size: 15px; line-height: 1.6; margin: 10px 0 18px; }
.fyl-contact__list { list-style: none; margin: 0 0 18px; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.fyl-contact__list li { display: flex; align-items: flex-start; gap: 12px; color: var(--fyl-text); font-size: 14.5px; }
.fyl-contact__list i { width: 38px; height: 38px; flex: none; border-radius: 10px; background: var(--fyl-brand-soft); color: var(--fyl-brand); display: grid; place-items: center; font-size: 15px; }
.fyl-contact__list a { color: var(--fyl-text); }
.fyl-contact__list a:hover { color: var(--fyl-brand); }

/* ==========================================================================
   LISTINGS PAGES (properties / projects) — layered over legacy markup
   Scoped to .main-homes / .search-box / .shop__sort so it never leaks into
   the homepage hero search (which uses its own .fyl-* classes).
   ========================================================================== */

/* Breadcrumb hero banner */
.main-homes .bgheadproject {
  position: relative;
  background-size: cover !important;
  background-position: center !important;
  padding: 56px 0;
}
.main-homes .bgheadproject::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,26,47,.62), rgba(10,26,47,.82));
}
.main-homes .bgheadproject .description { position: relative; z-index: 2; }
.main-homes .bgheadproject h1 { color: #fff; font: 800 clamp(26px, 4vw, 40px)/1.15 var(--fyl-font-display); margin: 0 0 10px; }
.main-homes .bgheadproject p { color: rgba(255,255,255,.88); font-size: 16px; margin: 0 auto 14px; max-width: 60ch; }
.main-homes .bgheadproject .breadcrumb {
  background: transparent; justify-content: center; padding: 0; margin: 0; font-size: 13.5px;
}
.main-homes .bgheadproject .breadcrumb-item, .main-homes .bgheadproject .breadcrumb-item a { color: rgba(255,255,255,.85); }
.main-homes .bgheadproject .breadcrumb-item.active { color: #fff; }
.main-homes .bgheadproject .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,.55); }

/* Filter search-box bar */
.search-box-content, .search-box .search-box-items {
  background: #fff;
}
.search-box .search-box-items {
  border: 1px solid var(--fyl-line); border-radius: var(--fyl-r);
  box-shadow: var(--fyl-shadow-sm); padding: 14px 10px;
}
.search-box .control-label {
  font: 600 11px/1 var(--fyl-font-body); letter-spacing: .07em; text-transform: uppercase;
  color: var(--fyl-muted); margin-bottom: 6px; display: block;
}
.search-box .form-control {
  border: 1px solid var(--fyl-line-strong); border-radius: 10px; height: 46px;
  font-size: 14px; color: var(--fyl-text); background: #fff;
}
.search-box .form-control:focus { border-color: var(--fyl-brand); box-shadow: 0 0 0 3px var(--fyl-brand-soft); }
.search-box textarea.form-control { height: auto; }
.search-box .input-has-icon { position: relative; }
.search-box .input-has-icon i { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); color: var(--fyl-muted); pointer-events: none; }
.search-box .input-has-icon .form-control { padding-right: 38px; }
.search-box .btn-secondary.dropdown-toggle {
  width: 100%; text-align: left; background: #fff; color: var(--fyl-text);
  border: 1px solid var(--fyl-line-strong); border-radius: 10px; height: 46px;
  display: flex; align-items: center; justify-content: space-between; font-size: 14px;
}
.search-box .btn-secondary.dropdown-toggle:hover, .search-box .btn-secondary.dropdown-toggle:focus { border-color: var(--fyl-brand); background: #fff; color: var(--fyl-text); }
.search-box .select--arrow { position: relative; }
.search-box .select--arrow > i { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); color: var(--fyl-muted); pointer-events: none; }
.search-box .btn-primary {
  background: var(--fyl-brand); border-color: var(--fyl-brand); border-radius: 10px;
  height: 46px; font-weight: 700; font-family: var(--fyl-font-display);
}
.search-box .btn-primary:hover, .search-box .btn-primary:focus { background: var(--fyl-brand-900); border-color: var(--fyl-brand-900); }
.search-box .dropdown-menu { border: 1px solid var(--fyl-line); border-radius: var(--fyl-r); box-shadow: var(--fyl-shadow-lg); }

/* Sort / per-page bar */
.shop__sort {
  background: #fff !important; border: 1px solid var(--fyl-line);
  border-radius: var(--fyl-r); box-shadow: var(--fyl-shadow-sm); padding: 10px 12px !important;
}
.shop__sort .form-control { border: 1px solid var(--fyl-line-strong); border-radius: 10px; height: 44px; font-size: 14px; }
.shop__sort .form-control:focus { border-color: var(--fyl-brand); box-shadow: 0 0 0 3px var(--fyl-brand-soft); }
.shop__sort .toggle-filter-offcanvas, .toggle-filter-mobile {
  border: 1px solid var(--fyl-line-strong); border-radius: 10px; padding: 9px 14px;
  color: var(--fyl-brand-900); font-weight: 600; display: inline-flex; align-items: center; background: #fff;
}
.shop__sort .change-view i { color: var(--fyl-muted); cursor: pointer; }
.shop__sort .change-view i.active { color: var(--fyl-brand); }

/* Listing grid gutters (legacy helpers used in items partial) */
.main-homes .rowm10 { margin-left: -10px; margin-right: -10px; }
.main-homes .colm10 { padding-left: 10px; padding-right: 10px; margin-bottom: 20px; }

/* Empty-state */
.data-listing .alert-warning {
  background: var(--fyl-accent-soft); border: 1px solid #ecdca0; color: #6f5800;
  border-radius: var(--fyl-r); padding: 18px 20px; font-weight: 600;
}

/* Bootstrap pagination → branded */
.pagination { gap: 6px; }
.pagination .page-link {
  border: 1px solid var(--fyl-line-strong); border-radius: 10px; color: var(--fyl-brand-900);
  min-width: 42px; height: 42px; display: flex; align-items: center; justify-content: center; font-weight: 600;
}
.pagination .page-link:hover { background: var(--fyl-brand-soft); border-color: var(--fyl-brand); color: var(--fyl-brand-900); }
.pagination .page-item.active .page-link { background: var(--fyl-brand); border-color: var(--fyl-brand); color: #fff; }
.pagination .page-item.disabled .page-link { color: var(--fyl-muted); opacity: .6; }

/* ==========================================================================
   DETAIL PAGES (property / project) — layered over legacy markup
   Scoped to .detailproject / .boxright. Tab show/hide logic untouched.
   ========================================================================== */
.detailproject .titlehouse { font: 800 clamp(24px, 3.4vw, 34px)/1.2 var(--fyl-font-display); color: var(--fyl-text); margin: 8px 0 6px; }
.detailproject .addresshouse { color: var(--fyl-muted); font-size: 14.5px; display: flex; align-items: center; flex-wrap: wrap; gap: 14px; }
.detailproject .addresshouse i { color: var(--fyl-brand) !important; }

/* Key spec strip (category / area / price) */
.detailproject .pulm { font: 800 20px/1.2 var(--fyl-font-display); color: var(--fyl-text); margin: 0 0 2px; }
.detailproject .kmn { border-left: 1px solid var(--fyl-line); }
@media (max-width: 575px) { .detailproject .klm { border-left: 0; border-top: 1px solid var(--fyl-line); padding-top: 12px; margin-top: 12px; } }

/* Section headings */
.detailproject .headifhouse, .detailproject h5.headifhouse {
  font: 700 19px/1.3 var(--fyl-font-display); color: var(--fyl-text);
  margin: 22px 0 14px; padding-left: 12px; border-left: 4px solid var(--fyl-brand);
}

/* Tab nav (styling only — display handled by existing JS/CSS) */
.detailproject .tabs { display: flex; flex-wrap: wrap; gap: 8px; border-bottom: 1px solid var(--fyl-line); padding-bottom: 0; margin: 18px 0 22px; }
.detailproject .tabs .tab-link {
  cursor: pointer; padding: 10px 16px; border-radius: 10px 10px 0 0; font: 600 14px/1 var(--fyl-font-display);
  color: var(--fyl-muted); border: 1px solid transparent; border-bottom: 2px solid transparent; margin-bottom: -1px;
}
.detailproject .tabs .tab-link:hover { color: var(--fyl-brand); background: var(--fyl-brand-soft); }
.detailproject .tabs .tab-link.active { color: var(--fyl-brand); border-bottom-color: var(--fyl-brand); background: var(--fyl-brand-soft); }

/* Tables */
.detailproject .table { border: 1px solid var(--fyl-line); border-radius: var(--fyl-r); overflow: hidden; }
.detailproject .table td, .detailproject .table th { border-color: var(--fyl-line); vertical-align: middle; }
.detailproject .table-striped tbody tr:nth-of-type(odd) { background: var(--fyl-bg-alt); }
.detailproject .table i { color: var(--fyl-brand); }

/* Masterplan / gallery images */
.detailproject .showfullimg { border-radius: var(--fyl-r); cursor: zoom-in; box-shadow: var(--fyl-shadow-sm); width: 100%; }

/* EMI calculator sliders */
.detailproject input[type="range"] { width: 100%; accent-color: var(--fyl-brand); height: 6px; }
.detailproject .plmb { border: 1px solid var(--fyl-line-strong); border-radius: 10px; height: 44px; margin-top: 6px; }
.detailproject .slider-label1, .detailproject .slider-label2 { font-size: 12px; color: var(--fyl-muted); }
.detailproject #emi-result { color: var(--fyl-brand-900) !important; font-family: var(--fyl-font-display); }

/* Sticky enquiry sidebar container */
.boxright { background: transparent; padding: 0 !important; }

/* ---- Enquiry lead card (consult-form) ---- */
.fyl-enquire { padding: 22px; }
.fyl-enquire__head { margin-bottom: 16px; }
.fyl-enquire__head .fyl-badge { margin-bottom: 12px; }
.fyl-enquire__quick { display: flex; flex-direction: column; gap: 10px; margin-bottom: 14px; }
.fyl-enquire__or { position: relative; text-align: center; margin: 6px 0 16px; }
.fyl-enquire__or::before { content: ""; position: absolute; top: 50%; left: 0; right: 0; height: 1px; background: var(--fyl-line); }
.fyl-enquire__or span { position: relative; background: #fff; padding: 0 12px; font-size: 12.5px; color: var(--fyl-muted); }
.fyl-enquire .form-control.fyl-input,
.fyl-enquire .fyl-input { width: 100%; }
.fyl-enquire .fyl-group { margin-bottom: 12px; }
.fyl-enquire .formError, .fyl-enquire .text-danger { font-size: 13px; }
.fyl-enquire__trust { list-style: none; margin: 18px 0 0; padding: 16px 0 0; border-top: 1px solid var(--fyl-line); display: flex; flex-direction: column; gap: 10px; }
.fyl-enquire__trust li { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--fyl-body); }
.fyl-enquire__trust i { color: var(--fyl-brand); width: 18px; text-align: center; }

/* Related properties strip uses Vue cards — give it breathing room */
.detailproject .projecthome { margin-top: 14px; }

/* Builder / possession / RERA chips under the property title */
.fyl-listing-meta { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0 4px; }
.fyl-chip {
  display: inline-flex; align-items: center; gap: 6px;
  font: 600 12.5px/1 var(--fyl-font-body); padding: 7px 12px; border-radius: var(--fyl-r-pill);
  background: var(--fyl-bg-alt); color: var(--fyl-body); border: 1px solid var(--fyl-line);
}
.fyl-chip i { color: var(--fyl-brand); font-size: 12px; }
.fyl-chip--verified { background: #E7ECF3; color: var(--fyl-brand-700); border-color: #D4DCEA; }
.fyl-chip--verified i { color: var(--fyl-brand-700); }
.fyl-chip--accent { background: var(--fyl-accent-soft); color: #6f5800; border-color: #ecdca0; }
.fyl-chip--accent i { color: var(--fyl-accent); }

/* Gallery slider (visual only — owl-carousel/magnific hooks preserved) */
.boxsliderdetail .slidetop .item img { border-radius: var(--fyl-r); object-fit: cover; width: 100%; }
.boxsliderdetail .slidebot { margin-top: 12px; }
.boxsliderdetail .slidebot .cthumb img { border-radius: 12px; opacity: .82; transition: opacity .2s var(--fyl-ease); }
.boxsliderdetail .slidebot .cthumb img:hover { opacity: 1; }
.boxsliderdetail .control .itemct { cursor: pointer; }
.boxsliderdetail .control .itemct .icon {
  border: 1px solid var(--fyl-line-strong); border-radius: 12px; padding: 10px 6px; text-align: center;
  color: var(--fyl-brand-900); transition: all .2s var(--fyl-ease); background: #fff;
}
.boxsliderdetail .control .itemct .icon:hover { border-color: var(--fyl-brand); background: var(--fyl-brand-soft); color: var(--fyl-brand); }
.boxsliderdetail .control .itemct .icon i { font-size: 18px; display: block; margin-bottom: 4px; color: var(--fyl-brand); }
.boxsliderdetail .control .itemct .icon p { margin: 0; font-size: 12px; }
.boxsliderdetail .ar-next, .boxsliderdetail .ar-prev {
  width: 34px; height: 34px; border-radius: 50%; background: #fff; box-shadow: var(--fyl-shadow-sm);
  display: grid; place-items: center; color: var(--fyl-brand-900); cursor: pointer; z-index: 5;
}

/* ==========================================================================
   ACCESSIBILITY / PERFORMANCE
   ========================================================================== */
.fyl-skip {
  position: absolute; left: 12px; top: -60px; z-index: 2000;
  background: var(--fyl-brand); color: #fff; padding: 10px 16px; border-radius: 0 0 10px 10px;
  font: 600 14px/1 var(--fyl-font-display); transition: top .18s var(--fyl-ease);
}
.fyl-skip:focus { top: 0; color: #fff; outline: 2px solid var(--fyl-accent); outline-offset: 2px; }
#app:focus { outline: none; }
/* Visible keyboard focus for interactive brand components */
.fyl-btn:focus-visible, .fyl-card__title a:focus-visible, .fyl-menu a:focus-visible,
.fyl-citytile:focus-visible, .fyl-cat:focus-visible { outline: 2px solid var(--fyl-brand); outline-offset: 2px; }
/* Respect reduced-motion */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
}

/* ==========================================================================
   PHASE 3 — HOMEPAGE HERO ("startup screen", retention-tuned)
   Cinematic navy scrim, staggered entrance, divided stats, chips, scroll cue.
   ========================================================================== */
.fyl-hero {
  background:
    radial-gradient(120% 95% at 12% 0%, rgba(20,51,86,.45), transparent 55%),
    linear-gradient(180deg, rgba(6,16,31,.55) 0%, rgba(10,26,47,.72) 55%, rgba(10,26,47,.90) 100%),
    var(--fyl-hero-img, linear-gradient(120deg, #0A1A2F, #143356)) center/cover no-repeat;
  padding: clamp(76px, 13vh, 150px) 0 clamp(96px, 16vh, 170px);
  overflow: hidden;
}
.fyl-hero::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 3px;
  background: linear-gradient(90deg, transparent, var(--fyl-accent), transparent); opacity: .55;
}
.fyl-hero__inner { max-width: 840px; position: relative; z-index: 2; }
.fyl-hero h1 {
  font-weight: 800; letter-spacing: -.02em; font-size: clamp(34px, 5.4vw, 60px);
  text-shadow: 0 2px 40px rgba(0,0,0,.28);
}
.fyl-hero p { color: rgba(255,255,255,.86); }

/* Staggered entrance */
@keyframes fylRise { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: none; } }
.fyl-hero__inner > * { animation: fylRise .7s var(--ease-out, cubic-bezier(.16,1,.3,1)) both; }
.fyl-hero__inner > .fyl-zero-commission { animation-delay: .05s; }
.fyl-hero__inner > h1 { animation-delay: .12s; }
.fyl-hero__inner > p  { animation-delay: .20s; }
.fyl-hero__inner > .fyl-searchbar { animation-delay: .30s; }
.fyl-hero__inner > .fyl-hero__chips { animation-delay: .40s; }
.fyl-hero__inner > .fyl-hero__stats { animation-delay: .48s; }

/* Stats — refined with dividers */
.fyl-hero__stats { gap: 0; border-top: 1px solid rgba(255,255,255,.16); padding-top: 22px; margin-top: 30px; }
.fyl-hero__stat { padding: 2px 28px; position: relative; }
.fyl-hero__stat:first-child { padding-left: 0; }
.fyl-hero__stat + .fyl-hero__stat::before { content: ""; position: absolute; left: 0; top: 4px; bottom: 4px; width: 1px; background: rgba(255,255,255,.18); }
.fyl-hero__stat b { font-size: clamp(22px, 3vw, 30px); }

/* Popular-search chips */
.fyl-hero__chips { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-top: 16px; }
.fyl-hero__chips .lbl { font-size: 12.5px; color: rgba(255,255,255,.72); margin-right: 2px; }
.fyl-hero__chip {
  display: inline-flex; align-items: center; gap: 6px; padding: 7px 14px; border-radius: var(--fyl-r-pill);
  font: 600 13px/1 var(--fyl-font-body); color: #fff; background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.22); transition: all .2s var(--fyl-ease); text-decoration: none;
}
.fyl-hero__chip:hover { background: #fff; color: var(--fyl-brand-900); transform: translateY(-1px); }

/* Scroll cue */
.fyl-hero__scroll {
  position: absolute; left: 50%; bottom: 18px; transform: translateX(-50%);
  color: rgba(255,255,255,.7); font-size: 18px; z-index: 2;
  animation: fylBob 1.8s ease-in-out infinite;
}
.fyl-hero__scroll:hover { color: #fff; }
@keyframes fylBob { 0%, 100% { transform: translate(-50%, 0); } 50% { transform: translate(-50%, 7px); } }

/* Search tab active gets subtle lift */
.fyl-search-tab.is-active { box-shadow: var(--fyl-shadow-sm); }

@media (prefers-reduced-motion: reduce) {
  .fyl-hero__inner > *, .fyl-hero__scroll { animation: none; }
}

/* Area price trend (NHB RESIDEX) */
.fyl-trend { background: var(--fyl-surface); border: 1px solid var(--fyl-line); border-radius: var(--fyl-r); box-shadow: var(--fyl-shadow-sm); padding: 22px; margin: 22px 0; }
.fyl-trend__head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; flex-wrap: wrap; }
.fyl-trend__title { font: 700 19px/1.3 var(--fyl-font-display); color: var(--fyl-text); margin: 2px 0 0; }
.fyl-trend__src { font-size: 11.5px; color: var(--fyl-muted); background: var(--fyl-bg-alt); padding: 5px 10px; border-radius: var(--fyl-r-pill); white-space: nowrap; }
.fyl-trend__stats { display: flex; gap: 26px; flex-wrap: wrap; margin: 16px 0 18px; }
.fyl-trend__stat b { display: block; font: 800 22px/1.1 var(--fyl-font-display); color: var(--fyl-text); }
.fyl-trend__stat b.is-up { color: var(--color-success, #1B7F5C); }
.fyl-trend__stat b.is-down { color: var(--color-danger, #C0392B); }
.fyl-trend__stat b i { font-size: 15px; }
.fyl-trend__stat span { font-size: 12.5px; color: var(--fyl-muted); }
.fyl-trend__chart { display: flex; align-items: flex-end; gap: 4px; height: 130px; padding-top: 8px; }
.fyl-trend__bar { flex: 1; min-width: 6px; background: linear-gradient(180deg, var(--fyl-brand-600), var(--fyl-brand)); border-radius: 5px 5px 0 0; position: relative; transition: opacity .15s var(--fyl-ease); }
.fyl-trend__bar:last-child { background: linear-gradient(180deg, var(--fyl-accent), var(--fyl-accent-600)); }
.fyl-trend__bar:hover { opacity: .85; }
.fyl-trend__barval { position: absolute; top: -16px; left: 50%; transform: translateX(-50%); font-size: 9.5px; color: var(--fyl-muted); opacity: 0; transition: opacity .15s; }
.fyl-trend__bar:hover .fyl-trend__barval { opacity: 1; }
.fyl-trend__axis { display: flex; justify-content: space-between; font-size: 11.5px; color: var(--fyl-muted); margin-top: 6px; }
.fyl-trend__note { font-size: 12px; color: var(--fyl-muted); margin: 12px 0 0; line-height: 1.5; }

/* Scroll-reveal for sections (added via JS; degrades gracefully if JS off) */
.fyl-reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s var(--ease-out, cubic-bezier(.16,1,.3,1)), transform .6s var(--ease-out, cubic-bezier(.16,1,.3,1)); }
.fyl-reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .fyl-reveal { opacity: 1 !important; transform: none !important; }
}
