﻿/* â”€â”€â”€ FGIP LEGACY LUXURY ESTATE PAGE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.fgip-hero {
  background: var(--dark-section);
  min-height: 90dvh;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
}

.fgip-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 80%, rgba(61,107,158,.09) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 20%, rgba(61,107,158,.05) 0%, transparent 50%);
  pointer-events: none;
}

.fgip-hero-inner {
  padding: clamp(60px,8vw,100px) clamp(20px,6vw,80px) 40px;
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.fgip-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-inter);
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  border: 1px solid var(--accent-border);
  padding: 5px 14px;
  border-radius: 100px;
  background: var(--accent-light);
  margin-bottom: 22px;
  width: fit-content;
}

.fgip-hero-title {
  font-family: var(--font-bebas);
  font-size: clamp(2.6rem,5.5vw,5rem);
  letter-spacing: -.01em;
  line-height: .9;
  color: var(--white);
  margin-bottom: 24px;
  max-width: 900px;
}

.fgip-hero-sub {
  font-family: var(--font-inter);
  font-size: clamp(.88rem,1.4vw,1rem);
  font-weight: 300;
  color: rgba(255,255,255,.45);
  max-width: 580px;
  line-height: 1.72;
  margin-bottom: 20px;
}

.fgip-hero-location {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-inter);
  font-size: .74rem;
  font-weight: 500;
  letter-spacing: .06em;
  color: var(--accent);
  margin-bottom: 32px;
}

.fgip-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }

.fgip-facts-bar {
  display: flex;
  background: rgba(255,255,255,.03);
  border-top: 1px solid rgba(255,255,255,.07);
  position: relative;
}

.fgip-fact {
  flex: 1;
  padding: clamp(18px,3vw,32px) clamp(16px,2.5vw,28px);
  border-right: 1px solid rgba(255,255,255,.06);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.fgip-fact:last-child { border-right: none; }

.fgip-fact-num {
  font-family: var(--font-bebas);
  font-size: clamp(1.6rem,3vw,2.8rem);
  letter-spacing: -.01em;
  color: var(--accent);
  line-height: 1;
}

.fgip-fact-label {
  font-family: var(--font-inter);
  font-size: .6rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.22);
}

/* SECTIONS */
.fgip-section { padding: clamp(60px,8vw,100px) clamp(20px,6vw,80px); }
.fgip-section.bg-white { background: var(--white); }
.fgip-section.bg-offwhite { background: var(--off-white); }

.fgip-section-inner { max-width: 1100px; }

.fgip-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px,6vw,80px);
  align-items: start;
}

.fgip-body {
  font-family: var(--font-inter);
  font-size: .9rem;
  color: var(--gray-500);
  line-height: 1.78;
}

/* LOCATION */
.fgip-location-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px,6vw,80px);
  margin-top: 32px;
  align-items: start;
}

.fgip-loc-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid var(--gray-200);
  font-family: var(--font-inter);
  font-size: .88rem;
  color: var(--off-black);
}

.fgip-loc-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
}

/* COLLECTIONS HORIZONTAL SCROLL */
.fgip-collections-section {
  background: var(--dark-section);
  padding: clamp(40px,5vw,64px) clamp(20px,6vw,80px) 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.fgip-collections-header { margin-bottom: clamp(20px,3vw,32px); }

.fgip-collections-track {
  display: flex;
  gap: 20px;
  padding-bottom: 40px;
  will-change: transform;
}

.fgip-collection-card {
  flex-shrink: 0;
  width: clamp(300px, 38vw, 480px);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  padding: clamp(24px,3vw,36px);
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: border-color .3s;
}

.fgip-collection-card:hover { border-color: rgba(61,107,158,.3); }

.fgip-coll-num {
  font-family: var(--font-bebas);
  font-size: .9rem;
  letter-spacing: .14em;
  color: var(--accent);
  opacity: .7;
}

.fgip-coll-title {
  font-family: var(--font-bebas);
  font-size: clamp(2rem,4vw,3rem);
  letter-spacing: .02em;
  color: var(--white);
  line-height: 1;
}

.fgip-coll-size {
  font-family: var(--font-inter);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
}

.fgip-coll-desc {
  font-family: var(--font-inter);
  font-size: .86rem;
  color: rgba(255,255,255,.45);
  line-height: 1.7;
  flex: 1;
}

.fgip-coll-features {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 16px;
}

.fgip-coll-features li {
  font-family: var(--font-inter);
  font-size: .8rem;
  color: rgba(255,255,255,.35);
  padding-left: 12px;
  position: relative;
}

.fgip-coll-features li::before {
  content: '';
  position: absolute;
  left: 0; top: 8px;
  width: 4px; height: 1px;
  background: var(--accent);
  opacity: .5;
}

.fgip-scroll-hint {
  font-family: var(--font-inter);
  font-size: .65rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.2);
  padding: 16px clamp(20px,6vw,80px) 24px;
}

/* AMENITIES */
.fgip-amenities-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 1px;
  background: var(--gray-200);
  border: 1px solid var(--gray-200);
}

.fgip-amenity-group {
  background: var(--white);
  padding: clamp(22px,3.5vw,36px);
  transition: background .3s;
}
.fgip-amenity-group:hover { background: var(--off-white); }

.fgip-amenity-icon {
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.05rem;
  margin-bottom: 14px;
  color: var(--accent);
  border: 1px solid var(--accent-border);
  border-radius: 12px;
  background: var(--accent-light);
}

.fgip-amenity-title {
  font-family: var(--font-inter);
  font-size: .84rem;
  font-weight: 600;
  color: var(--off-black);
  letter-spacing: -.01em;
  margin-bottom: 10px;
}

.fgip-amenity-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.fgip-amenity-list li {
  font-family: var(--font-inter);
  font-size: .76rem;
  color: var(--gray-500);
  padding-left: 10px;
  position: relative;
}
.fgip-amenity-list li::before { content: '·'; position: absolute; left: 0; color: var(--accent); }

/* IMPACT */
.fgip-impact-list { display: flex; flex-direction: column; border-top: 1px solid var(--gray-200); }
.fgip-impact-item {
  font-family: var(--font-inter);
  font-size: .9rem;
  color: var(--off-black);
  padding: 14px 0;
  border-bottom: 1px solid var(--gray-200);
  display: flex;
  align-items: center;
  gap: 12px;
}
.fgip-impact-item::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); flex-shrink: 0; }

/* INVESTOR */
.fgip-investor {
  background: var(--dark-section);
  padding: clamp(60px,8vw,100px) clamp(20px,6vw,80px);
  position: relative;
  overflow: hidden;
  text-align: center;
}
.fgip-investor::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 50% 50%, rgba(61,107,158,.08) 0%, transparent 70%); pointer-events: none; }
.fgip-investor-inner { position: relative; max-width: 700px; margin: 0 auto; }
.fgip-investor-body { font-family: var(--font-inter); font-size: .9rem; color: rgba(255,255,255,.42); line-height: 1.75; margin-bottom: 28px; }
.fgip-interest-areas { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin-bottom: 32px; }
.fgip-investor-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 32px; }
.fgip-sponsor-note { font-family: var(--font-inter); font-size: .64rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.18); }

.btn-primary { font-family: var(--font-inter); font-size: .75rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; text-decoration: none; color: var(--white); background: var(--accent); padding: 13px 28px; border-radius: 100px; transition: all .25s var(--ease-out); display: inline-block; }
.btn-primary:hover { background: #2f5680; transform: translateY(-2px); }
.btn-outline { font-family: var(--font-inter); font-size: .75rem; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; text-decoration: none; color: rgba(255,255,255,.6); border: 1px solid rgba(255,255,255,.2); padding: 13px 26px; border-radius: 100px; transition: all .25s var(--ease-out); display: inline-block; }
.btn-outline:hover { color: var(--white); border-color: rgba(255,255,255,.5); }

/* DEVELOPMENT OVERVIEW */
.fgip-overview {
  background: linear-gradient(180deg, var(--dark-section) 0%, #1c3350 100%);
  padding: clamp(60px,8vw,100px) clamp(20px,6vw,80px);
  position: relative;
  overflow: hidden;
}
.fgip-overview::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 80% 20%, rgba(255,180,0,.05) 0%, transparent 55%);
  pointer-events: none;
}
.fgip-overview-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 16px;
  margin-top: clamp(36px,5vw,56px);
}
.fgip-ov-stat {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  padding: clamp(22px,3vw,34px);
  display: flex; flex-direction: column; gap: 8px;
  transition: border-color .3s;
}
.fgip-ov-stat:hover { border-color: rgba(255,180,0,.35); }
.fgip-ov-stat:nth-child(1) .fgip-ov-num { color: var(--amber); }
.fgip-ov-stat:nth-child(2) .fgip-ov-num { color: #6ea8f7; }
.fgip-ov-stat:nth-child(3) .fgip-ov-num { color: var(--orange); }
.fgip-ov-stat:nth-child(4) .fgip-ov-num { color: #4cc56a; }
.fgip-ov-num { font-family: var(--font-bebas); font-size: clamp(2rem,3.6vw,3rem); letter-spacing: .01em; line-height: 1; }
.fgip-ov-label { font-family: var(--font-inter); font-size: .72rem; font-weight: 500; letter-spacing: .06em; color: rgba(255,255,255,.42); line-height: 1.5; }

.fgip-target-market { margin-top: clamp(28px,4vw,40px); display: flex; flex-direction: column; gap: 14px; }
.fgip-target-label { font-family: var(--font-inter); font-size: .64rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.3); }
.fgip-target-chips { display: flex; flex-wrap: wrap; gap: 10px; }
.fgip-chip {
  font-family: var(--font-inter); font-size: .76rem; font-weight: 500;
  color: rgba(255,255,255,.75); background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.14); padding: 8px 17px; border-radius: 100px;
  transition: all .25s var(--ease-out);
}
.fgip-chip:hover { border-color: var(--amber); color: var(--amber); }

/* COLLECTION CARD COLOR CODING */
.fgip-collection-card { position: relative; overflow: hidden; }
.fgip-collection-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; }
.fgip-collection-card:nth-child(1)::before { background: var(--amber); }
.fgip-collection-card:nth-child(2)::before { background: #6ea8f7; }
.fgip-collection-card:nth-child(3)::before { background: var(--green); }
.fgip-collection-card:nth-child(4)::before { background: var(--purple); }
.fgip-collection-card:nth-child(1) .fgip-coll-num { color: var(--amber); }
.fgip-collection-card:nth-child(2) .fgip-coll-num { color: #6ea8f7; }
.fgip-collection-card:nth-child(3) .fgip-coll-num { color: #4cc56a; }
.fgip-collection-card:nth-child(4) .fgip-coll-num { color: #c98bf5; }

/* AMENITY ICON COLOR CYCLE */
.fgip-amenity-group:nth-child(6n+1) .fgip-amenity-icon { background: var(--accent-light); color: var(--accent); border-color: var(--accent-border); }
.fgip-amenity-group:nth-child(6n+2) .fgip-amenity-icon { background: rgba(255,180,0,.1); color: #cc9000; border-color: rgba(255,180,0,.3); }
.fgip-amenity-group:nth-child(6n+3) .fgip-amenity-icon { background: var(--coral-light); color: var(--orange); border-color: rgba(255,92,0,.25); }
.fgip-amenity-group:nth-child(6n+4) .fgip-amenity-icon { background: rgba(31,166,60,.08); color: var(--green); border-color: rgba(31,166,60,.25); }
.fgip-amenity-group:nth-child(6n+5) .fgip-amenity-icon { background: rgba(182,92,240,.08); color: var(--purple); border-color: rgba(182,92,240,.25); }
.fgip-amenity-group:nth-child(6n+6) .fgip-amenity-icon { background: var(--gray-100); color: var(--accent-deep); border-color: var(--gray-300); }

/* VISION FIGURE */
.fgip-vision-figure { margin-top: clamp(36px,5vw,56px); }
.fgip-vision-img {
  width: 100%; max-height: 520px; object-fit: cover;
  border-radius: 20px; border: 1px solid var(--gray-200);
  box-shadow: 0 24px 60px -28px rgba(22,40,63,.35);
}
.fgip-img-caption {
  font-family: var(--font-inter); font-size: .72rem; color: var(--gray-400);
  margin-top: 12px; letter-spacing: .04em;
}

/* COLLECTION CARD IMAGE */
.fgip-coll-img {
  width: calc(100% + 2 * clamp(24px,3vw,36px));
  margin: calc(-1 * clamp(24px,3vw,36px)) calc(-1 * clamp(24px,3vw,36px)) 4px;
  height: clamp(110px, 15vh, 180px); object-fit: cover;
  border-radius: 17px 17px 0 0;
  display: block;
}

/* Static fallback when the section is taller than the viewport (no pin) —
   behaves like the mobile swipe track */
.fgip-coll-static { min-height: auto; padding-bottom: clamp(40px,6vw,60px); }
.fgip-coll-static .fgip-collections-track {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  padding-bottom: 24px;
}
.fgip-coll-static .fgip-collection-card { scroll-snap-align: center; }

/* COMMUNITY RENDERINGS GALLERY */
.fgip-gallery { background: var(--off-white); padding: clamp(60px,8vw,100px) clamp(20px,6vw,80px); }
.fgip-gallery-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; }
.fgip-gallery-item {
  position: relative; border-radius: 18px; overflow: hidden;
  border: 1px solid var(--gray-200); background: var(--white);
  transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out);
}
.fgip-gallery-item:hover { transform: translateY(-4px); box-shadow: 0 24px 50px -24px rgba(22,40,63,.3); }
.fgip-gallery-item img { width: 100%; height: clamp(220px,28vw,340px); object-fit: cover; display: block; }
.fgip-gallery-item figcaption {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-inter); font-size: .85rem; font-weight: 600;
  color: var(--off-black); padding: 14px 18px;
}
.fgip-gallery-tag {
  font-size: .6rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--white); padding: 4px 10px; border-radius: 100px;
}

/* INFRASTRUCTURE FIRST */
.fgip-infra { background: var(--wash-cream); padding: clamp(60px,8vw,100px) clamp(20px,6vw,80px); }
.fgip-infra-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 24px; margin-top: 24px; }
.fgip-infra-item {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-inter); font-size: .86rem; color: var(--off-black);
  padding: 11px 0; border-bottom: 1px solid rgba(31,45,61,.08);
}
.fgip-infra-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }

/* PROJECT SPONSORSHIP */
.fgip-sponsorship { background: var(--white); padding: clamp(60px,8vw,100px) clamp(20px,6vw,80px); }
.fgip-sponsor-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 20px; align-items: stretch; }
.fgip-sponsor-card {
  background: var(--off-white); border: 1px solid var(--gray-200); border-radius: 18px;
  padding: clamp(26px,4vw,42px); transition: border-color .3s;
}
.fgip-sponsor-card:hover { border-color: var(--accent-border); }
.fgip-sponsor-card-principal {
  display: grid; grid-template-columns: auto 1fr; gap: clamp(20px,3vw,32px);
  align-items: center; background: var(--dark-section); border-color: rgba(255,255,255,.08);
}
.fgip-sponsor-card-principal:hover { border-color: rgba(255,180,0,.4); }
.fgip-sponsor-card-principal .fgip-sponsor-card-name { color: var(--white); }
.fgip-sponsor-card-principal .fgip-sponsor-card-desc { color: rgba(255,255,255,.45); }
.fgip-sponsor-photo {
  width: clamp(90px,9vw,130px); aspect-ratio: 4/5; object-fit: cover;
  border-radius: 14px 40px 14px 14px; border: 3px solid var(--amber);
}
.fgip-sponsor-card-label { font-family: var(--font-inter); font-size: .62rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); margin-bottom: 10px; }
.fgip-sponsor-card-principal .fgip-sponsor-card-label { color: var(--amber); }
.fgip-sponsor-card-name { font-family: var(--font-bebas); font-size: clamp(1.6rem,2.6vw,2.2rem); letter-spacing: .02em; color: var(--off-black); line-height: 1; margin-bottom: 12px; }
.fgip-sponsor-card-desc { font-family: var(--font-inter); font-size: .84rem; color: var(--gray-500); line-height: 1.7; }
.fgip-sponsor-link {
  display: inline-block; margin-top: 14px;
  font-family: var(--font-inter); font-size: .76rem; font-weight: 600; letter-spacing: .04em;
  color: var(--amber); text-decoration: none; border-bottom: 1px solid rgba(255,180,0,.35);
  padding-bottom: 2px; transition: letter-spacing .2s;
}
.fgip-sponsor-link:hover { letter-spacing: .08em; }

@media (max-width: 900px) {
  .fgip-two-col { grid-template-columns: 1fr; }
  .fgip-location-grid { grid-template-columns: 1fr; }
  .fgip-amenities-grid { grid-template-columns: repeat(2,1fr); }
  .fgip-facts-bar { flex-wrap: wrap; }
  .fgip-fact { flex: 1 1 40%; }
  .fgip-overview-grid { grid-template-columns: 1fr 1fr; }
  .fgip-sponsor-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  /* Pinned horizontal scroll is disabled on mobile (see fgip.html) — swipe natively instead */
  .fgip-collections-section { min-height: auto; padding-bottom: clamp(40px,8vw,60px); }
  .fgip-collections-track {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: 24px;
    margin: 0 -20px;
    padding-left: 20px;
    padding-right: 20px;
  }
  .fgip-collection-card { width: min(82vw, 340px); scroll-snap-align: center; }
  .fgip-fact { flex: 1 1 100%; }
  .fgip-hero-actions { flex-wrap: wrap; }
}

@media (max-width: 600px) {
  .fgip-amenities-grid { grid-template-columns: 1fr; }
  .fgip-overview-grid { grid-template-columns: 1fr; }
  .fgip-infra-grid { grid-template-columns: 1fr; }
  .fgip-gallery-grid { grid-template-columns: 1fr; }
  .fgip-coll-img { height: 160px; }
  .fgip-sponsor-card-principal { grid-template-columns: 1fr; }
  .fgip-sponsor-photo { width: 110px; }
}
