/* ----------------------------------------------------
   HOUSE OF JEWELS BY BAFNA - LUXURY STYLE SHEET v3
   Color System: Alabaster, Warm Cream, Bronze Gold, and Ink
   Fonts: Playfair Display (headings), Cinzel (accents), DM Sans (body)
---------------------------------------------------- */

:root {
  /* Client color variables from hoj-website-v2.html */
  --ink: #1a1612;
  --ink2: #2e2822;
  --bronze: #a07840;
  --bronze-light: #c49a58;
  --bronze-pale: #e8d4a8;
  --bronze-ultra: #f5ece0;
  --warm: #faf6f0;
  --cream: #f0e8d8;
  --mid: #7a6a58;
  --soft: #b0a090;
  --border: rgba(160, 120, 64, 0.18);
  --border-strong: rgba(160, 120, 64, 0.42);
  --white: #ffffff;
  --black-glass: rgba(26, 22, 18, 0.88);
  
  /* Fonts */
  --font-serif: 'Playfair Display', Georgia, serif;
  --font-accent: 'Cinzel', serif;
  --font-sans: 'DM Sans', sans-serif;
  
  /* Layout tokens */
  --border-radius-sm: 4px;
  --border-radius-md: 8px;
  --border-radius-lg: 16px;
  --container-max-width: 1280px;
  --transition-smooth: all 0.5s cubic-bezier(0.25, 1, 0.5, 1);
  --transition-medium: all 0.35s cubic-bezier(0.25, 1, 0.5, 1);
  --transition-fast: all 0.2s ease;
}

/* --- Base & Reset --- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 17.5px;
  background-color: var(--warm);
  color: var(--ink);
}

body {
  font-family: var(--font-sans);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  background: var(--warm);
}

/* --- Scrollbar --- */
::-webkit-scrollbar {
  width: 6px;
}
::-webkit-scrollbar-track {
  background: var(--warm);
}
::-webkit-scrollbar-thumb {
  background: var(--bronze);
  border-radius: var(--border-radius-sm);
}
::-webkit-scrollbar-thumb:hover {
  background: var(--bronze-light);
}

/* --- Progress Bar --- */
#prog {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  background: var(--bronze);
  z-index: 1000;
  width: 0%;
  transition: width 0.1s ease;
}

/* --- Typography --- */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-serif);
  font-weight: 400;
  letter-spacing: 0.03em;
  color: var(--ink);
  text-wrap: balance;
}
h1 em, h2 em, h3 em, h4 em {
  font-style: italic;
  color: var(--bronze-light);
}

p {
  color: var(--mid);
  font-size: 1.05rem;
  font-weight: 400;
  line-height: 1.85;
}

/* --- Accessibility Skip Link --- */
.skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  background: var(--bronze);
  color: var(--white);
  padding: 1rem 2rem;
  z-index: 10000;
  font-weight: 500;
  text-decoration: none;
  font-family: var(--font-sans);
  transition: top 0.3s ease;
}
.skip-link:focus-visible {
  top: 0;
  outline: 2px solid var(--white);
}

/* Focus states for accessibility */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--bronze);
  outline-offset: 4px;
}

/* --- Buttons --- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  padding: 0.95rem 2.2rem;
  border-radius: 0;
  cursor: pointer;
  text-decoration: none;
  transition: var(--transition-smooth);
  position: relative;
  overflow: hidden;
}

.btn-primary {
  background: var(--ink);
  color: var(--white);
  border: 1px solid var(--ink);
}
.btn-primary:hover {
  background: var(--bronze);
  border-color: var(--bronze);
  color: var(--white);
  transform: translateY(-2px);
  box-shadow: 0 10px 25px rgba(160, 120, 64, 0.15);
}

.btn-secondary {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink2);
}
.btn-secondary:hover {
  border-color: var(--bronze);
  color: var(--bronze);
  transform: translateY(-2px);
}

/* --- Luxury Header Navbar --- */
.luxury-navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 900;
  height: 80px;
  background: rgba(250, 246, 240, 0.94);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  transition: var(--transition-medium);
  display: flex;
  align-items: center;
}
.luxury-navbar.shadow {
  box-shadow: 0 4px 30px rgba(26, 22, 18, 0.05);
}

.nav-container {
  width: 100%;
  max-width: var(--container-max-width);
  margin: 0 auto;
  padding: 0 4vw 0 2vw;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.brand-logo {
  text-decoration: none;
  display: flex;
  align-items: center;
  color: var(--ink);
}

.logo-wrapper {
  display: flex;
  align-items: center;
  gap: 0.9rem;
}

.logo-icon-image {
  width: 58px;
  height: 58px;
  object-fit: contain;
  transition: var(--transition-smooth);
}
.brand-logo:hover .logo-icon-image {
  transform: scale(1.05);
}

.logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1;
}
.logo-main {
  font-family: var(--font-serif);
  font-size: 1.45rem;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: 0.02em;
}
.logo-sub {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--bronze);
  margin-top: 2px;
}
.logo-desc {
  display: none; /* Hidden on header navbar, shown in footer */
}

/* Nav Links */
.nav-links {
  display: flex;
  gap: 1.5rem;
  list-style: none;
  align-items: center;
}

.nav-item {
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mid);
  text-decoration: none;
  position: relative;
  padding: 0.5rem 0;
  transition: color var(--transition-fast);
}
.nav-item::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--bronze);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease;
}
.nav-item:hover, .nav-item.act {
  color: var(--bronze);
}
.nav-item:hover::after, .nav-item.act::after {
  transform: scaleX(1);
}

/* Nav booking button */
.btn-nav {
  font-size: 0.65rem;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--white);
  background: var(--bronze);
  border: none;
  padding: 0.52rem 1.3rem;
  cursor: pointer;
  text-decoration: none;
  transition: background var(--transition-fast);
  white-space: nowrap;
}
.btn-nav:hover {
  background: var(--ink);
}

/* Hamburger toggle for mobile */
.hbg {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 6px;
  background: transparent;
  border: none;
  z-index: 1001;
}
.hbg span {
  display: block;
  width: 22px;
  height: 1px;
  background: var(--ink);
  transition: var(--transition-fast);
}
.hbg[aria-expanded="true"] span:nth-child(1) {
  transform: rotate(45deg) translate(4px, 4px);
}
.hbg[aria-expanded="true"] span:nth-child(2) {
  opacity: 0;
}
.hbg[aria-expanded="true"] span:nth-child(3) {
  transform: rotate(-45deg) translate(4px, -4px);
}

/* Mobile Drawer Menu */
.mob-menu {
  display: flex;
  position: fixed;
  top: 80px;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--warm);
  z-index: 850;
  flex-direction: column;
  padding: 2.5rem 8vw;
  gap: 0;
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.4s ease;
  overflow-y: auto;
}
.mob-menu.open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.mob-menu a {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 400;
  color: var(--ink);
  text-decoration: none;
  padding: 0.85rem 0;
  border-bottom: 1px solid var(--border);
  transition: color var(--transition-fast);
}
.mob-menu a:hover, .mob-menu a.act {
  color: var(--bronze);
  padding-left: 8px;
}

/* --- SPA Pages Toggle System --- */
.page {
  display: none;
  padding-top: 80px;
  min-height: calc(100vh - 80px);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.45s cubic-bezier(0.25, 1, 0.5, 1), transform 0.45s cubic-bezier(0.25, 1, 0.5, 1);
}
.page.visible {
  display: block;
}
.page.act {
  opacity: 1;
  transform: translateY(0);
}

/* Eliminate excessive spacing gaps between navbar and page headers */
.page > section:first-of-type {
  padding-top: 3rem;
}
.page > .cat-hero .cat-hero-info {
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
}
.page > .gem-hero .gem-hero-text {
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
}
.page > .lounge-section {
  padding-top: 4.5rem;
  padding-bottom: 4.5rem;
}
.page > .big-feature {
  padding-top: 4.5rem;
  padding-bottom: 4.5rem;
}

/* --- Global Section Settings --- */
section {
  padding: 5.5rem 8vw;
  max-width: var(--container-max-width);
  margin: 0 auto;
}
.s-label {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--bronze);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.8rem;
}
.s-label::before {
  content: '';
  width: 24px;
  height: 1px;
  background: var(--bronze);
}
.s-title {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 3.8vw, 3rem);
  font-weight: 400;
  line-height: 1.15;
  color: var(--ink);
  margin-bottom: 1.5rem;
}
.s-body {
  font-size: 1.05rem;
  font-weight: 400;
  line-height: 1.9;
  color: var(--mid);
  max-width: 650px;
}

/* --- Image Placeholders & Fallbacks --- */
.img-placeholder {
  width: 100%;
  background: var(--cream);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.img-fb {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-serif);
  font-style: italic;
  color: rgba(160, 120, 64, 0.35);
  font-size: clamp(0.72rem, 1.8vw, 0.95rem);
  text-align: center;
  padding: 1rem;
  position: absolute;
  inset: 0;
  background: var(--cream);
}

/* ══════════════ HOME PAGE SECTIONS ══════════════ */

/* Hero Section */
.hero {
  position: relative;
  height: calc(100vh - 80px);
  min-height: 580px;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  overflow: hidden;
  max-width: none;
  margin: 0;
  padding: 0;
}
.hero-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 5vw 4vw 5vw 8vw;
  position: relative;
  z-index: 2;
  background: var(--warm);
}
.hero-right {
  position: relative;
  overflow: hidden;
  background: var(--warm);
}
.hero-right img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  opacity: 0.94;
  transition: transform 8s ease;
}
.hero:hover .hero-right img {
  transform: scale(1.04);
}
.hero-right::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--warm) 0%, rgba(250, 246, 240, 0.4) 30%, transparent 55%),
              linear-gradient(0deg, var(--warm) 0%, rgba(250, 246, 240, 0.3) 15%, transparent 35%),
              linear-gradient(180deg, var(--warm) 0%, rgba(250, 246, 240, 0.2) 10%, transparent 25%);
  pointer-events: none;
}

.hero-eyebrow {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--bronze);
  margin-bottom: 1.8rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.hero-eyebrow::before {
  content: '';
  width: 32px;
  height: 1px;
  background: var(--bronze);
}
.hero h1 {
  font-family: var(--font-serif);
  font-size: clamp(2.6rem, 5vw, 4.2rem);
  font-weight: 400;
  line-height: 1.1;
  color: var(--ink);
  margin-bottom: 2rem;
}
.hero-sub {
  font-size: 1.08rem;
  font-weight: 400;
  line-height: 1.85;
  color: var(--mid);
  max-width: 520px;
  margin-bottom: 2.5rem;
}
.hero-btns {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.hero-scroll {
  position: absolute;
  bottom: 2.5rem;
  left: 8vw;
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--soft);
  display: flex;
  align-items: center;
  gap: 0.8rem;
}
.hero-scroll::before {
  content: '';
  width: 24px;
  height: 1px;
  background: var(--soft);
}

/* Marquee scrolling banner */
.mq {
  background: var(--ink);
  padding: 0.85rem 0;
  overflow: hidden;
  display: flex;
}
.mq-track {
  display: flex;
  gap: 2.5rem;
  white-space: nowrap;
  animation: mqRun 32s linear infinite;
}
.mq-track span {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(232, 212, 168, 0.7);
  display: flex;
  align-items: center;
}
.mq-track .dot {
  color: var(--bronze-light);
  font-size: 0.8rem;
}
@keyframes mqRun {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* Founding Promise / Values Strip */
.values-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  margin-top: 3.5rem;
}
.v-box {
  background: var(--warm);
  padding: 2.5rem 2rem;
  transition: var(--transition-medium);
  border: 1px solid transparent;
}
.v-box:hover {
  background: var(--bronze-ultra);
  border-color: rgba(160, 120, 64, 0.2);
  transform: translateY(-4px);
}
.v-icon {
  font-size: 1.5rem;
  margin-bottom: 1.2rem;
  display: block;
  color: var(--bronze);
}
.v-box h3 {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 0.7rem;
}
.v-box p {
  font-size: 0.95rem;
  font-weight: 400;
  line-height: 1.75;
  color: var(--mid);
}

/* Category visual grid strip */
.img-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-top: 2.5rem;
}
.img-strip-item {
  aspect-ratio: 0.85;
  overflow: hidden;
  position: relative;
  background: var(--cream);
  border: 1px solid var(--border);
  transition: var(--transition-smooth);
}
.img-strip-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.7s cubic-bezier(0.25, 1, 0.5, 1);
}
.img-strip-item:hover {
  border-color: var(--bronze);
  box-shadow: 0 12px 30px rgba(160, 120, 64, 0.15);
}
.img-strip-item:hover img {
  transform: scale(1.05);
}
.img-strip-item span {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(transparent, rgba(26, 22, 18, 0.85));
  padding: 2.5rem 1.2rem 1.2rem;
  font-family: var(--font-sans);
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.95);
  transition: color var(--transition-fast);
}
.img-strip-item:hover span {
  color: var(--bronze-pale);
}

/* ══════════════ CATEGORY HERO PAGES ══════════════ */

.cat-hero {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 0;
  min-height: 500px;
  background: var(--bronze-ultra);
  max-width: none;
  margin: 0;
  padding: 0;
  border-bottom: 1px solid var(--border);
}
.cat-hero-info {
  padding: 5rem 6vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.cat-hero-img {
  position: relative;
  overflow: hidden;
  background: var(--cream);
}
.cat-hero-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.95;
}
.karat-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--white);
  background: var(--bronze);
  padding: 0.45rem 1rem;
  margin-bottom: 1.8rem;
  width: fit-content;
}

.items-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.8rem;
  margin: 1.8rem 0;
}
.item-tag {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 300;
  color: var(--mid);
  background: var(--warm);
  border: 1px solid var(--border);
  padding: 0.35rem 0.9rem;
  transition: var(--transition-fast);
}
.item-tag:hover {
  border-color: var(--bronze);
  color: var(--bronze);
  background: var(--white);
}
.item-tag.order {
  border-style: dashed;
  opacity: 0.8;
  background: transparent;
}
.item-tag.order:hover {
  background: var(--white);
}

.collections-row {
  margin-top: 2.2rem;
  border-top: 1px solid rgba(160, 120, 64, 0.12);
  padding-top: 1.8rem;
}
.collections-row h4 {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 0.9rem;
  letter-spacing: 0.02em;
}
.coll-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}
.coll-pill {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bronze);
  border: 1px solid var(--bronze-pale);
  padding: 0.35rem 1rem;
  background: var(--white);
  transition: var(--transition-fast);
  cursor: default;
}
.coll-pill:hover {
  background: var(--bronze);
  color: var(--white);
  border-color: var(--bronze);
}

/* Product Card Grid */
.product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 2rem;
  margin-top: 3rem;
}
.product-card {
  border: 1px solid var(--border);
  background: var(--white);
  overflow: hidden;
  transition: var(--transition-medium);
  cursor: pointer;
  display: flex;
  flex-direction: column;
}
.product-card:hover {
  border-color: var(--bronze);
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(160, 120, 64, 0.1);
}
.product-card-img {
  aspect-ratio: 1;
  background: var(--cream);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.product-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}
.product-card:hover .product-card-img img {
  transform: scale(1.05);
}
.product-card-body {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}
.product-card-body h4 {
  font-family: var(--font-serif);
  font-size: 1.1rem;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 0.5rem;
  letter-spacing: 0.01em;
}
.product-card-body p {
  font-size: 0.8rem;
  font-weight: 300;
  line-height: 1.65;
  color: var(--mid);
  flex-grow: 1;
  margin-bottom: 1.2rem;
}
.product-card-badge {
  font-family: var(--font-sans);
  font-size: 0.6rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bronze);
  display: block;
}

/* ══════════════ EXCLUSIVE FLOOR SECTIONS ══════════════ */

.big-feature {
  background: var(--ink);
  max-width: none;
  margin: 0;
  padding: 6.5rem 8vw;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
  border-bottom: 1px solid rgba(160, 120, 64, 0.15);
}
.big-feature .s-label {
  color: rgba(232, 212, 168, 0.65);
}
.big-feature .s-label::before {
  background: rgba(232, 212, 168, 0.65);
}
.big-feature .s-title {
  color: var(--bronze-ultra);
}
.big-feature .s-body {
  color: rgba(240, 232, 216, 0.85);
  margin-bottom: 2rem;
}
.big-feature-img {
  position: relative;
  aspect-ratio: 0.85;
  overflow: hidden;
  border: 1px solid rgba(160, 120, 64, 0.22);
  background: var(--ink2);
}
.big-feature-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.9;
  transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}
.big-feature:hover .big-feature-img img {
  transform: scale(1.03);
}
.big-feature-img::before {
  content: 'Exclusive Showcase';
  position: absolute;
  top: 1.2rem;
  left: 1.2rem;
  z-index: 2;
  font-family: var(--font-sans);
  font-size: 0.58rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--bronze-light);
  padding: 0.35rem 0.9rem;
}

.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
}
.two-col.flip {
  direction: rtl;
}
.two-col.flip > * {
  direction: ltr;
}

/* ══════════════ SILVER GRID SECTIONS ══════════════ */

.silver-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 2rem;
  margin-top: 3.5rem;
}
.silver-card {
  background: var(--white);
  border: 1px solid var(--border);
  overflow: hidden;
  transition: var(--transition-medium);
  display: flex;
  flex-direction: column;
}
.silver-card:hover {
  border-color: var(--bronze);
  transform: translateY(-3px);
  box-shadow: 0 15px 35px rgba(160, 120, 64, 0.08);
}
.silver-card-img {
  aspect-ratio: 1;
  background: var(--cream);
  overflow: hidden;
  position: relative;
}
.silver-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}
.silver-card:hover .silver-card-img img {
  transform: scale(1.04);
}
.silver-card-info {
  padding: 1.2rem;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}
.silver-card-info h4 {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 0.4rem;
}
.silver-card-info p {
  font-size: 0.78rem;
  font-weight: 300;
  line-height: 1.6;
  color: var(--mid);
}

/* ══════════════ GEMSTONES GALLERY ══════════════ */

.gem-hero {
  background: var(--ink2);
  min-height: 500px;
  display: grid;
  grid-template-columns: 1.25fr 0.75fr;
  position: relative;
  overflow: hidden;
  max-width: none;
  margin: 0;
  padding: 0;
}
.gem-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 100% at 80% 50%, rgba(160, 120, 64, 0.15), transparent);
  pointer-events: none;
}
.gem-hero-text {
  padding: 5rem 6vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
  z-index: 2;
}
.gem-hero-text .s-label {
  color: rgba(232, 212, 168, 0.65);
}
.gem-hero-text .s-label::before {
  background: rgba(232, 212, 168, 0.65);
}
.gem-hero-text .s-title {
  color: var(--warm);
}
.gem-hero-text .s-body {
  color: rgba(240, 232, 216, 0.85);
}

.gem-orb-area {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 4rem 2rem;
  z-index: 2;
}
.gem-orb {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: radial-gradient(circle at 38% 38%, rgba(160, 120, 64, 0.2), rgba(26, 22, 18, 0.5));
  border: 1px solid rgba(160, 120, 64, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  animation: breathe 8s ease-in-out infinite alternate;
}
.gem-orb::before {
  content: '';
  position: absolute;
  inset: 12px;
  border-radius: 50%;
  border: 1px solid rgba(160, 120, 64, 0.12);
}
.gem-orb-txt {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-style: italic;
  color: var(--bronze-light);
  text-align: center;
  line-height: 1.4;
  letter-spacing: 0.05em;
}
.gem-orb-txt span {
  display: block;
  font-family: var(--font-accent);
  font-size: 2.2rem;
  font-style: normal;
  font-weight: 400;
  margin-bottom: 0.2rem;
  color: var(--bronze-pale);
}

@keyframes breathe {
  0% { transform: scale(1); box-shadow: 0 0 20px rgba(160, 120, 64, 0.1); }
  100% { transform: scale(1.04); box-shadow: 0 0 40px rgba(160, 120, 64, 0.25); }
}

.gem-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 1rem;
  margin-top: 3rem;
}
.gem-pill {
  background: var(--white);
  border: 1px solid var(--border);
  padding: 1.5rem 1rem;
  text-align: center;
  transition: var(--transition-medium);
  cursor: default;
}
.gem-pill:hover {
  border-color: var(--bronze);
  background: var(--bronze-ultra);
  transform: translateY(-2px);
}
.gem-pill .gem-img {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  margin: 0 auto 1.2rem;
  border: 1px solid var(--border);
  box-shadow: 0 4px 12px rgba(160, 120, 64, 0.08);
  display: block;
  object-fit: cover;
  background: var(--white);
  transition: transform 0.5s cubic-bezier(0.25, 1, 0.5, 1), border-color 0.5s ease;
}
.gem-pill:hover .gem-img {
  transform: scale(1.06);
  border-color: var(--bronze);
  box-shadow: 0 8px 20px rgba(160, 120, 64, 0.16);
}
.gem-pill p {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink);
  font-weight: 400;
}

/* ══════════════ JEWEL LOUNGE ══════════════ */

.lounge-section {
  background: linear-gradient(135deg, var(--ink) 0%, #2a2218 100%);
  max-width: none;
  margin: 0;
  padding: 6.5rem 8vw;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid rgba(160, 120, 64, 0.15);
}
.lounge-section::before {
  content: 'LOUNGE';
  position: absolute;
  right: -2%;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-serif);
  font-size: clamp(90px, 14vw, 200px);
  font-weight: 700;
  color: rgba(160, 120, 64, 0.04);
  letter-spacing: 0.1em;
  pointer-events: none;
  white-space: nowrap;
}
.lounge-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
}
.lounge-img {
  aspect-ratio: 0.8;
  background: var(--ink2);
  border: 1px solid rgba(160, 120, 64, 0.2);
  overflow: hidden;
  position: relative;
}
.lounge-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.9;
  transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}
.lounge-grid:hover .lounge-img img {
  transform: scale(1.03);
}
.lounge-img::after {
  content: 'By Appointment Only';
  position: absolute;
  bottom: 1.5rem;
  left: 1.5rem;
  right: 1.5rem;
  background: rgba(26, 22, 18, 0.9);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  font-family: var(--font-sans);
  font-size: 0.65rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--bronze-light);
  padding: 0.85rem 1rem;
  text-align: center;
  border: 1px solid rgba(160, 120, 64, 0.2);
}
.lounge-text .s-label {
  color: rgba(232, 212, 168, 0.6);
}
.lounge-text .s-label::before {
  background: rgba(232, 212, 168, 0.6);
}
.lounge-text .s-title {
  color: var(--warm);
}
.lounge-text .s-body {
  color: rgba(240, 232, 216, 0.85);
}

.lounge-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
  margin: 2.2rem 0;
}
.lounge-feat {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(160, 120, 64, 0.15);
  padding: 1.5rem;
  transition: var(--transition-medium);
}
.lounge-feat:hover {
  border-color: rgba(160, 120, 64, 0.45);
  background: rgba(255, 255, 255, 0.05);
}
.lounge-feat h4 {
  font-family: var(--font-serif);
  font-size: 1rem;
  font-weight: 400;
  color: var(--bronze-pale);
  margin-bottom: 0.5rem;
}
.lounge-feat p {
  font-size: 0.75rem;
  font-weight: 300;
  color: rgba(240, 232, 216, 0.7);
  line-height: 1.65;
}

/* ══════════════ HERITAGE & AUTHENTICITY ══════════════ */

.auth-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  margin-top: 4rem;
  align-items: start;
}
.auth-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.auth-item {
  padding: 1.8rem 2rem;
  border-left: 3px solid var(--bronze-pale);
  transition: var(--transition-medium);
  background: var(--white);
  box-shadow: 0 4px 15px rgba(26,22,18,0.02);
}
.auth-item:hover {
  border-left-color: var(--bronze);
  box-shadow: 0 10px 25px rgba(160, 120, 64, 0.05);
  transform: translateX(4px);
}
.auth-item h4 {
  font-family: var(--font-serif);
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 0.6rem;
}
.auth-item p {
  font-size: 0.85rem;
  font-weight: 300;
  line-height: 1.8;
  color: var(--mid);
}

.auth-seal {
  background: var(--ink);
  padding: 4rem 3rem;
  text-align: center;
  position: sticky;
  top: 96px;
  border: 1px solid rgba(160, 120, 64, 0.2);
}
.seal-ring {
  width: 96px;
  height: 96px;
  border-radius: 50%;
  border: 2px solid var(--bronze);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.8rem;
  font-size: 2.2rem;
  color: var(--bronze-pale);
  background: var(--ink2);
}
.auth-seal h3 {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-weight: 400;
  color: var(--warm);
  margin-bottom: 1rem;
}
.auth-seal p {
  font-size: 0.85rem;
  font-weight: 300;
  line-height: 1.8;
  color: rgba(240, 232, 216, 0.8);
  margin-bottom: 2rem;
}
.badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  justify-content: center;
}
.bdg {
  font-family: var(--font-sans);
  font-size: 0.62rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bronze-light);
  border: 1px solid rgba(160, 120, 64, 0.35);
  padding: 0.4rem 1rem;
  background: rgba(255, 255, 255, 0.02);
}

/* ══════════════ ABOUT & SHOWROOM ══════════════ */

.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: start;
}
.about-img-wrap {
  position: relative;
}
.about-img-main {
  aspect-ratio: 0.78;
  background: var(--cream);
  overflow: hidden;
  border: 1px solid var(--border);
}
.about-img-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.about-card-float {
  position: absolute;
  bottom: -2rem;
  right: -2rem;
  background: var(--bronze);
  padding: 2.2rem;
  min-width: 230px;
  box-shadow: 0 15px 35px rgba(26,22,18,0.15);
  border: 1px solid rgba(255,255,255,0.1);
}
.about-card-float h3 {
  font-family: var(--font-serif);
  font-size: 2.4rem;
  font-weight: 400;
  color: var(--white);
  line-height: 1;
}
.about-card-float p {
  font-family: var(--font-sans);
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
  margin-top: 0.4rem;
}

.about-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  margin: 3.5rem 0 2.5rem;
}
.stat {
  background: var(--warm);
  padding: 2rem 1.5rem;
  text-align: center;
}
.stat strong {
  font-family: var(--font-serif);
  font-size: 2.2rem;
  font-weight: 400;
  color: var(--bronze);
  display: block;
  margin-bottom: 0.3rem;
}
.stat p {
  font-family: var(--font-sans);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--soft);
}

.team-row {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 2rem;
}
.team-item {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  padding: 1.2rem;
  border: 1px solid var(--border);
  background: var(--white);
  transition: var(--transition-medium);
}
.team-item:hover {
  border-color: var(--bronze);
  box-shadow: 0 8px 20px rgba(160, 120, 64, 0.05);
}
.team-ava {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--bronze-pale);
  border: 1px solid var(--border-strong);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-serif);
  font-size: 1.25rem;
  color: var(--bronze);
  flex-shrink: 0;
}
.team-item h4 {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--ink);
}
.team-item p {
  font-size: 0.78rem;
  font-weight: 300;
  color: var(--mid);
  line-height: 1.4;
  margin-top: 2px;
}

/* ══════════════ JOURNAL / BLOG SECTIONS ══════════════ */

.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 2.5rem;
  margin-top: 3.5rem;
}
.blog-card {
  border: 1px solid var(--border);
  background: var(--white);
  overflow: hidden;
  transition: var(--transition-medium);
  cursor: pointer;
  display: flex;
  flex-direction: column;
}
.blog-card:hover {
  border-color: var(--bronze);
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(160, 120, 64, 0.1);
}
.blog-thumb {
  height: 200px;
  background: var(--cream);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.blog-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}
.blog-card:hover .blog-thumb img {
  transform: scale(1.05);
}
.blog-cat {
  position: absolute;
  top: 1.2rem;
  left: 1.2rem;
  font-family: var(--font-sans);
  font-size: 0.58rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--white);
  background: var(--bronze);
  padding: 0.35rem 0.8rem;
  z-index: 2;
}
.blog-body {
  padding: 1.8rem;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}
.blog-meta {
  font-family: var(--font-sans);
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  color: var(--soft);
  margin-bottom: 0.8rem;
  text-transform: uppercase;
}
.blog-card h3 {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--ink);
  line-height: 1.35;
  margin-bottom: 0.8rem;
}
.blog-card p {
  font-size: 0.85rem;
  font-weight: 300;
  line-height: 1.75;
  color: var(--mid);
  flex-grow: 1;
}
.blog-read {
  font-family: var(--font-sans);
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bronze);
  margin-top: 1.5rem;
  display: block;
  transition: transform var(--transition-fast);
}
.blog-card:hover .blog-read {
  transform: translateX(4px);
}

/* ══════════════ INTERACTIVE BESPOKE CUSTOMIZER ══════════════ */

.customizer-section {
  padding: 6rem 8vw;
  background: var(--bronze-ultra);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  max-width: none;
  margin: 0;
}
.customizer-container {
  max-width: var(--container-max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 5rem;
  align-items: center;
}
.customizer-info {
  display: flex;
  flex-direction: column;
}
.customizer-desc {
  font-size: 0.95rem;
  margin-bottom: 2.5rem;
  color: var(--mid);
}

.customizer-controls {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.control-group {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.group-label {
  font-family: var(--font-sans);
  font-size: 0.68rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bronze);
  font-weight: 500;
}

.option-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}
.opt-btn {
  background: var(--white);
  border: 1px solid var(--border);
  padding: 0.8rem 1.4rem;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--ink);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  transition: var(--transition-medium);
}
.opt-btn:hover {
  border-color: var(--bronze);
  background: var(--warm);
}
.opt-btn.active {
  border-color: var(--ink);
  background: var(--ink);
  color: var(--white);
}

/* Metal color preview dots */
.color-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  display: inline-block;
  border: 1px solid rgba(0,0,0,0.1);
}
.color-dot.yellow-gold { background: radial-gradient(circle, #fce0ad 0%, #dca450 100%); }
.color-dot.white-gold { background: radial-gradient(circle, #f0f0f0 0%, #b8b8b8 100%); }
.color-dot.rose-gold { background: radial-gradient(circle, #fcd8c4 0%, #e09478 100%); }

.color-dot.diamond-dot { background: radial-gradient(circle, #ffffff 0%, #ccd8e0 100%); }
.color-dot.emerald-dot { background: radial-gradient(circle, #48b880 0%, #0c7040 100%); }
.color-dot.sapphire-dot { background: radial-gradient(circle, #4c68d8 0%, #0c2088 100%); }

/* Customizer Preview Box */
.customizer-preview {
  display: flex;
  justify-content: center;
}
.preview-box {
  background: var(--white);
  border: 1px solid var(--border);
  padding: 2rem;
  width: 100%;
  max-width: 440px;
  display: flex;
  flex-direction: column;
  transition: var(--transition-smooth);
}
.preview-canvas-placeholder {
  position: relative;
  aspect-ratio: 1;
  background: var(--cream);
  overflow: hidden;
  border: 1px solid rgba(160, 120, 64, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
}
.preview-canvas-placeholder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity 0.25s ease, filter 0.4s ease;
}
.preview-overlay-text {
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  right: 1rem;
  background: rgba(26, 22, 18, 0.85);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  padding: 0.65rem 0.95rem;
  color: var(--white);
  font-family: var(--font-sans);
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-align: center;
  border: 1px solid rgba(255,255,255,0.08);
}
.preview-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 1.5rem;
  gap: 1rem;
}
.est-price {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-style: italic;
  color: var(--bronze);
  letter-spacing: 0.02em;
}

/* Customizer Glow states depending on selected metal */
.preview-box.yellow-gold-glow { box-shadow: 0 15px 40px rgba(160, 120, 64, 0.14); }
.preview-box.white-gold-glow { box-shadow: 0 15px 40px rgba(120, 128, 140, 0.12); }
.preview-box.rose-gold-glow { box-shadow: 0 15px 40px rgba(196, 120, 100, 0.14); }

/* ══════════════ CONTACT & APPOINTMENT FORM ══════════════ */

.contact-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 5rem;
  margin-top: 3.5rem;
}

.c-form {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  background: var(--white);
  border: 1px solid var(--border);
  padding: 3rem 2.5rem;
  box-shadow: 0 4px 25px rgba(26,22,18,0.02);
}
.f-group {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.f-group label {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bronze);
  font-weight: 500;
}
.f-group input, .f-group select, .f-group textarea {
  font-family: var(--font-sans);
  font-size: 0.88rem;
  font-weight: 300;
  color: var(--ink);
  background: var(--warm);
  border: 1px solid var(--border);
  padding: 0.9rem 1.1rem;
  outline: none;
  transition: var(--transition-fast);
  border-radius: 0;
  width: 100%;
}
.f-group input:focus, .f-group select:focus, .f-group textarea:focus {
  border-color: var(--ink);
  background: var(--white);
  box-shadow: 0 4px 12px rgba(26,22,18,0.03);
}

.f-group input.error, .f-group select.error, .f-group textarea.error {
  border-color: #d05050;
  background: #fdf5f5;
}
.error-msg {
  color: #c04040;
  font-size: 0.68rem;
  margin-top: 0.2rem;
  font-weight: 300;
  letter-spacing: 0.02em;
}

.f-half {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
}
.c-form button[type="submit"] {
  border: none;
  cursor: pointer;
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 1.1rem;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.c-info {
  display: flex;
  flex-direction: column;
  gap: 2.2rem;
}
.c-block h3 {
  font-family: var(--font-serif);
  font-size: 1.35rem;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 0.8rem;
}
.c-block p {
  font-size: 0.88rem;
  font-weight: 300;
  line-height: 1.8;
  color: var(--mid);
}
.c-link {
  color: var(--bronze);
  text-decoration: none;
  font-size: 0.82rem;
  font-family: var(--font-sans);
  letter-spacing: 0.05em;
  display: inline-block;
  margin-top: 0.4rem;
  position: relative;
  transition: color var(--transition-fast);
}
.c-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--bronze-pale);
  transform: scaleX(1);
  transition: transform 0.3s ease;
}
.c-link:hover {
  color: var(--bronze-light);
}
.c-link:hover::after {
  transform: scaleX(0);
}

.maps-cta {
  margin-top: 1rem;
  border-color: var(--bronze-pale) !important;
  color: var(--bronze) !important;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  padding: 0.8rem 1.4rem;
  display: inline-flex;
}
.maps-cta:hover {
  background: var(--bronze) !important;
  border-color: var(--bronze) !important;
  color: var(--white) !important;
}

.hours-g {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 0.5rem 1.5rem;
  margin-top: 0.8rem;
}
.hours-g span {
  font-size: 0.82rem;
  font-weight: 300;
  color: var(--mid);
}
.hours-g .d {
  font-weight: 400;
  color: var(--ink);
}

.social-row {
  display: flex;
  gap: 0.8rem;
  margin-top: 1rem;
  flex-wrap: wrap;
}
.soc-btn {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--bronze);
  border: 1px solid var(--bronze-pale);
  padding: 0.5rem 1.1rem;
  text-decoration: none;
  transition: var(--transition-fast);
  background: var(--white);
}
.soc-btn:hover {
  background: var(--bronze);
  color: var(--white);
  border-color: var(--bronze);
}

/* Spinner element for AJAX submission */
.btn-submit.loading .spinner {
  display: inline-block;
}
.spinner {
  display: none;
  width: 18px;
  height: 18px;
  border: 2px solid rgba(255,255,255,0.3);
  border-radius: 50%;
  border-top-color: var(--white);
  animation: spin 0.8s linear infinite;
  margin-left: 8px;
}
@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Inline success alert widget styling */
.form-success-alert {
  background: var(--bronze-ultra);
  border: 1px solid var(--border-strong);
  padding: 1.5rem;
  margin-top: 1rem;
  font-size: 0.85rem;
  color: var(--ink);
  line-height: 1.7;
  display: none;
}
.form-success-alert strong {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  color: var(--ink);
  display: block;
  margin-bottom: 0.4rem;
}

/* ══════════════ GENERAL / MISCELLANEOUS ══════════════ */

/* Toast Widget */
.toast {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 1000;
  background: var(--ink);
  color: var(--warm);
  padding: 1rem 1.8rem;
  font-size: 0.82rem;
  font-weight: 300;
  border-left: 3px solid var(--bronze);
  transform: translateY(80px);
  opacity: 0;
  transition: var(--transition-smooth);
  max-width: 320px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.15);
}
.toast.on {
  transform: translateY(0);
  opacity: 1;
}

/* Divider pattern between sections */
.divider {
  text-align: center;
  padding: 3rem 0;
  font-family: var(--font-serif);
  font-size: 1.3rem;
  color: var(--bronze-pale);
  letter-spacing: 0.8rem;
  user-select: none;
}

/* Comparison Table (Silver & Gemstones) */
.cmp-table-wrap {
  overflow-x: auto;
  margin-top: 2.5rem;
  border: 1px solid var(--border);
}
table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
  background: var(--white);
}
thead th {
  font-family: var(--font-sans);
  font-size: 0.62rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 1.2rem 1.5rem;
  text-align: left;
  font-weight: 400;
  border-bottom: 2px solid var(--bronze);
}
thead th:first-child {
  color: var(--mid);
}
thead th:nth-child(2) {
  background: var(--ink);
  color: var(--bronze-pale);
}
thead th:nth-child(3), thead th:nth-child(4) {
  background: var(--cream);
  color: var(--mid);
}
tbody tr {
  border-bottom: 1px solid var(--border);
}
tbody tr:hover td {
  background: rgba(160, 120, 64, 0.02);
}
tbody td {
  padding: 1.1rem 1.5rem;
  font-weight: 300;
  color: var(--mid);
  vertical-align: top;
  line-height: 1.7;
}
tbody td:first-child {
  font-weight: 400;
  color: var(--ink);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
}
tbody td:nth-child(2) {
  color: var(--ink);
}
.ck { color: #5a9a6a; font-size: 1.1rem; }
.cx { color: #c06060; font-size: 1.1rem; }
.cp { color: var(--bronze); font-size: 1.1rem; }
.hoj-tag {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 0.55rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: var(--bronze-pale);
  color: var(--bronze);
  padding: 0.2rem 0.5rem;
  margin-left: 0.4rem;
  font-weight: 500;
}

/* ══════════════ LUXURY FOOTER ══════════════ */

footer {
  background: var(--ink);
  padding: 5.5rem 8vw 2.5rem;
  border-top: 2px solid var(--bronze);
}
.ft-top {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1.2fr;
  gap: 4rem;
  padding-bottom: 4rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  margin-bottom: 2rem;
  max-width: var(--container-max-width);
  margin-left: auto;
  margin-right: auto;
}
.ft-brand .brand-logo {
  color: var(--warm);
  margin-bottom: 1.5rem;
}
.ft-brand .logo-icon-image {
  border: none;
  background: transparent;
}
.ft-brand .logo-main {
  color: var(--warm);
}
.ft-brand .logo-sub {
  color: var(--bronze-pale);
}
.ft-brand p {
  font-size: 0.8rem;
  font-weight: 300;
  line-height: 1.85;
  color: rgba(240, 232, 216, 0.65);
  max-width: 280px;
}
.ft-col h4 {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--bronze-pale);
  margin-bottom: 1.5rem;
  font-weight: 400;
}
.ft-col ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.ft-col ul a {
  font-size: 0.82rem;
  font-weight: 300;
  color: rgba(240, 232, 216, 0.7);
  text-decoration: none;
  transition: var(--transition-fast);
}
.ft-col ul a:hover {
  color: var(--bronze-light);
  padding-left: 2px;
}
.ft-bot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.5rem;
  max-width: var(--container-max-width);
  margin-left: auto;
  margin-right: auto;
}
.ft-bot p {
  font-size: 0.72rem;
  font-weight: 300;
  color: rgba(240, 232, 216, 0.45);
}
.socs {
  display: flex;
  gap: 0.8rem;
}
.socs a {
  width: 36px;
  height: 36px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(240, 232, 216, 0.6);
  text-decoration: none;
  font-size: 0.72rem;
  transition: var(--transition-fast);
}
.socs a:hover {
  border-color: var(--bronze);
  color: var(--bronze);
  background: rgba(255,255,255,0.03);
}

/* ══════════════ FLOATING WHATSAPP WIDGET ══════════════ */

.floating-whatsapp {
  position: fixed;
  bottom: 2rem;
  left: 2rem;
  z-index: 800;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-smooth);
  text-decoration: none;
}
.floating-whatsapp:hover {
  transform: scale(1.1);
}
.floating-whatsapp svg {
  width: 100%;
  height: 100%;
}

/* --- What We Offer Expanded Sections --- */
.offerings-wrapper {
  margin-top: 3.5rem;
  display: flex;
  flex-direction: column;
  gap: 4.5rem;
}
.offerings-group-title {
  font-family: var(--font-accent);
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bronze);
  margin-bottom: 2rem;
  display: flex;
  align-items: center;
  gap: 1.2rem;
}
.offerings-group-title::after {
  content: "";
  flex-grow: 1;
  height: 1px;
  background: var(--border);
}
.offerings-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
.offering-card {
  background: var(--white);
  border: 1px solid var(--border);
  overflow: hidden;
  transition: var(--transition-medium);
  display: flex;
  flex-direction: column;
}
.offering-card:hover {
  border-color: var(--bronze);
  transform: translateY(-4px);
  box-shadow: 0 15px 35px rgba(160, 120, 64, 0.08);
}
.offering-card-img {
  aspect-ratio: 1.15;
  overflow: hidden;
  position: relative;
  background: var(--cream);
}
.offering-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.25, 1, 0.5, 1);
}
.offering-card:hover .offering-card-img img {
  transform: scale(1.04);
}
.offering-card-info {
  padding: 1.5rem;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  background: var(--white);
  border-top: 1px solid var(--border);
}
.offering-card-info h3 {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 0.5rem;
}
.offering-card-info p {
  font-size: 0.92rem;
  line-height: 1.65;
  color: var(--mid);
  margin-bottom: 0;
}

@media(max-width: 900px) {
  .offerings-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media(max-width: 600px) {
  .offerings-grid {
    grid-template-columns: 1fr;
  }
}

/* ══════════════ RESPONSIVE BREAKPOINTS ══════════════ */

@media(max-width: 1024px) {
  .ft-top {
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
  }
  .customizer-container {
    grid-template-columns: 1fr;
    gap: 4rem;
  }
  .customizer-preview {
    order: -1;
  }
}

@media(max-width: 900px) {
  .nav-links, .btn-nav {
    display: none;
  }
  .hbg {
    display: flex;
  }
  .hero {
    grid-template-columns: 1fr;
    height: auto;
    min-height: auto;
  }
  .hero-right {
    min-height: 360px;
    display: block;
  }
  .hero-right::after {
    background: linear-gradient(180deg, var(--warm) 0%, rgba(250, 246, 240, 0.4) 25%, transparent 50%),
                linear-gradient(0deg, var(--warm) 0%, rgba(250, 246, 240, 0.3) 15%, transparent 35%);
  }
  .hero-left {
    padding: 5rem 6vw 4rem;
  }
  section {
    padding: 4rem 6vw;
  }
  .values-strip {
    grid-template-columns: 1fr 1fr;
  }
  .img-strip {
    grid-template-columns: 1fr 1fr;
  }
  .cat-hero {
    grid-template-columns: 1fr;
  }
  .cat-hero-img {
    min-height: 340px;
  }
  .big-feature {
    grid-template-columns: 1fr;
    padding: 4.5rem 6vw;
    gap: 3rem;
  }
  .big-feature-img {
    aspect-ratio: 1.1;
  }
  .two-col {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
  .gem-hero {
    grid-template-columns: 1fr;
  }
  .gem-orb-area {
    padding: 2rem;
  }
  .lounge-grid {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
  .auth-grid {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
  .auth-seal {
    position: static;
  }
  .about-grid {
    grid-template-columns: 1fr;
    gap: 4rem;
  }
  .about-card-float {
    position: relative;
    bottom: auto;
    right: auto;
    margin-top: 1rem;
    min-width: auto;
  }
  .contact-grid {
    grid-template-columns: 1fr;
    gap: 4rem;
  }
  .c-form {
    padding: 2.2rem 1.8rem;
  }
}

@media(max-width: 600px) {
  .values-strip {
    grid-template-columns: 1fr;
  }
  .img-strip {
    grid-template-columns: 1fr;
  }
  .f-half {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }
  .hours-g {
    grid-template-columns: 1fr;
    gap: 0.3rem;
  }
  .ft-top {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .ft-bot {
    flex-direction: column;
    text-align: center;
  }
}
