:root {
  --f: #0e1f14;
  --fm: #172a1c;
  --fl: #1f3826;
  --fd: #081009;
  --fxl: #eef4f0;
  --g: #b08d57;
  --gl: #d4af70;
  --gd: #8a6c3e;
  --gxp: #faf7f0;
  --gp: #f5edda;
  --cr: #f7f3eb;
  --crd: #ede6d4;
  --bd: #ddd5c2;
  --w: #fff;
  --ink: #161616;
  --s: #3d3d3d;
  --m: #777;
  --li: #aaa;
  --red: #c0392b;
  --green: #1e7e34;
  --blue: #1a5276;
  --orange: #d35400;
  --purple: #6c3483;
  --teal: #0e6655;
  --sh0: 0 2px 10px rgba(14, 31, 20, .06);
  --sh1: 0 8px 32px rgba(14, 31, 20, .10);
  --sh2: 0 20px 60px rgba(14, 31, 20, .15);
  --sh3: 0 40px 90px rgba(14, 31, 20, .2);
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box
}

html {
  scroll-behavior: smooth
}

body {
  font-family: 'DM Sans', sans-serif;
  background: var(--cr);
  color: var(--ink);
  overflow-x: hidden
}

::selection {
  background: var(--g);
  color: #fff
}

::-webkit-scrollbar {
  width: 5px
}

::-webkit-scrollbar-thumb {
  background: var(--g);
  border-radius: 4px
}

a {
  text-decoration: none;
  color: inherit
}

img {
  max-width: 100%;
  display: block
}

button,
input,
select {
  font-family: 'DM Sans', sans-serif
}

.hide {
  display: none !important
}

/* ═══ NAV ═══ */
#nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 900;
  height: 62px;
  background: rgba(8, 16, 9, .96);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(176, 141, 87, .12)
}

.nav-in {
  max-width: 1440px;
  margin: 0 auto;
  height: 100%;
  display: flex;
  align-items: center;
  padding: 0 4vw;
  gap: 14px
}

.logo {
  font-family: 'Playfair Display', serif;
  font-size: 19px;
  font-weight: 500;
  color: #fff;
  cursor: pointer;
  flex-shrink: 0
}

.logo b {
  color: var(--gl);
  font-weight: 400;
  font-style: italic
}

.nav-links {
  display: flex;
  gap: 1px;
  margin: 0 auto
}

.nl {
  font-size: 12px;
  font-weight: 500;
  color: rgba(255, 255, 255, .4);
  padding: 6px 12px;
  border-radius: 4px;
  cursor: pointer;
  transition: .14s;
  white-space: nowrap
}

.nl:hover {
  color: #fff
}

.nl.act {
  color: var(--gl)
}

.nav-r {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-shrink: 0
}

.nb {
  background: var(--g);
  color: var(--f);
  padding: 7px 18px;
  border-radius: 5px;
  font-size: 12px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  transition: .2s
}

.nb:hover {
  background: var(--gl)
}

.nb-ghost {
  background: transparent;
  border: 1.5px solid rgba(176, 141, 87, .28);
  color: rgba(255, 255, 255, .55);
  padding: 6px 14px;
  border-radius: 5px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: .2s
}

.nb-ghost:hover {
  border-color: var(--gl);
  color: var(--gl)
}

/* ═══ HERO ═══ */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  background: var(--fd);
  overflow: hidden;
  padding-top: 62px
}

.hero-bg {
  position: absolute;
  inset: 0;
  background: url('https://images.unsplash.com/photo-1570458436416-b8fcccfe883f?w=1920&q=80') center/cover;
  opacity: .14;
  transform: scale(1.05)
}

.hero-grid {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(176, 141, 87, .04) 1px, transparent 1px), linear-gradient(90deg, rgba(176, 141, 87, .04) 1px, transparent 1px);
  background-size: 60px 60px
}

.hero-grad {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 40%;
  background: linear-gradient(to top, var(--fd), transparent)
}

.hero-in {
  position: relative;
  z-index: 2;
  max-width: 1440px;
  margin: 0 auto;
  padding: 80px 5vw 100px;
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 60px;
  align-items: center
}

.hero-left {}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(176, 141, 87, .1);
  border: 1px solid rgba(176, 141, 87, .2);
  color: var(--gl);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 20px;
  margin-bottom: 24px
}

.hero-h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(44px, 6vw, 88px);
  font-weight: 400;
  color: #fff;
  line-height: 1.02;
  letter-spacing: -2px;
  margin-bottom: 20px
}

.hero-h1 em {
  font-style: italic;
  color: var(--gl)
}

.hero-h1 span {
  display: block;
  font-size: .55em;
  font-weight: 300;
  letter-spacing: -1px;
  color: rgba(255, 255, 255, .35);
  margin-top: 6px
}

.hero-sub {
  font-size: 15px;
  color: rgba(255, 255, 255, .36);
  line-height: 1.85;
  font-weight: 300;
  max-width: 540px;
  margin-bottom: 36px
}

.hero-stats {
  display: flex;
  gap: 32px;
  flex-wrap: wrap
}

.hstat {
  display: flex;
  flex-direction: column;
  gap: 3px
}

.hstat-n {
  font-family: 'Playfair Display', serif;
  font-size: 32px;
  color: var(--gl);
  font-weight: 400;
  line-height: 1
}

.hstat-l {
  font-size: 10px;
  font-weight: 700;
  color: rgba(255, 255, 255, .3);
  letter-spacing: 2px;
  text-transform: uppercase
}

/* Map / Right visual */
.hero-right {
  position: relative
}

.hero-map-card {
  background: rgba(255, 255, 255, .03);
  border: 1px solid rgba(176, 141, 87, .14);
  border-radius: 16px;
  padding: 28px;
  backdrop-filter: blur(10px)
}

.hmc-title {
  font-family: 'Playfair Display', serif;
  font-size: 16px;
  color: var(--gl);
  margin-bottom: 16px;
  font-weight: 400;
  font-style: italic
}

.mh-map-svg {
  width: 100%;
  height: auto;
  opacity: .72
}

.hero-legend {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 16px
}

.hl-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11.5px;
  color: rgba(255, 255, 255, .45)
}

.hl-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  flex-shrink: 0
}

/* ═══ STICKY FILTER BAR ═══ */
.filter-bar {
  position: sticky;
  top: 102px;
  z-index: 800;
  background: rgba(8, 16, 9, .95);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(176, 141, 87, .1);
  padding: 0 5vw
}

.fb-in {
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 4px;
  overflow-x: auto;
  padding: 10px 0;
  scrollbar-width: none
}

.fb-in::-webkit-scrollbar {
  display: none
}

.fb-all {
  font-size: 11.5px;
  font-weight: 700;
  padding: 7px 16px;
  border-radius: 20px;
  border: 1.5px solid var(--g);
  background: var(--g);
  color: var(--f);
  cursor: pointer;
  white-space: nowrap;
  transition: .18s;
  flex-shrink: 0
}

.fb-btn {
  font-size: 11.5px;
  font-weight: 600;
  padding: 7px 16px;
  border-radius: 20px;
  border: 1.5px solid rgba(255, 255, 255, .1);
  color: rgba(255, 255, 255, .44);
  cursor: pointer;
  white-space: nowrap;
  transition: .18s;
  background: transparent;
  flex-shrink: 0
}

.fb-btn:hover {
  border-color: rgba(176, 141, 87, .38);
  color: rgba(255, 255, 255, .78)
}

.fb-btn.on {
  border-color: var(--g);
  background: rgba(176, 141, 87, .12);
  color: var(--gl)
}

.fb-search {
  margin-left: auto;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, .07);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 20px;
  padding: 0 14px;
  height: 34px
}

.fb-search input {
  background: transparent;
  border: none;
  color: #fff;
  font-size: 12.5px;
  outline: none;
  width: 160px
}

.fb-search input::placeholder {
  color: rgba(255, 255, 255, .28)
}

/* ═══ SECTION HEADERS ═══ */
.section-header {
  max-width: 1440px;
  margin: 0 auto;
  padding: 60px 5vw 36px
}

.sh-kicker {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--g);
  margin-bottom: 10px
}

.sh-h {
  font-family: 'Playfair Display', serif;
  font-size: clamp(28px, 3.5vw, 46px);
  font-weight: 400;
  color: var(--f);
  letter-spacing: -1px;
  line-height: 1.1
}

.sh-h em {
  font-style: italic;
  color: var(--gd)
}

.sh-sub {
  font-size: 14px;
  color: var(--m);
  line-height: 1.8;
  font-weight: 300;
  max-width: 580px;
  margin-top: 8px
}

/* ═══ CITY GRID ═══ */
.city-grid-wrap {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 5vw 80px
}

.city-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: 20px
}

/* ═══ CITY CARD ═══ */
.ccard {
  background: var(--w);
  border: 1px solid var(--bd);
  border-radius: 16px;
  overflow: hidden;
  transition: .3s;
  cursor: pointer
}

.ccard:hover {
  transform: translateY(-5px);
  box-shadow: var(--sh2);
  border-color: rgba(176, 141, 87, .3)
}

.ccard.featured {
  border-color: rgba(176, 141, 87, .3);
  box-shadow: 0 0 0 1px rgba(176, 141, 87, .08)
}

.cc-img {
  position: relative;
  height: 200px;
  overflow: hidden;
  background: var(--fxl)
}

.cc-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.78) saturate(.9);
  transition: .55s
}

.ccard:hover .cc-img img {
  transform: scale(1.07);
  filter: brightness(.65)
}

.cc-region {
  position: absolute;
  top: 12px;
  left: 12px;
  display: flex;
  gap: 5px;
  z-index: 2;
  flex-wrap: wrap
}

.cc-reg-pill {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 18px;
  backdrop-filter: blur(6px)
}

.cc-score {
  position: absolute;
  top: 12px;
  right: 12px;
  background: rgba(14, 31, 20, .85);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(176, 141, 87, .25);
  border-radius: 8px;
  padding: 6px 11px;
  z-index: 2;
  text-align: center
}

.cc-score-n {
  font-family: 'Playfair Display', serif;
  font-size: 22px;
  color: var(--gl);
  line-height: 1;
  font-weight: 400
}

.cc-score-l {
  font-size: 8.5px;
  font-weight: 700;
  color: rgba(255, 255, 255, .4);
  letter-spacing: 1px;
  text-transform: uppercase
}

.cc-city-tag {
  position: absolute;
  bottom: 12px;
  left: 12px;
  background: rgba(8, 16, 9, .88);
  backdrop-filter: blur(8px);
  color: #fff;
  font-family: 'Playfair Display', serif;
  font-size: 22px;
  font-weight: 400;
  padding: 7px 14px;
  border-radius: 9px;
  z-index: 2;
  border: 1px solid rgba(255, 255, 255, .1);
  line-height: 1.2
}

.cc-city-tag small {
  font-size: 10px;
  color: rgba(255, 255, 255, .4);
  font-family: 'DM Sans', sans-serif;
  display: block;
  margin-top: 2px;
  line-height: 1
}

/* Card body */
.cc-body {
  padding: 18px 20px 0
}

.cc-tagline {
  font-family: 'Playfair Display', serif;
  font-size: 13px;
  font-style: italic;
  color: var(--gd);
  margin-bottom: 10px;
  font-weight: 400
}

.cc-desc {
  font-size: 13px;
  color: var(--s);
  line-height: 1.75;
  font-weight: 300;
  margin-bottom: 14px
}

/* Info pills row */
.cc-pills {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  margin-bottom: 14px
}

.cc-pill {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 18px;
  letter-spacing: .3px
}

/* Data grid */
.cc-data {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 14px
}

.ccd {
  background: var(--cr);
  border-radius: 8px;
  padding: 9px 12px
}

.ccd-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--m);
  margin-bottom: 3px
}

.ccd-val {
  font-size: 13px;
  font-weight: 700;
  color: var(--f)
}

.ccd-val.big {
  font-family: 'Playfair Display', serif;
  font-size: 17px;
  font-weight: 400
}

/* Expandable sections */
.cc-expand {
  border-top: 1px solid var(--bd);
  overflow: hidden;
  max-height: 0;
  transition: max-height .4s ease
}

.cc-expand.open {
  max-height: 900px
}

.cc-expand-body {
  padding: 16px 20px 18px
}

.ce-section {
  margin-bottom: 14px
}

.ce-section:last-child {
  margin-bottom: 0
}

.ce-title {
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--g);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 6px
}

.ce-list {
  display: flex;
  flex-direction: column;
  gap: 5px
}

.ce-item {
  font-size: 12.5px;
  color: var(--s);
  display: flex;
  align-items: flex-start;
  gap: 7px;
  line-height: 1.6
}

.ce-item::before {
  content: '→';
  color: var(--g);
  font-size: 11px;
  flex-shrink: 0;
  margin-top: 2px
}

.ce-tags {
  display: flex;
  gap: 5px;
  flex-wrap: wrap
}

.ce-tag {
  font-size: 11px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 6px;
  background: var(--fxl);
  color: var(--fl)
}

/* Growth bar */
.growth-bar {
  background: var(--crd);
  border-radius: 20px;
  height: 6px;
  overflow: hidden;
  margin-top: 4px
}

.growth-fill {
  height: 100%;
  border-radius: 20px;
  background: linear-gradient(90deg, var(--g), var(--gl))
}

/* Card footer */
.cc-foot {
  border-top: 1px solid var(--bd);
  padding: 13px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between
}

.cc-price-range {
  font-family: 'Playfair Display', serif;
  font-size: 15px;
  color: var(--f);
  font-weight: 400
}

.cc-price-range small {
  font-size: 10px;
  color: var(--m);
  font-family: 'DM Sans', sans-serif;
  display: block;
  line-height: 1.4
}

.cc-cta {
  background: var(--f);
  color: #fff;
  padding: 8px 18px;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  transition: .18s;
  display: flex;
  align-items: center;
  gap: 5px
}

.cc-cta:hover {
  background: var(--fl)
}

.cc-more {
  background: transparent;
  color: var(--g);
  border: 1.5px solid var(--bd);
  padding: 7px 14px;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: .18s;
  display: flex;
  align-items: center;
  gap: 5px
}

.cc-more:hover {
  border-color: var(--g);
  background: var(--gxp)
}

.cc-more-arrow {
  transition: .3s;
  display: inline-block
}

.cc-expand.open~.cc-foot .cc-more-arrow {
  transform: rotate(180deg)
}

/* ═══ REGION LEGEND ═══ */
.region-overview {
  background: var(--f);
  padding: 72px 5vw;
  position: relative;
  overflow: hidden
}

.region-overview::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('https://images.unsplash.com/photo-1506905925346-21bda4d32df4?w=1920&q=80') center/cover;
  opacity: .06
}

.ro-in {
  max-width: 1440px;
  margin: 0 auto;
  position: relative;
  z-index: 1
}

.ro-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(26px, 3.5vw, 46px);
  color: #fff;
  font-weight: 400;
  letter-spacing: -1px;
  margin-bottom: 8px
}

.ro-title em {
  font-style: italic;
  color: var(--gl)
}

.ro-sub {
  font-size: 13.5px;
  color: rgba(255, 255, 255, .34);
  font-weight: 300;
  margin-bottom: 40px
}

.regions-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px
}

.rg-card {
  background: rgba(255, 255, 255, .04);
  border: 1px solid rgba(255, 255, 255, .07);
  border-radius: 12px;
  padding: 22px;
  transition: .24s
}

.rg-card:hover {
  background: rgba(255, 255, 255, .07);
  border-color: rgba(176, 141, 87, .2)
}

.rg-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-bottom: 12px
}

.rg-name {
  font-family: 'Playfair Display', serif;
  font-size: 18px;
  color: #fff;
  font-weight: 400;
  margin-bottom: 5px
}

.rg-count {
  font-size: 10.5px;
  font-weight: 700;
  color: rgba(255, 255, 255, .26);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 10px
}

.rg-desc {
  font-size: 12.5px;
  color: rgba(255, 255, 255, .4);
  line-height: 1.72;
  font-weight: 300
}

.rg-pills {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  margin-top: 10px
}

.rg-pill {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  background: rgba(255, 255, 255, .06);
  color: rgba(255, 255, 255, .4)
}

/* ═══ COMPARISON TABLE ═══ */
.compare-section {
  background: var(--w);
  padding: 72px 5vw;
  border-top: 1px solid var(--bd)
}

.cs-in {
  max-width: 1440px;
  margin: 0 auto
}

.table-wrap {
  overflow-x: auto;
  border-radius: 12px;
  border: 1px solid var(--bd);
  box-shadow: var(--sh0)
}

.cmp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
  min-width: 960px
}

.cmp-table thead {
  background: var(--f)
}

.cmp-table thead th {
  padding: 13px 16px;
  text-align: left;
  color: rgba(255, 255, 255, .4);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  white-space: nowrap
}

.cmp-table tbody tr {
  border-bottom: 1px solid var(--bd);
  transition: .12s
}

.cmp-table tbody tr:last-child {
  border-bottom: none
}

.cmp-table tbody tr:hover {
  background: var(--gxp)
}

.cmp-table td {
  padding: 12px 16px;
  vertical-align: middle;
  color: var(--s)
}

.ct-city {
  font-weight: 700;
  color: var(--f);
  font-size: 13.5px
}

.ct-price {
  font-family: 'Playfair Display', serif;
  font-size: 14px;
  color: var(--f)
}

.ct-roi {
  font-weight: 700;
  color: var(--green)
}

.ct-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 10px
}

.ct-stars {
  color: var(--g);
  letter-spacing: 2px
}

.bar-mini {
  height: 5px;
  border-radius: 3px;
  background: var(--crd);
  overflow: hidden;
  min-width: 80px
}

.bar-fill {
  height: 100%;
  border-radius: 3px;
  background: linear-gradient(90deg, var(--g), var(--gl))
}

/* ═══ INVESTMENT INSIGHTS ═══ */
.insights-section {
  padding: 72px 5vw;
  background: var(--cr)
}

.ins-in {
  max-width: 1440px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px
}

.ins-card {
  background: var(--w);
  border: 1px solid var(--bd);
  border-radius: 14px;
  padding: 28px;
  transition: .24s
}

.ins-card:hover {
  box-shadow: var(--sh1);
  border-color: rgba(176, 141, 87, .24)
}

.ins-card.dark {
  background: var(--f);
  border-color: transparent
}

.ins-ico {
  font-size: 32px;
  margin-bottom: 14px
}

.ins-title {
  font-family: 'Playfair Display', serif;
  font-size: 21px;
  font-weight: 400;
  color: var(--f);
  margin-bottom: 8px
}

.ins-card.dark .ins-title {
  color: #fff
}

.ins-desc {
  font-size: 13.5px;
  color: var(--m);
  line-height: 1.8;
  font-weight: 300;
  margin-bottom: 16px
}

.ins-card.dark .ins-desc {
  color: rgba(255, 255, 255, .38)
}

.ins-list {
  display: flex;
  flex-direction: column;
  gap: 8px
}

.ins-li {
  font-size: 12.5px;
  color: var(--s);
  display: flex;
  align-items: flex-start;
  gap: 8px;
  line-height: 1.6
}

.ins-card.dark .ins-li {
  color: rgba(255, 255, 255, .52)
}

.ins-li::before {
  content: '✓';
  color: var(--g);
  font-weight: 700;
  flex-shrink: 0
}

/* ═══ CTA STRIP ═══ */
.cta-strip {
  background: var(--f);
  padding: 80px 5vw;
  text-align: center;
  position: relative;
  overflow: hidden
}

.cta-strip::after {
  content: 'INVEST';
  position: absolute;
  right: -10px;
  bottom: -30px;
  font-family: 'Playfair Display', serif;
  font-size: 160px;
  color: rgba(255, 255, 255, .02);
  pointer-events: none;
  font-style: italic
}

.cta-strip-in {
  max-width: 700px;
  margin: 0 auto;
  position: relative;
  z-index: 1
}

.cta-strip-in h2 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(28px, 4vw, 50px);
  font-weight: 400;
  color: #fff;
  letter-spacing: -1px;
  margin-bottom: 12px
}

.cta-strip-in h2 em {
  font-style: italic;
  color: var(--gl)
}

.cta-strip-in p {
  font-size: 14px;
  color: rgba(255, 255, 255, .36);
  line-height: 1.8;
  font-weight: 300;
  margin-bottom: 28px
}

.cta-btns {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap
}

.btn-main {
  background: var(--g);
  color: var(--f);
  padding: 14px 32px;
  border-radius: 7px;
  font-size: 14px;
  font-weight: 800;
  border: none;
  cursor: pointer;
  transition: .2s
}

.btn-main:hover {
  background: var(--gl);
  transform: translateY(-1px);
  box-shadow: 0 10px 28px rgba(176, 141, 87, .28)
}

.btn-sec {
  background: transparent;
  color: rgba(255, 255, 255, .52);
  border: 1.5px solid rgba(255, 255, 255, .14);
  padding: 13px 26px;
  border-radius: 7px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: .2s
}

.btn-sec:hover {
  color: #fff;
  border-color: rgba(255, 255, 255, .32)
}

/* ═══ FOOTER ═══ */
footer {
  background: var(--fd);
  padding: 40px 5vw;
  border-top: 1px solid rgba(176, 141, 87, .08);
  text-align: center
}

footer p {
  font-size: 12.5px;
  color: rgba(255, 255, 255, .2);
  font-weight: 300
}

footer span {
  color: var(--g)
}

/* ═══ FLOAT WA ═══ */
.flt-wa {
  position: fixed;
  right: 22px;
  bottom: 22px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #25d366;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 21px;
  box-shadow: 0 6px 22px rgba(37, 211, 102, .38);
  cursor: pointer;
  z-index: 700;
  animation: waBeat 3s infinite
}

@keyframes waBeat {

  0%,
  100% {
    box-shadow: 0 6px 20px rgba(37, 211, 102, .32)
  }

  50% {
    box-shadow: 0 6px 32px rgba(37, 211, 102, .55)
  }
}

/* Toast */
#toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(14px);
  z-index: 2000;
  background: var(--f);
  color: #fff;
  padding: 11px 20px;
  border-radius: 8px;
  font-size: 12.5px;
  font-weight: 600;
  box-shadow: var(--sh2);
  opacity: 0;
  transition: .28s;
  white-space: nowrap;
  pointer-events: none;
  border-left: 3px solid var(--g)
}

#toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0)
}

/* Scroll reveal */
.rv {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .7s ease, transform .7s ease
}

.rv.visible {
  opacity: 1;
  transform: none
}

/* Responsive */
@media(max-width:1100px) {
  .hero-in {
    grid-template-columns: 1fr
  }

  .hero-right {
    display: none
  }

  .ins-in {
    grid-template-columns: 1fr
  }
}

@media(max-width:768px) {
  .nav-links {
    display: none
  }

  .city-grid {
    grid-template-columns: 1fr
  }

  .regions-grid {
    grid-template-columns: 1fr 1fr
  }
}

@media(max-width:480px) {
  .regions-grid {
    grid-template-columns: 1fr
  }
}