:root {
  --navy: #0A1338;
  --navy-dark: #00020D;
  --navy-mid: #21263B;
  --gold: #D9B300;
  --gold-strong: #FFD200;
  --ink: #040A21;
  --muted: #505050;
  --line: #cacaca;
  --paper: #ffffff;
  --soft: #F8F8F8;
  --steel: #2D3454;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { color: var(--ink); font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; background: var(--paper); }
a { color: inherit; }
img { max-width: 100%; display: block; }
.skip-link { position: absolute; left: -999px; top: 1rem; z-index: 2000; background: var(--gold); color: var(--navy); padding: .6rem .9rem; }
.skip-link:focus { left: 1rem; }

.site-nav {
  position: fixed;
  top: 8px;
  left: 0;
  right: 0;
  z-index: 1030;
  padding: 0;
  background: transparent;
  pointer-events: none;
}
.site-nav > .container-xl { pointer-events: auto; }
.nav-shell {
  width: 100%;
  min-height: 72px;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 10px 24px;
  background-color: #0A1338;
  background-image: none;
  backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 16px;
  box-shadow: 0 18px 44px rgba(4,10,33,.24);
}
.navbar-brand { display: flex; align-items: center; flex: 0 0 214px; width: 214px; padding: .35rem 0; margin: 0; color: #fff; contain: layout paint; }
.navbar-brand:hover { color: #fff; }
.brand-logo-img { width: 214px; height: auto; max-height: 54px; object-fit: contain; transform: translateZ(0); backface-visibility: hidden; }
.site-nav .navbar-collapse { align-items: center; }
.site-nav .navbar-nav { gap: .28rem; }
.site-nav .nav-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: .42rem;
  color: rgba(255,255,255,.9);
  font-size: .86rem;
  font-weight: 650;
  line-height: 1;
  letter-spacing: 0;
  text-transform: uppercase;
  padding: .95rem .68rem;
}
.site-nav .nav-link i { color: currentColor; font-size: .9rem; }
.site-nav .dropdown-toggle::after { display: none; }
.site-nav .nav-caret { font-size: .68rem; margin-left: .08rem; flex: 0 0 auto; }
.site-nav .nav-link:hover,
.site-nav .nav-link:focus,
.site-nav .nav-link.show,
.site-nav .nav-link[aria-expanded="true"],
.site-nav .nav-link.active {
  color: var(--gold-strong);
}
.site-nav .nav-link.active::after {
  content: "";
  position: absolute;
  left: .68rem;
  right: .68rem;
  bottom: .38rem;
  height: 2px;
  background: var(--gold);
  box-shadow: 0 0 18px rgba(217,179,0,.72);
}
.navbar-toggler {
  margin-left: auto;
  border: 1px solid rgba(217,179,0,.38);
  border-radius: 8px;
  padding: .58rem .68rem;
}
.navbar-toggler:focus { box-shadow: 0 0 0 .2rem rgba(217,179,0,.22); }
.navbar-toggler-icon { filter: invert(1); width: 1.2em; height: 1.2em; }
.dropdown-menu {
  margin-top: 0;
  padding: .45rem;
  border-radius: 8px;
  border: 1px solid rgba(217,179,0,.28);
  background: rgba(255,255,255,.98);
  box-shadow: 0 20px 45px rgba(4,10,33,.28);
}
.dropdown-item {
  border-radius: 6px;
  color: var(--ink);
  font-size: .9rem;
  font-weight: 750;
  padding: .62rem .75rem;
}
.dropdown-item:active, .dropdown-item:hover { background: var(--gold); color: var(--navy-dark); }
.nav-actions { display: flex; align-items: center; gap: .75rem; margin-left: 1rem; }
.site-nav .dropdown { padding-bottom: .55rem; margin-bottom: -.55rem; }
.nav-phone {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  min-height: 38px;
  padding: .42rem .74rem;
  border: 1px solid rgba(217,179,0,.38);
  border-radius: 999px;
  color: #fff;
  font-size: .8rem;
  font-weight: 850;
  text-decoration: none;
  white-space: nowrap;
}
.nav-phone i { color: var(--gold); }
.nav-phone:hover { color: var(--gold-strong); border-color: rgba(217,179,0,.72); }
.nav-sign-in {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: .42rem .9rem;
  border: 1px solid rgba(217,179,0,.38);
  border-radius: 999px;
  background: rgba(217,179,0,.08);
  color: var(--gold);
  font-size: .8rem;
  font-weight: 850;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
}
.nav-sign-in:hover, .nav-sign-in:focus, .nav-sign-in.active { background: var(--gold); border-color: var(--gold); color: var(--navy-dark); }

.btn { border-radius: 6px; font-weight: 750; padding: .85rem 1.05rem; display: inline-flex; align-items: center; gap: .45rem; }
.btn-gold { background: var(--gold); border-color: var(--gold); color: var(--navy); }
.btn-gold:hover { background: var(--gold-strong); border-color: var(--gold-strong); color: var(--navy); }
.btn-outline-light { border-color: rgba(255,255,255,.55); color: #fff; }
.btn-outline-light:hover { background: #fff; color: var(--navy); }
.btn-outline-navy { border: 1px solid var(--navy); color: var(--navy); }
.btn-outline-navy:hover { background: var(--navy); color: #fff; }
.text-link { color: var(--navy); font-weight: 800; text-decoration: none; }
.text-link:hover { color: #846c00; }

.hero { position: relative; overflow: hidden; background-color: #f1e8d4; background-image: radial-gradient(circle at 76% 20%, rgba(255,255,255,.38), transparent 34%), radial-gradient(circle at 10% 84%, rgba(10,19,56,.08), transparent 30%), linear-gradient(90deg, rgba(255,255,255,.58), rgba(255,255,255,.08)); background-size: 100% 100%; color: #071334; padding: clamp(8rem, 11vw, 10rem) 0 4.5rem; }
.hero-soft-steel {
  isolation: isolate;
  color: var(--fx-text, #071334);
  background: var(--fx-bg, linear-gradient(135deg, #d9e1e7 0%, #b7c7d3 100%));
}
.hero-soft-steel::before,
.hero-soft-steel::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.hero-soft-steel::before {
  z-index: -2;
  opacity: var(--fx-pattern-opacity, .75);
  background-image: var(--fx-pattern, none);
  background-size: var(--fx-pattern-size, 100% 100%);
  animation: var(--fx-animation, fx-float-soft 22s ease-in-out infinite alternate);
}
.hero-soft-steel::after {
  z-index: -1;
  background: var(--fx-wash, linear-gradient(90deg, rgba(255,255,255,.5), rgba(255,255,255,.1)));
}
.hero-soft-steel > .container-xl { position: relative; z-index: 1; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(320px, .75fr); gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.eyebrow { color: var(--gold); font-size: .78rem; font-weight: 850; letter-spacing: .12em; text-transform: uppercase; margin-bottom: .75rem; }
.hero h1, .page-hero h1 { font-size: clamp(2.35rem, 5.2vw, 5rem); line-height: .98; letter-spacing: 0; font-weight: 850; max-width: 920px; }
.hero .lead { color: rgba(255,255,255,.82); max-width: 680px; margin: 1.25rem 0 0; font-size: clamp(1.05rem, 1.4vw, 1.25rem); }
.hero-soft-steel .lead { color: var(--fx-muted, #43505b); }
.hero-home h1 { font-size: clamp(2.1rem, 4vw, 3.75rem); line-height: 1.06; max-width: 820px; }
.hero-soft-steel .btn-outline-light {
  border-color: var(--fx-outline-border, rgba(7,19,52,.42));
  color: var(--fx-outline, #071334);
}
.hero-soft-steel .btn-outline-light:hover { background: var(--fx-outline, #071334); color: var(--fx-outline-hover-text, #fff); }

.hero-actions { display: flex; gap: .8rem; flex-wrap: wrap; margin-top: 2rem; }
.hero-property-panel {
  background: #fff;
  color: var(--ink);
  border: 1px solid rgba(255,255,255,.35);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 28px 70px rgba(0,0,0,.28);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.hero-soft-steel .hero-property-panel {
  border-color: rgba(7,19,52,.1);
  box-shadow: 0 28px 70px rgba(4,10,33,.18);
}
.hero-property-panel:hover { transform: translateY(-4px); box-shadow: 0 34px 80px rgba(0,0,0,.34); border-color: rgba(217,179,0,.55); }
.hero-soft-steel .hero-property-panel:hover { box-shadow: 0 34px 80px rgba(4,10,33,.24); }
.hero-property-image { position: relative; display: block; overflow: hidden; color: inherit; }
.hero-property-panel img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; transition: transform .35s ease; }
.hero-property-panel:hover img { transform: scale(1.035); }
.hero-property-content { padding: 1.25rem 1.25rem 1.35rem; }
.hero-property-panel h2 { margin: .35rem 0 .45rem; font-size: clamp(1.25rem, 1.7vw, 1.55rem); line-height: 1.18; color: var(--navy); font-weight: 800; }
.hero-property-panel h2 a { color: inherit; text-decoration: none; }
.hero-property-panel p { margin: 0 0 1rem; color: var(--muted); font-size: .98rem; line-height: 1.55; }
.panel-label { position: absolute; left: 1rem; top: 1rem; display: inline-flex; align-items: center; min-height: 30px; padding: .4rem .65rem; border-radius: 999px; background: var(--gold); color: var(--navy-dark); font-size: .72rem; font-weight: 850; letter-spacing: .05em; text-transform: uppercase; box-shadow: 0 10px 24px rgba(4,10,33,.18); }

.page-hero {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: linear-gradient(180deg, #6e8290 0%, #2b4053 58%, #12243a 100%);
  color: #fff;
  padding: clamp(7rem, 9vw, 9rem) 0 clamp(3.5rem, 7vw, 6rem);
}
.page-hero::before,
.page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.page-hero::before {
  z-index: 0;
  opacity: .75;
  background-image: linear-gradient(180deg, transparent 0%, rgba(255,255,255,.14) 46%, transparent 72%);
  background-size: 100% 180%;
  animation: fx-horizon 22s ease-in-out infinite alternate;
}
.page-hero::after {
  z-index: 0;
  background: linear-gradient(90deg, rgba(4,10,33,.36), rgba(4,10,33,.02));
}
.page-hero > .container-xl { position: relative; z-index: 1; }
.properties-hero { min-height: clamp(24rem, 34vw, 28rem); display: flex; align-items: center; }
.compact-hero p:not(.eyebrow) { max-width: 780px; color: rgba(255,255,255,.82); font-size: 1.12rem; }
.section { padding: clamp(3.5rem, 7vw, 6rem) 0; }
.section-compact { padding-top: clamp(2.5rem, 5vw, 4rem); }
.band-light { background: var(--soft); }
.section-heading { margin-bottom: 2rem; }
.section-heading h2 { color: var(--navy); font-size: clamp(2rem, 3vw, 3.1rem); line-height: 1.05; font-weight: 850; }
.home-section-heading h2 { font-size: clamp(1.6rem, 2.4vw, 2.48rem); }
.section-heading p { color: var(--muted); max-width: 720px; }
.split-heading { display: flex; justify-content: space-between; gap: 1.5rem; align-items: end; }
.centered { text-align: center; max-width: 760px; margin-left: auto; margin-right: auto; }
.centered p { margin-left: auto; margin-right: auto; }

.property-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1.25rem; }
.property-card { border: 1px solid var(--line); border-radius: 8px; overflow: hidden; background: #fff; display: grid; grid-template-columns: minmax(220px, .86fr) 1fr; min-height: 300px; transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease; }
.property-card[hidden] { display: none; }
.property-card-image { position: relative; min-height: 100%; background: var(--soft); }
.property-card-image img { width: 100%; height: 100%; min-height: 300px; object-fit: cover; transition: transform .35s ease; }
.property-card-image span { position: absolute; left: .9rem; top: .9rem; background: var(--gold); color: var(--navy-dark); padding: .42rem .62rem; border-radius: 4px; font-size: .75rem; font-weight: 850; text-transform: uppercase; }
.property-card-body { padding: 1.35rem; display: flex; flex-direction: column; }
.property-card:hover { transform: translateY(-4px); border-color: rgba(217,179,0,.65); box-shadow: 0 22px 52px rgba(4,10,33,.14); }
.property-card:hover .property-card-image img { transform: scale(1.035); }
.property-card-kicker { color: #846c00; text-transform: uppercase; font-weight: 850; font-size: .72rem; letter-spacing: .08em; line-height: 1.2; }
.property-card h3 { font-size: clamp(1.25rem, 1.7vw, 1.55rem); line-height: 1.18; margin: .42rem 0 .45rem; color: var(--navy); font-weight: 800; }
.property-card h3 a { text-decoration: none; }
.property-card p { color: var(--muted); font-size: .98rem; line-height: 1.55; }
.property-card dl { display: grid; grid-template-columns: repeat(3, 1fr); gap: .65rem; margin: auto 0 1rem; }
.property-card dt { font-size: .7rem; text-transform: uppercase; color: var(--muted); }
.property-card dd { margin: 0; color: var(--navy); font-weight: 800; }

.opportunity-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.opportunity-grid > div { background: #fff; border: 1px solid var(--line); padding: 1.4rem; border-radius: 8px; transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease; }
.opportunity-grid > div:hover { transform: translateY(-4px); border-color: rgba(217,179,0,.65); box-shadow: 0 18px 45px rgba(4,10,33,.12); }
.opportunity-grid i { color: var(--gold); font-size: 1.7rem; margin-bottom: 1rem; }
.opportunity-grid h3 { color: var(--navy); font-size: 1.22rem; line-height: 1.2; font-weight: 800; }
.opportunity-grid p { color: var(--muted); font-size: .98rem; line-height: 1.58; }

.filter-bar { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.filter-button { border: 1px solid var(--line); background: #fff; color: var(--navy); border-radius: 999px; padding: .55rem .95rem; font-weight: 800; }
.filter-button.active, .filter-button:hover { border-color: var(--gold); background: rgba(217,179,0,.18); color: var(--navy-dark); }

.property-detail-hero { background: var(--soft); padding: 7.25rem 0 1.5rem; border-bottom: 1px solid var(--line); }
.breadcrumb-lite { color: var(--muted); margin-bottom: 1.35rem; }
.breadcrumb-lite a { color: var(--navy); font-weight: 800; text-decoration: none; }
.property-title-grid { display: flex; justify-content: space-between; gap: 1rem; align-items: end; }
.property-title-grid h1 { color: var(--navy); font-size: clamp(2.2rem, 4vw, 4rem); font-weight: 850; }
.property-title-actions { display: flex; flex-direction: column; align-items: flex-end; gap: .8rem; }
.page-share { display: inline-flex; align-items: center; gap: .48rem; color: var(--navy); }
.page-share span { margin-right: .1rem; color: var(--muted); font-size: .76rem; font-weight: 850; letter-spacing: .08em; line-height: 1; text-transform: uppercase; }
.page-share a { width: 38px; height: 38px; display: grid; place-items: center; border: 1px solid rgba(10,19,56,.2); border-radius: 999px; background: #fff; color: var(--navy); text-decoration: none; transition: background-color .18s ease, border-color .18s ease, color .18s ease, transform .18s ease; }
.page-share a:hover, .page-share a:focus { border-color: var(--gold); background: var(--gold); color: var(--navy-dark); transform: translateY(-1px); }
.property-layout { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 1.5rem; align-items: start; }
.gallery-main { border-radius: 8px; overflow: hidden; background: var(--soft); border: 1px solid var(--line); }
.gallery-main img { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; }
.gallery-thumbs { display: grid; grid-template-columns: repeat(5, 1fr); gap: .55rem; margin-top: .65rem; }
.gallery-thumbs button { padding: 0; border: 2px solid transparent; border-radius: 6px; overflow: hidden; background: transparent; }
.gallery-thumbs button.active { border-color: var(--gold); }
.gallery-thumbs img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.detail-copy { margin-top: 2rem; font-size: 1.05rem; line-height: 1.75; }
.detail-copy h2, .facts-panel h2, .realtor-panel h2 { color: var(--navy); font-weight: 850; }
.property-sidebar { position: sticky; top: 92px; display: grid; gap: 1rem; }
.facts-panel, .realtor-panel, .contact-panel, .contact-form, .article-cta { border: 1px solid var(--line); border-radius: 8px; background: #fff; padding: 1.35rem; }
.facts-panel dl { margin: 0; }
.facts-panel div { display: flex; justify-content: space-between; gap: 1rem; border-bottom: 1px solid var(--line); padding: .75rem 0; }
.facts-panel div:last-child { border-bottom: 0; }
.facts-panel dt { color: var(--muted); }
.facts-panel dd { margin: 0; color: var(--navy); font-weight: 800; text-align: right; }
.realtor-panel a, .realtor-panel span, .contact-panel a, .contact-panel span { display: flex; gap: .55rem; align-items: center; margin-top: .65rem; text-decoration: none; color: var(--navy); font-weight: 750; }

.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.blog-grid-wide { grid-template-columns: repeat(2, 1fr); }
.blog-card { border: 1px solid var(--line); border-radius: 8px; overflow: hidden; background: #fff; display: flex; flex-direction: column; transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease; }
.blog-card:hover { transform: translateY(-4px); border-color: rgba(217,179,0,.65); box-shadow: 0 22px 52px rgba(4,10,33,.14); }
.blog-card-image { display: block; overflow: hidden; }
.blog-card-image img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; transition: transform .35s ease; }
.blog-card:hover .blog-card-image img { transform: scale(1.035); }
.blog-card-body { padding: 1.25rem; }
.blog-card-body span { color: #846c00; font-weight: 850; text-transform: uppercase; font-size: .72rem; letter-spacing: .08em; line-height: 1.2; }
.blog-card-date, .article-date { display: block; color: var(--muted); font-size: .86rem; font-weight: 750; letter-spacing: 0; text-transform: none; }
.blog-card-date { margin-top: .35rem; }
.article-header .article-date { margin: .35rem 0 1rem; color: rgba(7,19,52,.68); }
.blog-card h3 { margin: .45rem 0; color: var(--navy); font-size: clamp(1.18rem, 1.5vw, 1.42rem); line-height: 1.2; font-weight: 800; }
.blog-card h3 a { text-decoration: none; }
.blog-card p { color: var(--muted); font-size: .98rem; line-height: 1.58; }

.property-card h3 a:hover, .blog-card h3 a:hover, .hero-property-panel h2 a:hover, .development-card h2 a:hover { color: #846c00; }
.property-card .text-link, .blog-card .text-link, .hero-property-panel .text-link { display: inline-flex; align-items: center; gap: .38rem; margin-top: auto; }
.property-card .text-link i, .blog-card .text-link i, .hero-property-panel .text-link i { transition: transform .2s ease; }
.property-card:hover .text-link i, .blog-card:hover .text-link i, .hero-property-panel:hover .text-link i { transform: translateX(3px); }

.development-section { background: #fff; }
.development-list { display: grid; gap: 1rem; }
.development-card {
  display: grid;
  grid-template-columns: minmax(280px, .92fr) minmax(0, 1.08fr);
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.development-card:hover { transform: translateY(-4px); border-color: rgba(217,179,0,.65); box-shadow: 0 22px 52px rgba(4,10,33,.14); }
.development-card-media { display: block; overflow: hidden; background: var(--soft); }
.development-card-media img { width: 100%; height: 100%; min-height: 320px; aspect-ratio: 16 / 10; object-fit: cover; transition: transform .35s ease; }
.development-card:hover .development-card-media img { transform: scale(1.035); }
.development-card-body { padding: clamp(1.25rem, 2.5vw, 2rem); display: flex; flex-direction: column; justify-content: center; }
.development-kicker { color: #846c00; text-transform: uppercase; font-weight: 850; font-size: .72rem; letter-spacing: .08em; line-height: 1.2; margin-bottom: .45rem; }
.development-card h2 { color: var(--navy); font-size: clamp(1.55rem, 2.3vw, 2.35rem); line-height: 1.08; font-weight: 850; margin: 0 0 .6rem; }
.development-card h2 a { text-decoration: none; }
.development-card p { color: var(--muted); font-size: 1rem; line-height: 1.6; }
.development-location { display: flex; align-items: center; gap: .45rem; color: var(--navy); font-weight: 750; }
.development-card .text-link { display: inline-flex; align-items: center; gap: .38rem; margin-top: .4rem; }
.development-card .text-link i { transition: transform .2s ease; }
.development-card:hover .text-link i { transform: translateX(3px); }
.development-detail-media { overflow: hidden; border: 1px solid var(--line); border-radius: 8px; background: var(--soft); }
.development-detail-media img { display: block; width: 100%; aspect-ratio: 16 / 10; object-fit: cover; }

.password-section { background: var(--soft); }
.password-gate {
  max-width: 560px;
  margin: 0 auto;
  padding: 1.5rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 45px rgba(4,10,33,.1);
}
.password-gate label { display: block; color: var(--navy); font-weight: 800; margin-bottom: .5rem; }
.password-row { display: flex; gap: .65rem; align-items: stretch; }
.password-row input {
  flex: 1 1 auto;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: .85rem;
  font: inherit;
}
.password-row input:focus { outline: 2px solid rgba(217,179,0,.45); border-color: var(--gold); }
.password-error { margin: .8rem 0 0; color: #9c1c1c; font-weight: 750; }

.article-header { background: var(--soft); padding: clamp(7rem, 9vw, 9rem) 0 2rem; }
.narrow { max-width: 900px; }
.article-header-meta { display: flex; justify-content: space-between; gap: 1rem; align-items: start; margin-bottom: 1rem; }
.article-header-meta .eyebrow { margin-bottom: .35rem; }
.article-header-meta .article-date { margin-bottom: 0; }
.article-header-meta .page-share { margin-top: .05rem; }
.article-header h1 { color: var(--navy); font-weight: 850; font-size: clamp(2.2rem, 5vw, 4.2rem); line-height: 1; }
.article-header p { color: var(--muted); font-size: 1.15rem; }
.article-hero-image { width: 100%; aspect-ratio: 16 / 8; object-fit: cover; border-radius: 8px; margin-top: 2rem; }
.article-body { padding-top: 2rem; padding-bottom: 4rem; font-size: 1.06rem; line-height: 1.8; }
.article-body h2 { color: var(--navy); margin-top: 2rem; font-weight: 850; }
.article-body a { color: var(--navy); font-weight: 800; }
.article-cta { margin-top: 2rem; background: var(--soft); }
.article-cta .btn { margin-right: .5rem; margin-top: .5rem; }

.about-section { background: linear-gradient(180deg, #fff 0%, #f7f8fa 100%); }
.about-story { display: grid; gap: clamp(2.5rem, 5vw, 4rem); }
.about-spotlight {
  display: grid;
  grid-template-columns: minmax(240px, .42fr) minmax(0, 1fr);
  gap: clamp(1.5rem, 4vw, 3.5rem);
  align-items: center;
  padding-bottom: clamp(2.25rem, 5vw, 4rem);
  border-bottom: 1px solid var(--line);
}
.about-spotlight-media {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 360px;
  padding: clamp(1rem, 3vw, 2rem);
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 22px 60px rgba(4,10,33,.1);
}
.about-spotlight-media img {
  width: min(100%, 280px);
  border: 1px solid var(--line);
  border-radius: 6px;
  box-shadow: 0 16px 35px rgba(4,10,33,.18);
}
.about-spotlight-copy h2,
.about-partners-heading h2 {
  color: var(--navy);
  font-size: clamp(2rem, 3vw, 3.1rem);
  line-height: 1.05;
  font-weight: 850;
}
.about-spotlight-copy p:not(.eyebrow),
.about-partners-heading > p,
.about-partner-card p:not(.about-role) {
  color: var(--muted);
  line-height: 1.65;
}
.about-partners-heading { margin-bottom: 0; }
.about-partners-heading > p { max-width: 520px; }
.about-partner-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1.25rem; }
.about-partner-card {
  display: grid;
  grid-template-columns: minmax(180px, .68fr) minmax(0, 1fr);
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.about-partner-card:hover { transform: translateY(-4px); border-color: rgba(217,179,0,.65); box-shadow: 0 22px 52px rgba(4,10,33,.14); }
.about-partner-card img { width: 100%; height: 100%; min-height: 390px; object-fit: cover; object-position: center top; transition: transform .35s ease; }
.about-partner-card:hover img { transform: scale(1.035); }
.about-partner-card div { padding: clamp(1.25rem, 2.4vw, 1.8rem); display: flex; flex-direction: column; justify-content: center; }
.about-role { color: #846c00; font-size: .72rem; font-weight: 850; letter-spacing: .08em; line-height: 1.2; margin-bottom: .45rem; text-transform: uppercase; }
.about-partner-card h3 { color: var(--navy); font-size: clamp(1.45rem, 2vw, 2rem); line-height: 1.08; font-weight: 850; margin-bottom: .75rem; }
.contact-grid { display: grid; grid-template-columns: .8fr 1fr; gap: 1.25rem; align-items: start; }
.contact-form { display: grid; gap: 1rem; }
.contact-form label { display: grid; gap: .35rem; color: var(--navy); font-weight: 750; }
.contact-form input, .contact-form textarea { width: 100%; border: 1px solid var(--line); border-radius: 6px; padding: .85rem; font: inherit; }
.contact-form input:focus, .contact-form textarea:focus { outline: 2px solid rgba(217,179,0,.45); border-color: var(--gold); }

.site-footer { background-color: var(--navy); background-image: none; color: rgba(255,255,255,.78); padding: 2rem 0; }
.site-footer .footer-brand { display: inline-flex; margin: 0 0 1rem; }
.site-footer .footer-brand img { width: 292px; height: auto; }
.footer-cta { display: flex; justify-content: space-between; gap: 1rem; align-items: center; padding: 1.5rem 0 2rem; border-bottom: 1px solid rgba(255,255,255,.14); }
.footer-cta h2 { color: #fff; font-weight: 850; }
.footer-cta .btn-gold, .footer-cta .btn-gold:hover, .footer-cta .btn-gold:focus { display: inline-flex; color: var(--navy-dark); }
.footer-main { padding: 2rem 0; }
.site-footer h3, .site-footer h4 { color: #fff; font-weight: 850; }
.site-footer a { color: rgba(255,255,255,.82); display: block; text-decoration: none; margin: .35rem 0; }
.site-footer a:hover { color: var(--gold-strong); }
.social-links { display: flex; gap: .5rem; margin-top: 1rem; }
.social-links a { width: 40px; height: 40px; border: 1px solid rgba(255,255,255,.22); display: grid; place-items: center; border-radius: 50%; }
.footer-bottom { display: flex; justify-content: space-between; gap: 1rem; border-top: 1px solid rgba(255,255,255,.14); padding-top: 1rem; font-size: .9rem; }
.footer-main p { margin-top: .2rem; }
.footer-address-label { display: block; color: #fff; font-weight: 850; margin-bottom: .2rem; }
.footer-bottom-links { display: flex; gap: 1rem; flex-wrap: wrap; }



@media (min-width: 1200px) and (max-width: 1399.98px) {
  .nav-shell { padding-left: 18px; padding-right: 18px; gap: .7rem; }
  .navbar-brand { flex-basis: 184px; width: 184px; }
  .brand-logo-img { width: 184px; max-height: 50px; }
  .site-nav .navbar-nav { gap: .08rem; }
  .site-nav .nav-link { font-size: .78rem; padding-left: .5rem; padding-right: .5rem; gap: .34rem; }
  .nav-actions { gap: .45rem; margin-left: .55rem; }
  .nav-phone { padding-left: .58rem; padding-right: .58rem; font-size: .76rem; }
  .nav-sign-in { min-height: 34px; padding-left: .62rem; padding-right: .62rem; font-size: .76rem; }
}

@media (min-width: 1200px) {
  .site-nav .dropdown > .dropdown-menu,
  .site-nav .dropdown > .dropdown-menu[data-bs-popper] {
    top: calc(100% - .25rem);
    margin-top: 0;
  }
  .site-nav .dropdown:hover > .dropdown-menu,
  .site-nav .dropdown:focus-within > .dropdown-menu {
    display: block;
  }
}

@media (max-width: 1199.98px) {
  .site-nav { top: 8px; padding: 0 12px; }
  .site-nav > .container-xl { padding-left: 0; padding-right: 0; }
  .nav-shell { flex-wrap: wrap; min-height: 64px; padding: 9px 14px; border-radius: 14px; }
  .navbar-brand { flex-basis: 172px; width: 172px; }
  .brand-logo-img { width: 172px; max-height: 48px; }
  .site-nav .navbar-collapse { flex-basis: 100%; padding-top: .65rem; }
  .site-nav .navbar-nav { align-items: stretch !important; gap: .1rem; }
  .site-nav .nav-link { width: 100%; justify-content: flex-start; padding: .82rem .35rem; }
  .site-nav .nav-link.active::after { left: .35rem; right: auto; width: 56px; bottom: .35rem; }
  .dropdown-menu { margin: .15rem 0 .45rem; }
  .nav-actions { align-items: flex-start; flex-direction: column; margin: .55rem 0 0; padding-top: .85rem; border-top: 1px solid rgba(255,255,255,.12); }
  .hero { padding-top: 8.5rem; }
  .about-partner-card { grid-template-columns: 1fr; }
  .about-partner-card img { min-height: 0; aspect-ratio: 4 / 3; }
}

@media (max-width: 991.98px) {
  .hero-grid, .property-layout, .about-spotlight, .about-partner-grid, .contact-grid { grid-template-columns: 1fr; }
  .property-sidebar { position: static; }
  .property-grid, .blog-grid, .blog-grid-wide, .opportunity-grid { grid-template-columns: 1fr; }
  .development-card { grid-template-columns: 1fr; }
  .development-card-media img { min-height: 260px; }
  .property-card { grid-template-columns: 1fr; }
  .split-heading, .property-title-grid, .footer-cta { align-items: start; flex-direction: column; }
  .property-title-actions { align-items: flex-start; }
  .article-header-meta { flex-direction: column; }
  .gallery-thumbs { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 575.98px) {
  .hero { padding-top: 8rem; }
  .property-card dl { grid-template-columns: 1fr; }
  .gallery-thumbs { grid-template-columns: repeat(3, 1fr); }
  .password-row { flex-direction: column; }
  .password-row .btn { justify-content: center; }
  .development-card-media img { min-height: 220px; }
  .opportunity-grid > div { display: grid; grid-template-columns: 42px minmax(0, 1fr); gap: .15rem .85rem; align-items: start; padding: 1rem; }
  .opportunity-grid i { grid-row: 1 / span 2; width: 42px; height: 42px; display: grid; place-items: center; margin-bottom: 0; font-size: 1.35rem; }
  .opportunity-grid h3 { margin: .1rem 0 .18rem; font-size: 1.05rem; }
  .opportunity-grid p { margin: 0; font-size: .92rem; line-height: 1.45; }
  .about-spotlight-media { min-height: 0; }
  .about-partner-card img { aspect-ratio: 4 / 3; }
  .footer-bottom { flex-direction: column; }
  .page-share { flex-wrap: wrap; }
  .page-share a { width: 36px; height: 36px; }
}


.fx-lab { padding: 4rem 0; background: #f3f5f7; }
.fx-preview {
  position: relative;
  min-height: min(680px, calc(100vh - 120px));
  display: grid;
  align-items: center;
  overflow: hidden;
  border-radius: 8px;
  color: var(--fx-text, #fff);
  background: var(--fx-bg, var(--navy));
  box-shadow: 0 24px 70px rgba(4,10,33,.2);
  isolation: isolate;
}
.fx-preview::before,
.fx-preview::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.fx-preview::before {
  z-index: -2;
  opacity: var(--fx-pattern-opacity, .75);
  background-image: var(--fx-pattern, none);
  background-size: var(--fx-pattern-size, 40px 40px);
  animation: var(--fx-animation, fx-pan 26s linear infinite);
}
.fx-preview::after {
  z-index: -1;
  background: var(--fx-wash, linear-gradient(90deg, rgba(0,0,0,.32), rgba(0,0,0,.05)));
}
.fx-preview-inner { max-width: 820px; padding: clamp(3rem, 7vw, 6rem); }
.fx-preview h1 { font-size: clamp(2.4rem, 5vw, 4.8rem); line-height: 1.02; font-weight: 850; margin-bottom: 1rem; }
.fx-preview p:not(.eyebrow) { color: var(--fx-muted, rgba(255,255,255,.82)); max-width: 650px; font-size: clamp(1.05rem, 1.45vw, 1.25rem); }
.fx-preview .btn-outline-light { color: var(--fx-outline, #fff); border-color: var(--fx-outline-border, rgba(255,255,255,.65)); }
.fx-preview .btn-outline-light:hover { background: var(--fx-outline, #fff); color: var(--navy); }
.fx-info-panel {
  position: absolute;
  right: 1.25rem;
  bottom: 1.25rem;
  width: min(310px, calc(100% - 2.5rem));
  padding: 1rem;
  border-radius: 8px;
  background: var(--fx-panel, rgba(255,255,255,.12));
  border: 1px solid var(--fx-panel-line, rgba(255,255,255,.22));
  backdrop-filter: blur(14px);
  color: var(--fx-panel-text, var(--fx-text, #fff));
}
.fx-info-panel span { color: var(--gold); font-weight: 850; font-size: .76rem; }
.fx-info-panel strong { display: block; margin-top: .25rem; font-size: 1.08rem; }
.fx-info-panel small { display: block; margin-top: .25rem; color: var(--fx-muted, rgba(255,255,255,.76)); line-height: 1.45; }
.fx-toolbar { display: flex; align-items: end; justify-content: space-between; gap: 1rem; margin: 2rem 0 1rem; }
.fx-toolbar h2 { color: var(--navy); font-size: clamp(1.8rem, 3vw, 2.8rem); font-weight: 850; margin: 0; }
.fx-toolbar-actions { display: flex; gap: .5rem; }
.fx-icon-button {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--navy);
  background: #fff;
}
.fx-icon-button:hover { border-color: var(--gold); background: rgba(217,179,0,.14); }
.fx-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: .75rem; }
.fx-swatch {
  min-height: 104px;
  padding: .6rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--navy);
  text-align: left;
  font-weight: 750;
}
.fx-swatch span { display: block; height: 54px; border-radius: 6px; margin-bottom: .55rem; background: var(--swatch-bg, #0A1338); border: 1px solid rgba(4,10,33,.12); }
.fx-swatch strong { display: block; font-size: .84rem; line-height: 1.2; }
.fx-swatch.active, .fx-swatch:hover { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(217,179,0,.16); }

.fx-lab-hero { min-height: 100vh; }
.fx-lab-hero .hero-grid { margin-top: clamp(1.5rem, 3vw, 2.5rem); }
.fx-hero-controls {
  display: grid;
  grid-template-columns: minmax(220px, .42fr) auto;
  gap: .75rem 1rem;
  align-items: center;
  padding: .85rem;
  border: 1px solid rgba(7,19,52,.12);
  border-radius: 8px;
  background: rgba(255,255,255,.78);
  color: var(--navy);
  box-shadow: 0 20px 52px rgba(4,10,33,.14);
  backdrop-filter: blur(16px);
}
.fx-current { min-width: 0; }
.fx-current span {
  display: block;
  color: #846c00;
  font-size: .72rem;
  font-weight: 850;
  letter-spacing: .08em;
  line-height: 1.2;
  text-transform: uppercase;
}
.fx-current strong {
  display: block;
  margin-top: .18rem;
  color: var(--navy);
  font-size: 1rem;
  line-height: 1.15;
}
.fx-current small {
  display: block;
  margin-top: .18rem;
  color: #4b5259;
  line-height: 1.35;
}
.fx-hero-controls .fx-toolbar-actions { justify-self: end; }
.fx-choice-strip {
  grid-column: 1 / -1;
  display: flex;
  gap: .55rem;
  overflow-x: auto;
  padding: .15rem .05rem .35rem;
  scroll-snap-type: x proximity;
  scrollbar-color: rgba(10,19,56,.32) transparent;
}
.fx-choice-strip .fx-swatch {
  flex: 0 0 164px;
  min-height: 58px;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: .55rem;
  padding: .5rem .6rem;
  border-color: rgba(7,19,52,.16);
  background: rgba(255,255,255,.84);
  scroll-snap-align: start;
}
.fx-choice-strip .fx-swatch span {
  width: 34px;
  height: 34px;
  margin: 0;
  border-radius: 6px;
}
.fx-choice-strip .fx-swatch strong {
  overflow: hidden;
  color: var(--navy);
  font-size: .76rem;
  line-height: 1.15;
  text-overflow: ellipsis;
}
.fx-choice-strip .fx-swatch.active,
.fx-choice-strip .fx-swatch:hover {
  background: #fff;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(217,179,0,.18);
}

.fx-bg-01, .fx-swatch[data-bg="fx-bg-01"] span { --fx-bg: #1d3048; --fx-pattern: linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px); --fx-pattern-size: 32px 32px; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.52), rgba(4,10,33,.1)); --swatch-bg: #1d3048; }
.fx-bg-02, .fx-swatch[data-bg="fx-bg-02"] span { --fx-bg: #efe8d9; --fx-text: #081336; --fx-muted: #3f4658; --fx-outline: #081336; --fx-outline-border: rgba(8,19,54,.55); --fx-pattern: linear-gradient(rgba(10,19,56,.12) 1px, transparent 1px), linear-gradient(90deg, rgba(10,19,56,.12) 1px, transparent 1px); --fx-pattern-size: 36px 36px; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.55), rgba(255,255,255,.12)); --fx-panel: rgba(255,255,255,.72); --fx-panel-line: rgba(10,19,56,.12); --fx-panel-text: #081336; --swatch-bg: #efe8d9; }
.fx-bg-03, .fx-swatch[data-bg="fx-bg-03"] span { --fx-bg: linear-gradient(120deg, #122943, #506173); --fx-pattern: repeating-linear-gradient(115deg, rgba(255,255,255,.08) 0 1px, transparent 1px 26px); --fx-pattern-size: 220px 220px; --fx-animation: fx-diagonal 32s linear infinite; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.56), rgba(4,10,33,.08)); --swatch-bg: linear-gradient(120deg, #122943, #506173); }
.fx-bg-04, .fx-swatch[data-bg="fx-bg-04"] span { --fx-bg: #d8e0e8; --fx-text: #071334; --fx-muted: #424b58; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.45); --fx-pattern: repeating-linear-gradient(0deg, rgba(10,19,56,.1) 0 1px, transparent 1px 18px), repeating-linear-gradient(90deg, rgba(10,19,56,.06) 0 1px, transparent 1px 120px); --fx-pattern-size: 240px 240px; --fx-animation: fx-pan-slow 36s linear infinite; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.6), rgba(255,255,255,.14)); --fx-panel: rgba(255,255,255,.72); --fx-panel-text: #071334; --swatch-bg: #d8e0e8; }
.fx-bg-05, .fx-swatch[data-bg="fx-bg-05"] span { --fx-bg: #d6b45a; --fx-text: #071334; --fx-muted: #2f2b1f; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.5); --fx-pattern: linear-gradient(rgba(4,10,33,.13) 1px, transparent 1px), linear-gradient(90deg, rgba(4,10,33,.1) 1px, transparent 1px); --fx-pattern-size: 34px 34px; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.46), rgba(255,255,255,.08)); --fx-panel: rgba(255,255,255,.6); --fx-panel-text: #071334; --swatch-bg: #d6b45a; }
.fx-bg-06, .fx-swatch[data-bg="fx-bg-06"] span { --fx-bg: #06393f; --fx-pattern: repeating-linear-gradient(90deg, rgba(217,179,0,.18) 0 1px, transparent 1px 44px), repeating-linear-gradient(0deg, rgba(255,255,255,.05) 0 1px, transparent 1px 28px); --fx-pattern-size: 180px 180px; --fx-animation: fx-pan-slow 30s linear infinite; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.42), rgba(0,2,13,.05)); --swatch-bg: #06393f; }
.fx-bg-07, .fx-swatch[data-bg="fx-bg-07"] span { --fx-bg: #111820; --fx-pattern: repeating-linear-gradient(135deg, rgba(217,179,0,.18) 0 1px, transparent 1px 30px); --fx-pattern-size: 120px 120px; --fx-animation: fx-diagonal 40s linear infinite; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.38), rgba(0,2,13,.08)); --swatch-bg: #111820; }
.fx-bg-08, .fx-swatch[data-bg="fx-bg-08"] span { --fx-bg: #c9d8e3; --fx-text: #081336; --fx-muted: #394a5c; --fx-outline: #081336; --fx-outline-border: rgba(8,19,54,.48); --fx-pattern: linear-gradient(rgba(10,19,56,.12) 1px, transparent 1px), linear-gradient(90deg, rgba(10,19,56,.12) 1px, transparent 1px); --fx-pattern-size: 30px 30px; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.56), rgba(255,255,255,.1)); --fx-panel: rgba(255,255,255,.68); --fx-panel-text: #081336; --swatch-bg: #c9d8e3; }
.fx-bg-09, .fx-swatch[data-bg="fx-bg-09"] span { --fx-bg: #102842; --fx-pattern: linear-gradient(rgba(255,255,255,.11) 2px, transparent 2px), linear-gradient(90deg, rgba(255,255,255,.08) 2px, transparent 2px); --fx-pattern-size: 56px 56px; --fx-animation: fx-pan-slow 34s linear infinite; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.46), rgba(4,10,33,.03)); --swatch-bg: #102842; }
.fx-bg-10, .fx-swatch[data-bg="fx-bg-10"] span { --fx-bg: linear-gradient(120deg, #2b2723, #40515f); --fx-pattern: repeating-linear-gradient(90deg, rgba(255,255,255,.06) 0 1px, transparent 1px 36px); --fx-pattern-size: 140px 140px; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.42), rgba(0,2,13,.08)); --swatch-bg: linear-gradient(120deg, #2b2723, #40515f); }
.fx-bg-11, .fx-swatch[data-bg="fx-bg-11"] span { --fx-bg: #eef1f3; --fx-text: #071334; --fx-muted: #3f4658; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.45); --fx-pattern: repeating-linear-gradient(90deg, rgba(10,19,56,.1) 0 28px, transparent 28px 36px), repeating-linear-gradient(0deg, rgba(217,179,0,.16) 0 18px, transparent 18px 42px); --fx-pattern-size: 180px 120px; --fx-animation: fx-pan-x 42s linear infinite; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.6), rgba(255,255,255,.18)); --fx-panel: rgba(255,255,255,.72); --fx-panel-text: #071334; --swatch-bg: #eef1f3; }
.fx-bg-12, .fx-swatch[data-bg="fx-bg-12"] span { --fx-bg: #fbfbf7; --fx-text: #071334; --fx-muted: #444b55; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.45); --fx-pattern: linear-gradient(rgba(10,19,56,.1) 1px, transparent 1px), linear-gradient(90deg, rgba(10,19,56,.1) 1px, transparent 1px), repeating-linear-gradient(45deg, transparent 0 38px, rgba(217,179,0,.16) 38px 39px); --fx-pattern-size: 32px 32px, 32px 32px, 180px 180px; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.64), rgba(255,255,255,.1)); --fx-panel: rgba(255,255,255,.72); --fx-panel-text: #071334; --swatch-bg: #fbfbf7; }
.fx-bg-13, .fx-swatch[data-bg="fx-bg-13"] span { --fx-bg: #4e6477; --fx-pattern: repeating-linear-gradient(135deg, rgba(255,255,255,.09) 0 1px, transparent 1px 24px), linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px); --fx-pattern-size: 180px 180px, 40px 40px; --fx-animation: fx-diagonal 38s linear infinite; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.42), rgba(4,10,33,.04)); --swatch-bg: #4e6477; }
.fx-bg-14, .fx-swatch[data-bg="fx-bg-14"] span { --fx-bg: #10203a; --fx-pattern: repeating-linear-gradient(90deg, rgba(217,179,0,.2) 0 1px, transparent 1px 80px); --fx-pattern-size: 240px 240px; --fx-animation: fx-pan-x 46s linear infinite; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.04), rgba(255,255,255,.13)); --swatch-bg: #10203a; }
.fx-bg-15, .fx-swatch[data-bg="fx-bg-15"] span { --fx-bg: #eef0e8; --fx-text: #071334; --fx-muted: #45504b; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.45); --fx-pattern: repeating-linear-gradient(8deg, rgba(10,19,56,.1) 0 1px, transparent 1px 18px), repeating-linear-gradient(-8deg, rgba(217,179,0,.1) 0 1px, transparent 1px 22px); --fx-pattern-size: 220px 220px; --fx-animation: fx-pan-slow 48s linear infinite; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.6), rgba(255,255,255,.1)); --fx-panel: rgba(255,255,255,.7); --fx-panel-text: #071334; --swatch-bg: #eef0e8; }
.fx-bg-16, .fx-swatch[data-bg="fx-bg-16"] span { --fx-bg: #44524c; --fx-pattern: linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px), linear-gradient(90deg, rgba(217,179,0,.09) 1px, transparent 1px); --fx-pattern-size: 44px 44px; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.44), rgba(4,10,33,.06)); --swatch-bg: #44524c; }
.fx-bg-17, .fx-swatch[data-bg="fx-bg-17"] span { --fx-bg: #101824; --fx-pattern: repeating-linear-gradient(0deg, rgba(255,255,255,.1) 0 1px, transparent 1px 48px); --fx-pattern-size: 100% 160px; --fx-animation: fx-scan 18s linear infinite; --fx-wash: linear-gradient(90deg, rgba(10,19,56,.32), rgba(255,255,255,.06)); --swatch-bg: #101824; }
.fx-bg-18, .fx-swatch[data-bg="fx-bg-18"] span { --fx-bg: #dde0de; --fx-text: #071334; --fx-muted: #50565c; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.45); --fx-pattern: linear-gradient(rgba(10,19,56,.1) 1px, transparent 1px), linear-gradient(90deg, rgba(10,19,56,.08) 1px, transparent 1px); --fx-pattern-size: 38px 38px; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.62), rgba(255,255,255,.08)); --fx-panel: rgba(255,255,255,.7); --fx-panel-text: #071334; --swatch-bg: #dde0de; }
.fx-bg-19, .fx-swatch[data-bg="fx-bg-19"] span { --fx-bg: linear-gradient(120deg, #27394a, #566372); --fx-pattern: repeating-linear-gradient(90deg, rgba(217,179,0,.18) 0 1px, transparent 1px 32px), repeating-linear-gradient(0deg, rgba(255,255,255,.06) 0 1px, transparent 1px 60px); --fx-pattern-size: 220px 220px; --fx-animation: fx-pan-slow 34s linear infinite; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.38), rgba(4,10,33,.05)); --swatch-bg: linear-gradient(120deg, #27394a, #566372); }
.fx-bg-20, .fx-swatch[data-bg="fx-bg-20"] span { --fx-bg: #0e1625; --fx-pattern: repeating-linear-gradient(90deg, rgba(255,255,255,.08) 0 24px, transparent 24px 34px), repeating-linear-gradient(0deg, rgba(217,179,0,.12) 0 10px, transparent 10px 44px); --fx-pattern-size: 180px 120px; --fx-animation: fx-pan-x 40s linear infinite; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.44), rgba(0,2,13,.08)); --swatch-bg: #0e1625; }
.fx-bg-21, .fx-swatch[data-bg="fx-bg-21"] span { --fx-bg: #e7dfcf; --fx-text: #071334; --fx-muted: #4e463a; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.45); --fx-pattern: repeating-linear-gradient(90deg, rgba(10,19,56,.08) 0 1px, transparent 1px 30px), repeating-linear-gradient(0deg, rgba(10,19,56,.07) 0 1px, transparent 1px 30px); --fx-pattern-size: 30px 30px; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.58), rgba(255,255,255,.12)); --fx-panel: rgba(255,255,255,.66); --fx-panel-text: #071334; --swatch-bg: #e7dfcf; }
.fx-bg-22, .fx-swatch[data-bg="fx-bg-22"] span { --fx-bg: linear-gradient(180deg, #8fa6ba 0%, #314962 48%, #0f213a 100%); --fx-pattern: repeating-linear-gradient(90deg, rgba(255,255,255,.09) 0 1px, transparent 1px 42px); --fx-pattern-size: 240px 240px; --fx-animation: fx-pan-x 44s linear infinite; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.35), rgba(4,10,33,.02)); --swatch-bg: linear-gradient(180deg, #8fa6ba, #0f213a); }
.fx-bg-23, .fx-swatch[data-bg="fx-bg-23"] span { --fx-bg: #172033; --fx-pattern: repeating-linear-gradient(0deg, transparent 0 58px, rgba(217,179,0,.3) 58px 60px), repeating-linear-gradient(90deg, rgba(255,255,255,.05) 0 1px, transparent 1px 54px); --fx-pattern-size: 220px 220px; --fx-animation: fx-pan-slow 38s linear infinite; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.42), rgba(0,2,13,.04)); --swatch-bg: #172033; }
.fx-bg-24, .fx-swatch[data-bg="fx-bg-24"] span { --fx-bg: #f5f6f4; --fx-text: #071334; --fx-muted: #4b5259; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.45); --fx-pattern: linear-gradient(rgba(10,19,56,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(10,19,56,.08) 1px, transparent 1px); --fx-pattern-size: 26px 26px; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.62), rgba(255,255,255,.16)); --fx-panel: rgba(255,255,255,.76); --fx-panel-text: #071334; --swatch-bg: #f5f6f4; }
.fx-bg-25, .fx-swatch[data-bg="fx-bg-25"] span { --fx-bg: #07162c; --fx-pattern: repeating-linear-gradient(90deg, rgba(217,179,0,.18) 0 1px, transparent 1px 20px), repeating-linear-gradient(135deg, rgba(255,255,255,.07) 0 1px, transparent 1px 38px); --fx-pattern-size: 180px 180px; --fx-animation: fx-diagonal 36s linear infinite; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.42), rgba(255,255,255,.03)); --swatch-bg: #07162c; }


.fx-bg-26, .fx-swatch[data-bg="fx-bg-26"] span { --fx-bg: linear-gradient(135deg, #46554e 0%, #64746b 54%, #2f3d38 100%); --fx-pattern: radial-gradient(circle at 72% 26%, rgba(255,255,255,.18), transparent 34%), radial-gradient(circle at 18% 78%, rgba(217,179,0,.14), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-float-soft 18s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.4), rgba(4,10,33,.02)); --swatch-bg: linear-gradient(135deg, #46554e, #64746b); }
.fx-bg-27, .fx-swatch[data-bg="fx-bg-27"] span { --fx-bg: linear-gradient(135deg, #f3efe5 0%, #dfd3bd 100%); --fx-text: #071334; --fx-muted: #4b463d; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.42); --fx-pattern: radial-gradient(circle at 76% 18%, rgba(217,179,0,.22), transparent 32%), radial-gradient(circle at 12% 82%, rgba(10,19,56,.1), transparent 32%); --fx-pattern-size: 100% 100%; --fx-animation: fx-float-soft 22s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.68), rgba(255,255,255,.12)); --fx-panel: rgba(255,255,255,.7); --fx-panel-text: #071334; --swatch-bg: linear-gradient(135deg, #f3efe5, #dfd3bd); }
.fx-bg-28, .fx-swatch[data-bg="fx-bg-28"] span { --fx-bg: linear-gradient(135deg, #12323e 0%, #274c58 56%, #0a1a27 100%); --fx-pattern: radial-gradient(circle at 76% 30%, rgba(255,255,255,.13), transparent 34%), radial-gradient(circle at 14% 80%, rgba(217,179,0,.12), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-breathe 16s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.42), rgba(0,2,13,.02)); --swatch-bg: linear-gradient(135deg, #12323e, #274c58); }
.fx-bg-29, .fx-swatch[data-bg="fx-bg-29"] span { --fx-bg: linear-gradient(135deg, #d9e1e7 0%, #b7c7d3 100%); --fx-text: #071334; --fx-muted: #43505b; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.42); --fx-pattern: radial-gradient(circle at 70% 24%, rgba(255,255,255,.42), transparent 34%), radial-gradient(circle at 10% 74%, rgba(10,19,56,.08), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-float-soft 22s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.5), rgba(255,255,255,.1)); --fx-panel: rgba(255,255,255,.68); --fx-panel-text: #071334; --swatch-bg: linear-gradient(135deg, #d9e1e7, #b7c7d3); }
.fx-bg-30, .fx-swatch[data-bg="fx-bg-30"] span { --fx-bg: linear-gradient(135deg, #d8bd67 0%, #efe2bd 100%); --fx-text: #071334; --fx-muted: #443a20; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.44); --fx-pattern: radial-gradient(circle at 70% 20%, rgba(255,255,255,.32), transparent 34%), radial-gradient(circle at 10% 82%, rgba(10,19,56,.1), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-breathe 20s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.48), rgba(255,255,255,.08)); --fx-panel: rgba(255,255,255,.62); --fx-panel-text: #071334; --swatch-bg: linear-gradient(135deg, #d8bd67, #efe2bd); }
.fx-bg-31, .fx-swatch[data-bg="fx-bg-31"] span { --fx-bg: linear-gradient(135deg, #172a25 0%, #34473f 62%, #0b1515 100%); --fx-pattern: radial-gradient(circle at 72% 22%, rgba(217,179,0,.16), transparent 30%), radial-gradient(circle at 18% 84%, rgba(255,255,255,.1), transparent 26%); --fx-pattern-size: 100% 100%; --fx-animation: fx-float-soft 19s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.48), rgba(0,2,13,.04)); --swatch-bg: linear-gradient(135deg, #172a25, #34473f); }
.fx-bg-32, .fx-swatch[data-bg="fx-bg-32"] span { --fx-bg: linear-gradient(135deg, #ecebe6 0%, #cfcfc7 100%); --fx-text: #071334; --fx-muted: #4d4d47; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.42); --fx-pattern: radial-gradient(circle at 80% 24%, rgba(255,255,255,.5), transparent 34%), radial-gradient(circle at 16% 82%, rgba(217,179,0,.12), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-float-soft 24s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.54), rgba(255,255,255,.1)); --fx-panel: rgba(255,255,255,.68); --fx-panel-text: #071334; --swatch-bg: linear-gradient(135deg, #ecebe6, #cfcfc7); }
.fx-bg-33, .fx-swatch[data-bg="fx-bg-33"] span { --fx-bg: linear-gradient(135deg, #7f929e 0%, #455d6e 58%, #203144 100%); --fx-pattern: radial-gradient(circle at 66% 22%, rgba(255,255,255,.2), transparent 32%), radial-gradient(circle at 10% 82%, rgba(217,179,0,.11), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-breathe 20s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.38), rgba(4,10,33,.02)); --swatch-bg: linear-gradient(135deg, #7f929e, #203144); }
.fx-bg-34, .fx-swatch[data-bg="fx-bg-34"] span { --fx-bg: #0d1d3d; --fx-pattern: radial-gradient(circle at 72% 26%, rgba(217,179,0,.25), transparent 30%), radial-gradient(circle at 16% 86%, rgba(255,255,255,.11), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-glow-drift 18s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.34), rgba(0,2,13,.04)); --swatch-bg: #0d1d3d; }
.fx-bg-35, .fx-swatch[data-bg="fx-bg-35"] span { --fx-bg: linear-gradient(135deg, #5b4f48 0%, #344452 60%, #182534 100%); --fx-pattern: radial-gradient(circle at 76% 24%, rgba(255,255,255,.12), transparent 32%), radial-gradient(circle at 18% 80%, rgba(217,179,0,.13), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-float-soft 21s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.4), rgba(0,2,13,.04)); --swatch-bg: linear-gradient(135deg, #5b4f48, #344452); }
.fx-bg-36, .fx-swatch[data-bg="fx-bg-36"] span { --fx-bg: linear-gradient(135deg, #dfe7dd 0%, #aebfac 100%); --fx-text: #071334; --fx-muted: #3f4c42; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.42); --fx-pattern: radial-gradient(circle at 72% 24%, rgba(255,255,255,.42), transparent 32%), radial-gradient(circle at 12% 84%, rgba(217,179,0,.12), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-float-soft 24s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.52), rgba(255,255,255,.08)); --fx-panel: rgba(255,255,255,.7); --fx-panel-text: #071334; --swatch-bg: linear-gradient(135deg, #dfe7dd, #aebfac); }
.fx-bg-37, .fx-swatch[data-bg="fx-bg-37"] span { --fx-bg: linear-gradient(135deg, #050b1d 0%, #15254a 70%, #071125 100%); --fx-pattern: radial-gradient(circle at 70% 24%, rgba(255,255,255,.11), transparent 32%), radial-gradient(circle at 12% 84%, rgba(217,179,0,.16), transparent 26%); --fx-pattern-size: 100% 100%; --fx-animation: fx-breathe 18s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.36), rgba(0,2,13,.02)); --swatch-bg: linear-gradient(135deg, #050b1d, #15254a); }
.fx-bg-38, .fx-swatch[data-bg="fx-bg-38"] span { --fx-bg: linear-gradient(135deg, #f1e8d4 0%, #e1c784 100%); --fx-text: #071334; --fx-muted: #4c412b; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.42); --fx-pattern: radial-gradient(circle at 76% 20%, rgba(255,255,255,.38), transparent 34%), radial-gradient(circle at 10% 84%, rgba(10,19,56,.08), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-float-soft 22s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.58), rgba(255,255,255,.08)); --fx-panel: rgba(255,255,255,.66); --fx-panel-text: #071334; --swatch-bg: linear-gradient(135deg, #f1e8d4, #e1c784); }
.fx-bg-39, .fx-swatch[data-bg="fx-bg-39"] span { --fx-bg: linear-gradient(135deg, #44524c 0%, #5f6d65 58%, #26342f 100%); --fx-pattern: radial-gradient(circle at 74% 24%, rgba(255,255,255,.14), transparent 32%), radial-gradient(circle at 12% 84%, rgba(217,179,0,.13), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-float-soft 20s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.42), rgba(4,10,33,.02)); --swatch-bg: linear-gradient(135deg, #44524c, #5f6d65); }
.fx-bg-40, .fx-swatch[data-bg="fx-bg-40"] span { --fx-bg: linear-gradient(135deg, #081335 0%, #21375a 62%, #0a1024 100%); --fx-pattern: radial-gradient(circle at 66% 26%, rgba(255,255,255,.16), transparent 34%), radial-gradient(circle at 18% 80%, rgba(217,179,0,.13), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-glow-drift 22s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.34), rgba(0,2,13,.02)); --swatch-bg: linear-gradient(135deg, #081335, #21375a); }

@keyframes fx-float-soft { from { background-position: 0 0; transform: scale(1); } to { background-position: 26px -20px; transform: scale(1.025); } }
@keyframes fx-breathe { from { opacity: .78; transform: scale(1); } to { opacity: 1; transform: scale(1.035); } }
@keyframes fx-glow-drift { from { background-position: 0 0; opacity: .78; } to { background-position: 42px -28px; opacity: 1; } }


.fx-bg-41, .fx-swatch[data-bg="fx-bg-41"] span { --fx-bg: linear-gradient(135deg, #3b443c 0%, #5b6254 58%, #252f2b 100%); --fx-pattern: radial-gradient(circle at 72% 22%, rgba(217,179,0,.18), transparent 32%), radial-gradient(circle at 14% 82%, rgba(255,255,255,.09), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-ambient-one 24s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.42), rgba(4,10,33,.03)); --swatch-bg: linear-gradient(135deg, #3b443c, #5b6254); }
.fx-bg-42, .fx-swatch[data-bg="fx-bg-42"] span { --fx-bg: linear-gradient(150deg, #24495f 0%, #5e7c8a 56%, #10263b 100%); --fx-pattern: radial-gradient(circle at 76% 24%, rgba(255,255,255,.18), transparent 30%), linear-gradient(180deg, transparent 0%, rgba(255,255,255,.12) 52%, transparent 100%); --fx-pattern-size: 100% 100%; --fx-animation: fx-horizon 20s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.36), rgba(4,10,33,.01)); --swatch-bg: linear-gradient(150deg, #24495f, #5e7c8a); }
.fx-bg-43, .fx-swatch[data-bg="fx-bg-43"] span { --fx-bg: linear-gradient(135deg, #e6e0d5 0%, #c8c2b7 100%); --fx-text: #071334; --fx-muted: #4b4944; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.42); --fx-pattern: radial-gradient(circle at 72% 20%, rgba(255,255,255,.42), transparent 34%), radial-gradient(circle at 12% 84%, rgba(10,19,56,.08), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-ambient-two 26s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.58), rgba(255,255,255,.1)); --fx-panel: rgba(255,255,255,.68); --fx-panel-text: #071334; --swatch-bg: linear-gradient(135deg, #e6e0d5, #c8c2b7); }
.fx-bg-44, .fx-swatch[data-bg="fx-bg-44"] span { --fx-bg: linear-gradient(135deg, #13241f 0%, #2c453c 62%, #081319 100%); --fx-pattern: radial-gradient(circle at 74% 26%, rgba(255,255,255,.1), transparent 30%), radial-gradient(circle at 16% 84%, rgba(217,179,0,.14), transparent 26%); --fx-pattern-size: 100% 100%; --fx-animation: fx-ambient-one 23s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.48), rgba(0,2,13,.04)); --swatch-bg: linear-gradient(135deg, #13241f, #2c453c); }
.fx-bg-45, .fx-swatch[data-bg="fx-bg-45"] span { --fx-bg: linear-gradient(135deg, #caa85c 0%, #7b735f 48%, #2f4552 100%); --fx-pattern: radial-gradient(circle at 18% 22%, rgba(255,255,255,.25), transparent 30%), radial-gradient(circle at 82% 78%, rgba(10,19,56,.16), transparent 32%); --fx-pattern-size: 100% 100%; --fx-animation: fx-glow-drift 22s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.38), rgba(4,10,33,.02)); --swatch-bg: linear-gradient(135deg, #caa85c, #2f4552); }
.fx-bg-46, .fx-swatch[data-bg="fx-bg-46"] span { --fx-bg: linear-gradient(140deg, #263746 0%, #71808a 52%, #142332 100%); --fx-pattern: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.16) 45%, transparent 62%); --fx-pattern-size: 220% 220%; --fx-animation: fx-light-sweep 18s ease-in-out infinite; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.4), rgba(4,10,33,.02)); --swatch-bg: linear-gradient(140deg, #263746, #71808a); }
.fx-bg-47, .fx-swatch[data-bg="fx-bg-47"] span { --fx-bg: linear-gradient(135deg, #6d7d61 0%, #9ba982 58%, #35463c 100%); --fx-pattern: radial-gradient(circle at 74% 22%, rgba(255,255,255,.22), transparent 32%), radial-gradient(circle at 10% 84%, rgba(10,19,56,.12), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-ambient-two 26s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.38), rgba(4,10,33,.04)); --swatch-bg: linear-gradient(135deg, #6d7d61, #9ba982); }
.fx-bg-48, .fx-swatch[data-bg="fx-bg-48"] span { --fx-bg: linear-gradient(135deg, #f5ead4 0%, #e1d4bd 100%); --fx-text: #071334; --fx-muted: #4c463d; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.42); --fx-pattern: radial-gradient(circle at 78% 26%, rgba(10,19,56,.12), transparent 34%), radial-gradient(circle at 8% 82%, rgba(217,179,0,.16), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-ambient-one 26s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.62), rgba(255,255,255,.12)); --fx-panel: rgba(255,255,255,.7); --fx-panel-text: #071334; --swatch-bg: linear-gradient(135deg, #f5ead4, #e1d4bd); }
.fx-bg-49, .fx-swatch[data-bg="fx-bg-49"] span { --fx-bg: linear-gradient(135deg, #5d7180 0%, #2f4659 62%, #1a2a3b 100%); --fx-pattern: radial-gradient(circle at 70% 28%, rgba(255,255,255,.18), transparent 32%), radial-gradient(circle at 12% 82%, rgba(255,255,255,.08), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-breathe 19s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.36), rgba(4,10,33,.02)); --swatch-bg: linear-gradient(135deg, #5d7180, #2f4659); }
.fx-bg-50, .fx-swatch[data-bg="fx-bg-50"] span { --fx-bg: #07122e; --fx-pattern: radial-gradient(circle at 84% 18%, rgba(217,179,0,.28), transparent 30%), radial-gradient(circle at 18% 84%, rgba(255,255,255,.1), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-ambient-one 21s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.38), rgba(0,2,13,.04)); --swatch-bg: #07122e; }
.fx-bg-51, .fx-swatch[data-bg="fx-bg-51"] span { --fx-bg: linear-gradient(135deg, #d8d9cf 0%, #b5c0af 100%); --fx-text: #071334; --fx-muted: #444b43; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.42); --fx-pattern: radial-gradient(circle at 74% 24%, rgba(255,255,255,.38), transparent 34%), radial-gradient(circle at 12% 82%, rgba(10,19,56,.1), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-ambient-two 28s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.56), rgba(255,255,255,.1)); --fx-panel: rgba(255,255,255,.72); --fx-panel-text: #071334; --swatch-bg: linear-gradient(135deg, #d8d9cf, #b5c0af); }
.fx-bg-52, .fx-swatch[data-bg="fx-bg-52"] span { --fx-bg: linear-gradient(180deg, #6e8290 0%, #2b4053 58%, #12243a 100%); --fx-pattern: linear-gradient(180deg, transparent 0%, rgba(255,255,255,.14) 46%, transparent 72%); --fx-pattern-size: 100% 180%; --fx-animation: fx-horizon 22s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.36), rgba(4,10,33,.02)); --swatch-bg: linear-gradient(180deg, #6e8290, #12243a); }
.fx-bg-53, .fx-swatch[data-bg="fx-bg-53"] span { --fx-bg: linear-gradient(135deg, #17151a 0%, #3d3024 52%, #0d1730 100%); --fx-pattern: radial-gradient(circle at 76% 22%, rgba(217,179,0,.18), transparent 30%), radial-gradient(circle at 12% 82%, rgba(255,255,255,.08), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-glow-drift 24s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.48), rgba(0,2,13,.04)); --swatch-bg: linear-gradient(135deg, #17151a, #3d3024); }
.fx-bg-54, .fx-swatch[data-bg="fx-bg-54"] span { --fx-bg: linear-gradient(135deg, #e5eadc 0%, #c6d0b2 100%); --fx-text: #071334; --fx-muted: #46503f; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.42); --fx-pattern: radial-gradient(circle at 72% 22%, rgba(255,255,255,.38), transparent 34%), radial-gradient(circle at 12% 82%, rgba(217,179,0,.12), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-ambient-one 28s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.58), rgba(255,255,255,.1)); --fx-panel: rgba(255,255,255,.7); --fx-panel-text: #071334; --swatch-bg: linear-gradient(135deg, #e5eadc, #c6d0b2); }
.fx-bg-55, .fx-swatch[data-bg="fx-bg-55"] span { --fx-bg: linear-gradient(135deg, #d7dedf 0%, #99abb1 100%); --fx-text: #071334; --fx-muted: #405057; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.42); --fx-pattern: radial-gradient(circle at 76% 20%, rgba(255,255,255,.44), transparent 34%), radial-gradient(circle at 8% 84%, rgba(10,19,56,.1), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-breathe 24s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.52), rgba(255,255,255,.08)); --fx-panel: rgba(255,255,255,.68); --fx-panel-text: #071334; --swatch-bg: linear-gradient(135deg, #d7dedf, #99abb1); }
.fx-bg-56, .fx-swatch[data-bg="fx-bg-56"] span { --fx-bg: linear-gradient(135deg, #1d3941 0%, #49645f 58%, #102229 100%); --fx-pattern: radial-gradient(circle at 78% 22%, rgba(255,255,255,.12), transparent 32%), radial-gradient(circle at 12% 84%, rgba(217,179,0,.14), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-ambient-two 24s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.42), rgba(0,2,13,.04)); --swatch-bg: linear-gradient(135deg, #1d3941, #49645f); }
.fx-bg-57, .fx-swatch[data-bg="fx-bg-57"] span { --fx-bg: linear-gradient(135deg, #d6c797 0%, #a39776 58%, #5c6260 100%); --fx-text: #071334; --fx-muted: #494331; --fx-outline: #071334; --fx-outline-border: rgba(7,19,52,.42); --fx-pattern: radial-gradient(circle at 74% 22%, rgba(255,255,255,.32), transparent 34%), radial-gradient(circle at 10% 84%, rgba(10,19,56,.12), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-ambient-one 26s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(255,255,255,.5), rgba(255,255,255,.08)); --fx-panel: rgba(255,255,255,.64); --fx-panel-text: #071334; --swatch-bg: linear-gradient(135deg, #d6c797, #5c6260); }
.fx-bg-58, .fx-swatch[data-bg="fx-bg-58"] span { --fx-bg: linear-gradient(135deg, #050c22 0%, #20304d 55%, #050a18 100%); --fx-pattern: radial-gradient(circle at 78% 18%, rgba(255,255,255,.14), transparent 30%), radial-gradient(circle at 14% 82%, rgba(85,113,145,.24), transparent 30%); --fx-pattern-size: 100% 100%; --fx-animation: fx-light-sweep 19s ease-in-out infinite; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.34), rgba(0,2,13,.03)); --swatch-bg: linear-gradient(135deg, #050c22, #20304d); }
.fx-bg-59, .fx-swatch[data-bg="fx-bg-59"] span { --fx-bg: linear-gradient(180deg, #7a8b80 0%, #45584f 56%, #263630 100%); --fx-pattern: linear-gradient(180deg, transparent 0%, rgba(255,255,255,.14) 45%, transparent 72%), radial-gradient(circle at 80% 20%, rgba(217,179,0,.12), transparent 30%); --fx-pattern-size: 100% 180%, 100% 100%; --fx-animation: fx-horizon 24s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(4,10,33,.4), rgba(4,10,33,.02)); --swatch-bg: linear-gradient(180deg, #7a8b80, #263630); }
.fx-bg-60, .fx-swatch[data-bg="fx-bg-60"] span { --fx-bg: linear-gradient(135deg, #14171d 0%, #2e3134 58%, #080b12 100%); --fx-pattern: radial-gradient(circle at 78% 20%, rgba(217,179,0,.16), transparent 30%), radial-gradient(circle at 12% 84%, rgba(255,255,255,.08), transparent 28%); --fx-pattern-size: 100% 100%; --fx-animation: fx-ambient-two 26s ease-in-out infinite alternate; --fx-wash: linear-gradient(90deg, rgba(0,2,13,.48), rgba(0,2,13,.04)); --swatch-bg: linear-gradient(135deg, #14171d, #2e3134); }

.fx-bg-01, .fx-bg-03, .fx-bg-06, .fx-bg-07, .fx-bg-09, .fx-bg-10, .fx-bg-13, .fx-bg-14, .fx-bg-16, .fx-bg-17, .fx-bg-19, .fx-bg-20, .fx-bg-22, .fx-bg-23, .fx-bg-25, .fx-bg-26, .fx-bg-28, .fx-bg-31, .fx-bg-33, .fx-bg-34, .fx-bg-35, .fx-bg-37, .fx-bg-39, .fx-bg-40, .fx-bg-41, .fx-bg-42, .fx-bg-44, .fx-bg-45, .fx-bg-46, .fx-bg-47, .fx-bg-49, .fx-bg-50, .fx-bg-52, .fx-bg-53, .fx-bg-56, .fx-bg-58, .fx-bg-59, .fx-bg-60 {
  --fx-text: #fff;
  --fx-muted: rgba(255,255,255,.82);
  --fx-outline: #fff;
  --fx-outline-border: rgba(255,255,255,.66);
  --fx-outline-hover-text: var(--navy);
  --fx-panel: rgba(255,255,255,.12);
  --fx-panel-line: rgba(255,255,255,.22);
  --fx-panel-text: #fff;
}


@keyframes fx-ambient-one { from { background-position: 0 0; opacity: .76; transform: scale(1); } to { background-position: 34px -24px; opacity: 1; transform: scale(1.03); } }
@keyframes fx-ambient-two { from { background-position: 0 0; opacity: .82; transform: scale(1); } to { background-position: -26px 32px; opacity: 1; transform: scale(1.025); } }
@keyframes fx-horizon { from { background-position: 0 0; opacity: .8; } to { background-position: 0 42px; opacity: 1; } }
@keyframes fx-light-sweep { 0% { background-position: 120% 0; opacity: .55; } 50% { opacity: .95; } 100% { background-position: -120% 0; opacity: .55; } }

@keyframes fx-pan { from { background-position: 0 0; } to { background-position: 96px 64px; } }
@keyframes fx-pan-slow { from { background-position: 0 0; } to { background-position: 180px 120px; } }
@keyframes fx-pan-x { from { background-position: 0 0; } to { background-position: 240px 0; } }
@keyframes fx-diagonal { from { background-position: 0 0; } to { background-position: 180px 180px; } }
@keyframes fx-scan { from { background-position: 0 -160px; } to { background-position: 0 160px; } }

@media (prefers-reduced-motion: reduce) {
  .hero-soft-steel::before,
  .page-hero::before,
  .fx-preview::before { animation: none; }
}

@media (max-width: 1199.98px) {
  .fx-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 767.98px) {
  .fx-lab-hero { min-height: auto; }
  .fx-hero-controls {
    grid-template-columns: 1fr auto;
    gap: .65rem;
    padding: .7rem;
  }
  .fx-current small { display: none; }
  .fx-choice-strip .fx-swatch { flex-basis: 142px; }
  .fx-lab-hero .hero-grid { margin-top: 1.4rem; }
}

@media (max-width: 767.98px) {
  .fx-lab { padding-top: 3rem; }
  .fx-preview { min-height: 620px; }
  .fx-preview-inner { padding: 2rem; align-self: start; padding-top: 4rem; }
  .fx-info-panel { left: 1rem; right: 1rem; bottom: 1rem; width: auto; }
  .fx-toolbar { align-items: start; flex-direction: column; }
  .fx-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 480px) {
  .fx-grid { grid-template-columns: 1fr; }
}
