:root {
  --navy:#12477f;
  --navy-dark:#0a2e54;
  --green:#7bb331;
  --green-dark:#5a8424;
  --muted:#6c7384;
  --border:#e1e6f0;
  --bg:#ffffff;
  --max-width:1140px;
  --radius-lg:22px;
  --radius-md:16px;
  --radius-sm:10px;
  --shadow-soft:0 18px 45px rgba(6,26,58,0.18);
}

* { box-sizing:border-box; }

body {
  margin:0;
  font-family:'Poppins',system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:var(--bg);
  color:#141927;
}

a { color:var(--navy); text-decoration:none; }
a:hover { text-decoration:underline; }

/* NAV BAR (APPEARS AFTER SCROLL) */
.site-nav {
  position:fixed;
  top:0;
  left:0;
  right:0;
  padding:0.45rem 1.2rem;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,0.96);
  border-bottom:1px solid rgba(0,0,0,0.06);
  box-shadow:0 10px 30px rgba(0,0,0,0.08);
  transform:translateY(-100%);
  opacity:0;
  transition:transform 0.35s ease, opacity 0.35s ease;
  z-index:50;
  backdrop-filter:blur(14px);
}
.site-nav.visible { transform:translateY(0); opacity:1; }

.nav-inner {
  width:100%;
  max-width:var(--max-width);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}

.nav-brand { display:flex; align-items:center; gap:0.6rem; }
.nav-brand img { height:40px; width:auto; }
.nav-brand span { font-weight:700; font-size:0.95rem; color:var(--navy-dark); }

.nav-links { display:flex; flex-wrap:wrap; gap:0.9rem; font-size:0.82rem; }
.nav-links a { text-transform:uppercase; letter-spacing:0.15em; font-weight:600; color:var(--muted); }
.nav-links a:hover { color:var(--navy-dark); }

.nav-cta { display:flex; align-items:center; gap:0.5rem; }

.badge-pill {
  font-size:0.75rem;
  border-radius:999px;
  padding:0.25rem 0.7rem;
  background:#f5f8ff;
  border:1px solid rgba(18,71,127,0.14);
  color:var(--muted);
}

.btn-small {
  border-radius:999px;
  padding:0.35rem 1rem;
  border:none;
  background:linear-gradient(135deg,var(--green),var(--green-dark));
  color:#fff;
  font-size:0.78rem;
  font-weight:700;
  letter-spacing:0.12em;
  text-transform:uppercase;
  cursor:pointer;
  box-shadow:0 8px 22px rgba(97,159,44,0.5);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0.35rem;
  text-decoration:none;
}
.btn-small:hover {
  transform:translateY(-1px);
  box-shadow:0 12px 28px rgba(86,140,39,0.6);
  text-decoration:none;
}
.btn-small.alt {
  background:linear-gradient(135deg,var(--navy),var(--navy-dark));
  box-shadow:0 10px 26px rgba(8,32,70,0.35);
}

/* PAGE WRAPPER */
main {
  max-width:var(--max-width);
  margin:0 auto;
  padding:2.2rem 1.2rem 3.2rem;
}

/* HERO WITH CENTERED LOGO */
.hero {
  min-height:70vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  position:relative;
}
.hero::before {
  content:"";
  position:absolute;
  inset:-40px;
  background:
    radial-gradient(circle at 10% 0, rgba(123,179,49,0.2), transparent 50%),
    radial-gradient(circle at 90% 100%, rgba(18,71,127,0.22), transparent 60%);
  opacity:0.9;
  filter:blur(26px);
  pointer-events:none;
  z-index:-1;
}

.hero-inner { position:relative; z-index:1; max-width:760px; }

.hero-logo-wrap {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:1.2rem 1.6rem;
  border-radius:26px;
  background:#ffffff;
  box-shadow:var(--shadow-soft);
  margin-bottom:1.1rem;
}
.hero-logo-wrap img { width:260px; max-width:70vw; height:auto; display:block; }

.hero-kicker {
  font-size:0.82rem;
  text-transform:uppercase;
  letter-spacing:0.22em;
  color:var(--muted);
  margin-bottom:0.4rem;
}

.hero-title {
  font-size:2.4rem;
  line-height:1.05;
  margin:0 0 0.6rem;
  color:var(--navy-dark);
}
.hero-title span {
  background:linear-gradient(135deg,var(--green),#b6ec4d,var(--navy));
  -webkit-background-clip:text;
  color:transparent;
}

.hero-sub {
  margin:0 auto 1.3rem;
  color:var(--muted);
  font-size:0.98rem;
  max-width:32rem;
}

.hero-tags {
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:0.5rem;
  margin-bottom:1.4rem;
}

.hero-tag-pill {
  border-radius:999px;
  border:1px solid rgba(8,34,72,0.15);
  padding:0.35rem 0.8rem;
  font-size:0.8rem;
  background:#ffffff;
  color:var(--navy);
  display:inline-flex;
  align-items:center;
  gap:0.35rem;
  box-shadow:0 6px 18px rgba(6,26,58,0.08);
}

.hero-tag-pill .tag-icon {
  width:22px;
  height:22px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(123,179,49,0.12);
  font-size:0.9rem;
}

.hero-buttons {
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:0.75rem;
}

.btn-primary {
  border:none;
  border-radius:999px;
  padding:0.8rem 1.9rem;
  background:linear-gradient(135deg,var(--navy),var(--navy-dark));
  color:#fff;
  font-size:0.9rem;
  font-weight:700;
  letter-spacing:0.16em;
  text-transform:uppercase;
  cursor:pointer;
  box-shadow:0 16px 40px rgba(8,32,70,0.55);
  display:inline-flex;
  align-items:center;
  gap:0.45rem;
}
.btn-primary:hover { transform:translateY(-1px); box-shadow:0 22px 50px rgba(4,21,48,0.7); }

.btn-ghost {
  border-radius:999px;
  padding:0.8rem 1.6rem;
  border:1px solid rgba(8,32,70,0.2);
  background:rgba(255,255,255,0.9);
  font-size:0.9rem;
  font-weight:600;
  color:var(--navy-dark);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:0.4rem;
}
.btn-ghost:hover { background:#ffffff; box-shadow:0 10px 26px rgba(10,30,66,0.18); }

.hero-meta { margin-top:1.1rem; font-size:0.8rem; color:var(--muted); }

/* SECTION TITLES */
.section { margin-top:3rem; }

.section-header {
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:1rem;
  margin-bottom:1.1rem;
  flex-wrap:wrap;
}

.section-title { font-size:1.35rem; margin:0; color:var(--navy-dark); }
.section-sub { margin:0; font-size:0.86rem; color:var(--muted); max-width:26rem; }

/* FEATURED CARDS */
.featured-row {
  display:grid;
  grid-template-columns: repeat(auto-fit,minmax(260px,1fr));
  gap:1.1rem;
}

.card {
  border-radius:var(--radius-md);
  background:#ffffff;
  border:1px solid var(--border);
  box-shadow:0 14px 40px rgba(7,22,46,0.12);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}

.card-image { position:relative; overflow:hidden; }
.card-image img {
  width:100%;
  height:170px;
  object-fit:cover;
  display:block;
  transform:scale(1.02);
}

.card-body { padding:0.85rem 0.95rem 0.75rem; flex:1; }

/* Region pill ABOVE title with icon */
.region-pill {
  display:inline-flex;
  align-items:center;
  gap:0.45rem;
  padding:0.28rem 0.75rem;
  border-radius:999px;
  border:1px solid rgba(18,71,127,0.18);
  background:#f5f8ff;
  color:var(--navy-dark);
  font-size:0.78rem;
  font-weight:700;
  margin-bottom:0.55rem;
  width:fit-content;
  max-width:100%;
}
.region-pill .ico {
  width:22px;
  height:22px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(18,71,127,0.10);
  flex:0 0 auto;
  font-size:0.95rem;
}
.region-pill .txt {
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  max-width:280px;
}

.card-title { margin:0 0 0.35rem; font-size:1rem; color:var(--navy-dark); }
.card-meta { margin:0 0 0.65rem; font-size:0.84rem; color:var(--muted); }

.facts {
  display:grid;
  grid-template-columns: 1fr;
  gap:0.3rem;
  margin-top:0.2rem;
  margin-bottom:0.75rem;
  font-size:0.84rem;
  color:var(--muted);
}
.facts strong { color:var(--navy-dark); font-weight:700; }

.price-grid {
  margin-top:0.4rem;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0.6rem;
}
.price-col {
  border:1px solid rgba(12,30,66,0.10);
  background:#fbfcff;
  border-radius:12px;
  padding:0.55rem 0.6rem;
}
.price-col h4 {
  margin:0 0 0.35rem;
  font-size:0.78rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--navy-dark);
}
.price-line {
  font-size:0.85rem;
  color:var(--muted);
  margin:0.15rem 0;
  line-height:1.25;
}
.price-line strong { color:var(--navy-dark); font-weight:800; }

.card-footer {
  padding:0.8rem 0.95rem 0.95rem;
  border-top:1px dashed rgba(12,26,55,0.16);
  display:flex;
  flex-direction:column;
  gap:0.65rem;
}

.cta-row {
  display:flex;
  gap:0.6rem;
  align-items:center;
  justify-content:flex-start;
  flex-wrap:wrap;
}

/* FILTERS + GRID */
.filters-bar {
  border-radius:var(--radius-md);
  background:#ffffff;
  border:1px solid var(--border);
  box-shadow:0 16px 40px rgba(9,31,65,0.12);
  padding:0.8rem 0.95rem 1rem;
  display:flex;
  flex-wrap:wrap;
  gap:0.8rem 1.3rem;
  align-items:flex-end;
  margin-bottom:1.4rem;
}

.filter-block {
  display:flex;
  flex-direction:column;
  gap:0.25rem;
  min-width:160px;
  flex:1;
}

.filter-block label {
  font-size:0.72rem;
  text-transform:uppercase;
  letter-spacing:0.16em;
  font-weight:600;
  color:var(--muted);
}

.filter-block input,
.filter-block select {
  border-radius:999px;
  border:1px solid rgba(9,31,65,0.26);
  padding:0.48rem 0.85rem;
  font-size:0.86rem;
  outline:none;
  background:#ffffff;
}
.filter-block input:focus,
.filter-block select:focus {
  border-color:var(--green);
  box-shadow:0 0 0 2px rgba(123,179,49,0.35);
}

.sort-row { display:flex; flex-wrap:wrap; gap:0.45rem; align-items:center; }
.sort-label {
  font-size:0.76rem;
  text-transform:uppercase;
  letter-spacing:0.16em;
  color:var(--muted);
  font-weight:600;
}

.sort-pill {
  border-radius:999px;
  padding:0.25rem 0.75rem;
  border:1px solid rgba(10,34,72,0.3);
  background:#ffffff;
  font-size:0.78rem;
  cursor:pointer;
}
.sort-pill.active { background:var(--navy); color:#fff; border-color:var(--navy); }

/* All available properties grid: 4 across (desktop) */
.grid {
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:1rem;
}
@media (max-width: 1100px) {
  .grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .region-pill .txt { max-width:220px; }
}
@media (max-width: 820px) {
  .grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px) {
  .grid { grid-template-columns: 1fr; }
}

.empty-state { text-align:center; padding:2rem 1rem; font-size:0.9rem; color:var(--muted); }

/* REAL ESTATE CLASS SECTION */
.class-section { margin-top:2.5rem; }

.class-card {
  border-radius:var(--radius-lg);
  background:#f5f9ff;
  border:1px solid rgba(18,71,127,0.16);
  box-shadow:0 20px 50px rgba(9,31,65,0.16);
  padding:1.3rem 1.4rem 1.6rem;
  display:grid;
  grid-template-columns:minmax(0,2.1fr) minmax(0,1.4fr);
  gap:1.4rem;
  align-items:center;
}

.class-badge {
  display:inline-flex;
  align-items:center;
  gap:0.35rem;
  border-radius:999px;
  padding:0.25rem 0.9rem;
  background:#ffffff;
  border:1px solid rgba(10,46,92,0.25);
  font-size:0.78rem;
  color:var(--navy);
  margin-bottom:0.5rem;
}

.class-title { margin:0 0 0.4rem; font-size:1.4rem; color:var(--navy-dark); }
.class-lead { margin:0 0 0.6rem; font-size:0.9rem; color:var(--muted); max-width:34rem; }
.class-points { margin:0; padding-left:1rem; font-size:0.86rem; color:var(--muted); }
.class-points li { margin-bottom:0.3rem; }

.class-cta-wrap { display:flex; flex-direction:column; align-items:center; gap:0.6rem; }
.class-highlight { font-size:0.85rem; color:var(--navy-dark); font-weight:600; align-items:center; }

.btn-outline {
  border-radius:999px;
  padding:0.7rem 1.4rem;
  border:1px solid var(--navy);
  background:#ffffff;
  font-size:0.86rem;
  font-weight:600;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--navy-dark);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:0.4rem;
  text-decoration:none;
  box-shadow:0 10px 28px rgba(9,31,65,0.18);
}
.btn-outline:hover { background:#f0f4ff; text-decoration:none; }

.class-note { font-size:0.78rem; color:var(--muted); }

/* VISIT SECTION */
.visit-section {
  border-radius:var(--radius-lg);
  background:linear-gradient(135deg,var(--navy-dark),#0d4f8c);
  padding:1.4rem 1.3rem 1.7rem;
  color:#f3f7ff;
  box-shadow:0 20px 60px rgba(3,15,34,0.7);
}

.visit-header {
  display:flex;
  justify-content:space-between;
  gap:1rem;
  align-items:flex-end;
  flex-wrap:wrap;
  margin-bottom:1.1rem;
}

.visit-header h2 { margin:0; font-size:1.35rem; }
.visit-header p { margin:0; font-size:0.86rem; max-width:26rem; }

.visit-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1rem; }

.world-card {
  border-radius:var(--radius-md);
  background:#ffffff;
  color:#141927;
  padding:0.85rem 0.9rem 1rem;
  box-shadow:0 14px 40px rgba(0,0,0,0.6);
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  gap:0.55rem;
}

.world-chip {
  position:absolute;
  top:0.6rem;
  right:0.75rem;
  font-size:0.72rem;
  text-transform:uppercase;
  letter-spacing:0.14em;
  padding:0.2rem 0.55rem;
  border-radius:999px;
  background:#f0f4ff;
  color:var(--navy);
}

.world-main { display:flex; gap:0.85rem; }
.world-thumb {
  width:110px;
  height:80px;
  border-radius:var(--radius-sm);
  overflow:hidden;
  background:#d0d8f3;
  flex-shrink:0;
}
.world-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.world-main h3 { margin:0 0 0.25rem; font-size:1rem; color:var(--navy-dark); }
.world-main p { margin:0; font-size:0.8rem; color:var(--muted); }
.world-meta { font-size:0.8rem; color:var(--muted); }

.btn-teleport {
  margin-top:0.4rem;
  border-radius:999px;
  padding:0.55rem 1.15rem;
  border:none;
  display:inline-flex;
  align-items:center;
  gap:0.4rem;
  background:linear-gradient(135deg,var(--navy),var(--navy-dark));
  color:#fff;
  font-size:0.8rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  font-weight:700;
  cursor:pointer;
  text-decoration:none;
  justify-content:center;
}
.btn-teleport:hover { text-decoration:none; box-shadow:0 12px 32px rgba(7,24,52,0.75); transform:translateY(-1px); }

/* GT SECTION */
.gt-section {
  margin-top:2.5rem;
  border-radius:var(--radius-md);
  border:1px dashed rgba(121,134,58,0.7);
  background:#f7fbf1;
  padding:1.1rem 1.2rem 1.3rem;
  display:flex;
  flex-wrap:wrap;
  gap:0.9rem;
  align-items:flex-start;
}

.gt-icon {
  width:46px;
  height:46px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 15%,#fff, #ffd54f);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  color:#5d4200;
  box-shadow:0 10px 24px rgba(116,96,0,0.55);
  flex-shrink:0;
}

.gt-content h3 { margin:0 0 0.4rem; font-size:1rem; color:var(--navy-dark); }
.gt-content p { margin:0 0 0.3rem; font-size:0.84rem; color:var(--muted); max-width:40rem; }

.gt-tags { display:flex; flex-wrap:wrap; gap:0.4rem; margin-top:0.2rem; }
.gt-tag {
  border-radius:999px;
  padding:0.2rem 0.7rem;
  background:#ffffff;
  border:1px solid rgba(139,152,64,0.55);
  font-size:0.78rem;
  color:#616b2a;
}

.gt-disclaimer { margin-top:0.35rem; font-size:0.74rem; color:#878f5e; }

/* FOOTER */
footer {
  margin-top:3rem;
  padding:1.4rem 1.2rem 1.6rem;
  border-top:1px solid var(--border);
  font-size:0.8rem;
  color:var(--muted);
  background:#ffffff;
}

.footer-inner {
  max-width:var(--max-width);
  margin:0 auto;
  display:flex;
  flex-wrap:wrap;
  gap:0.85rem;
  justify-content:space-between;
  align-items:flex-start;
}

.footer-inner strong { color:var(--navy-dark); }
.footer-links { display:flex; flex-wrap:wrap; gap:0.7rem; align-items:center; }
.footer-links a { font-size:0.8rem; color:var(--navy); }
.footer-notes { font-size:0.76rem; color:#9ca3b5; margin-top:0.25rem; }

@media (max-width: 800px) {
  .hero { min-height:68vh; }
  .site-nav { padding:0.5rem 0.8rem; }
  main { padding:1.7rem 0.9rem 2.6rem; }
  .class-card { grid-template-columns:1fr; }
}

@media (max-width: 640px) {
  .nav-inner { flex-wrap:wrap; justify-content:space-between; }
  .nav-links { display:none; }
  .filters-bar { padding:0.8rem 0.8rem 0.95rem; }
}
