/* ================================================
   EXOTIC COLLECTION — Design System
   Dark Luxury Editorial · Legacy Heritage
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400;1,500&family=DM+Sans:wght@300;400;500&family=JetBrains+Mono:wght@400;500&display=swap');

html, h1, h2, h3, h4, .display-xl, .display-lg, .display-md {
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
}

body {
  overflow-x: hidden;
  width: 100%;
  max-width: 100%;
}
* {
  box-sizing: border-box;
  max-width: 100%;
  touch-action: manipulation;
  margin: 0;
  padding: 0;
}
img, video, iframe {
  max-width: 100%;
  height: auto;
  display: block;
}

:root {
  --bg-primary:   #07060A;
  --bg-card:      #0E0C14;
  --bg-surface:   #15121E;
  --bg-elevated:  #1C1828;
  --ruby:         #C0284A;
  --gold:         #C9A84C;
  --gold-light:   #E2C97A;
  --gold-dim:     #8A6E2E;
  --emerald:      #1A7A4A;
  --sapphire:     #2A5ABF;
  --pearl:        #F0ECE8;
  --muted:        #A89CB4;
  --border-gold:        1px solid rgba(201,168,76,0.12);
  --border-gold-hover:  1px solid rgba(201,168,76,0.35);
  --glow-gold:          0 0 40px rgba(201,168,76,0.15);
  --glow-gold-strong:   0 0 65px rgba(201,168,76,0.3);
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'DM Sans', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', 'Courier New', monospace;
  --ease-luxury:       cubic-bezier(0.25,0.46,0.45,0.94);
  --transition-slow:   0.6s var(--ease-luxury);
  --transition-medium: 0.4s var(--ease-luxury);
  --transition-fast:   0.22s var(--ease-luxury);
  --radius-sm:   2px;
  --radius-md:   6px;
  --radius-full: 9999px;

  /* 325px base font size */
  font-size: 14px;
}

@media (min-width: 375px) {
  :root { font-size: 15px; }
}
@media (min-width: 425px) {
  :root { font-size: 16px; }
}

h1, h2, h3, h4, .display-xl, .display-lg, .display-md {
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
}

body {
  background-color: var(--bg-primary);
  color: var(--pearl);
  font-family: var(--font-body);
  font-weight: 300;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a { color: inherit; text-decoration: none; padding: 4px 0; }
button { cursor: pointer; min-height: 44px; border: none; background: none; }

.display-xl{font-family:var(--font-display);font-size:clamp(3rem,7vw,5.5rem);font-weight:300;font-style:italic;line-height:1.08;color:var(--pearl)}
.display-lg{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.75rem);font-weight:300;font-style:italic;line-height:1.12}
.display-md{font-family:var(--font-display);font-size:clamp(1.6rem,3.5vw,2.5rem);font-weight:400;font-style:italic;line-height:1.2}
.section-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);font-weight:300;font-style:italic;color:var(--pearl);text-align:center;letter-spacing:0.02em}
.section-subtitle{font-family:var(--font-body);font-size:0.95rem;font-weight:300;color:var(--muted);text-align:center;letter-spacing:0.04em;margin-top:0.75rem;max-width:540px;margin-left:auto;margin-right:auto}
.label-mono{font-family:var(--font-mono);font-size:0.68rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted)}

.text-gold{color:var(--gold)}
.text-ruby{color:var(--ruby)}
.text-emerald{color:#4aad7e}
.text-muted{color:var(--muted)}
.text-pearl{color:var(--pearl)}

.container{width:100%;max-width:1280px;margin:0 auto;padding:0 0.5rem}@media(min-width:769px){.container{padding:0 2rem}}
.container-narrow{width:100%;max-width:860px;margin:0 auto;padding:0 2rem}
.section{padding:7rem 0}
.section-sm{padding:4rem 0}

.gold-divider{width:56px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:1.25rem auto}
.gold-divider-left{margin-left:0}

.pill{display:inline-flex;align-items:center;gap:.3rem;padding:.32rem .8rem;border-radius:var(--radius-full);border:var(--border-gold-hover);font-family:var(--font-mono);font-size:.62rem;font-weight:500;letter-spacing:.13em;text-transform:uppercase;color:var(--gold);background:rgba(201,168,76,.05)}
.pill-ruby{border-color:rgba(192,40,74,.4);color:#e05070;background:rgba(192,40,74,.06)}
.pill-emerald{border-color:rgba(26,122,74,.4);color:#4aad7e;background:rgba(26,122,74,.06)}
.pill-sapphire{border-color:rgba(42,90,191,.4);color:#6a90e8;background:rgba(42,90,191,.06)}
.pill-white{border-color:rgba(240,236,232,.2);color:var(--pearl);background:rgba(240,236,232,.04)}

.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.15rem;font-family:var(--font-body);font-size:.78rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:var(--radius-sm);transition:all var(--transition-medium);white-space:normal;text-align:center}
.btn-gold{background:linear-gradient(135deg,var(--gold) 0%,#a8862e 100%);color:var(--bg-primary)}
.btn-gold:hover{background:linear-gradient(135deg,var(--gold-light) 0%,var(--gold) 100%);box-shadow:var(--glow-gold-strong);transform:translateY(-2px)}
.btn-outline-gold{background:transparent;color:var(--gold);border:1px solid rgba(201,168,76,.45)}
.btn-outline-gold:hover{background:rgba(201,168,76,.07);border-color:var(--gold);box-shadow:var(--glow-gold);transform:translateY(-2px)}
.btn-whatsapp{background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);color:#fff;border-radius:var(--radius-md);font-size:.88rem;padding:.9rem 2rem}
.btn-whatsapp:hover{background:linear-gradient(135deg,#30e874 0%,#1ab8a6 100%);box-shadow:0 0 30px rgba(37,211,102,.35);transform:translateY(-2px)}

.card{background:var(--bg-card);border:var(--border-gold);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-medium)}
.card:hover{border-color:rgba(201,168,76,.28);box-shadow:var(--glow-gold);transform:translateY(-4px)}

.jewel-image-wrap{overflow:hidden;position:relative}
.jewel-image-wrap img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.jewel-image-wrap:hover img{transform:scale(1.04)}
.jewel-image-wrap:hover{box-shadow:var(--glow-gold)}

.stars{display:flex;gap:2px;color:var(--gold);font-size:.82rem}

.reveal{opacity:0;transform:translateY(28px);transition:opacity var(--transition-slow),transform var(--transition-slow)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* ─── Floating WhatsApp ─────────────────────────── */
.whatsapp-float {
  position: fixed;
  bottom: 20px;
  right: 16px;
  z-index: 9999;
  width: 52px;
  height: 52px;
  border-radius: var(--radius-full);
  background: linear-gradient(135deg,#25D366,#128C7E);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 24px rgba(37,211,102,0.38);
  transition: all var(--transition-medium);
}
@media (min-width: 769px) {
  .whatsapp-float { bottom: 2rem; right: 2rem; width: 58px; height: 58px; }
}
.whatsapp-float:hover { transform: scale(1.1) translateY(-2px); box-shadow: 0 8px 36px rgba(37,211,102,.52); }
.whatsapp-float svg { width: 24px; height: 24px; fill: white; }
@media (min-width: 769px) { .whatsapp-float svg { width: 28px; height: 28px; } }

/* ─── Navbar ────────────────────────────────────── */
.navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 900;
  height: 72px;
  padding: 0 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: rgba(7,6,10,0.82);
  border-bottom: var(--border-gold);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition: background var(--transition-medium), box-shadow var(--transition-medium);
}

@media (min-width: 769px) {
  .navbar { padding: 0 2.5rem; }
}

.navbar.scrolled {
  background: rgba(7,6,10,0.97);
  box-shadow: 0 2px 40px rgba(0,0,0,.6);
}

.nav-logo { display:flex; flex-direction:column; gap:1px; }
.nav-logo-name {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.15em;
  color: var(--gold);
  text-transform: uppercase;
  line-height: 1;
  transition: font-size var(--transition-fast);
}

@media (min-width: 375px) { .nav-logo-name { font-size: 18px; } }
@media (min-width: 425px) { .nav-logo-name { font-size: 20px; } }
@media (min-width: 1024px) { .nav-logo-name { font-size: 1.2rem; letter-spacing: 0.3em; } }

.nav-logo-sub { font-family:var(--font-mono); font-size:.57rem; letter-spacing:.14em; color:var(--muted); text-transform:uppercase; }

.nav-links { display: none; align-items:center; gap:2rem; list-style:none; }
@media (min-width: 769px) { .nav-links { display: flex; } }

.nav-links a { font-family:var(--font-body); font-size:.74rem; font-weight:400; letter-spacing:.1em; text-transform:uppercase; color:var(--pearl); transition:color var(--transition-fast); position:relative; }
.nav-links a::after { content:''; position:absolute; bottom:-3px; left:0; width:0; height:1px; background:var(--gold); transition:width var(--transition-medium); }
.nav-links a:hover, .nav-links a.active { color:var(--gold); }
.nav-links a:hover::after, .nav-links a.active::after { width:100%; }

.nav-hamburger {
  display: flex;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  padding: .5rem;
  width: 44px;
  height: 44px;
  justify-content: center;
  align-items: flex-end;
  z-index: 1001;
}
@media (min-width: 769px) { .nav-hamburger { display: none; } }

.nav-hamburger span { display:block; width:22px; height:1px; background:var(--pearl); transition:all var(--transition-medium); }

/* Nav Mobile Drawer */
.nav-mobile-overlay {
  position: fixed;
  inset: 0;
  z-index: 998;
  background: rgba(7,6,10,0.7);
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition-medium);
}


.nav-mobile {
  position: fixed;
  top: 0;
  right: 0;
  width: 280px;
  height: 100svh;
  z-index: 10001;
  background: #07060A;
  display: flex;
  flex-direction: column;
  padding: 80px 2rem 2rem;
  gap: 1rem;
  transition: right var(--transition-medium);
  box-shadow: -10px 0 40px rgba(0,0,0,0.5);
}



.nav-mobile a {
  font-family: var(--font-display);
  font-size: 24px;
  color: var(--gold);
  height: 48px;
  display: flex;
  align-items: center;
  transition: color var(--transition-fast);
}

.nav-mobile-close {
  position: absolute;
  top: 14px;
  right: 1.25rem;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  color: var(--pearl);
  background: none;
  border: none;
  cursor: pointer;
}

/* ─── Form Controls ─────────────────────────────── */
.form-group{display:flex;flex-direction:column;gap:.5rem}
.form-label{font-family:var(--font-mono);font-size:.63rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted)}
.form-input,.form-textarea,.form-select{background:var(--bg-elevated);border:var(--border-gold);border-radius:var(--radius-sm);color:var(--pearl);font-family:var(--font-body);font-size: 16px;padding:.85rem 1rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;width:100%;-webkit-appearance:none;appearance:none;min-height: 48px;}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:rgba(201,168,76,.4);box-shadow:0 0 0 3px rgba(201,168,76,.06)}
.form-textarea{resize:vertical;min-height:120px}
.form-select option{background:var(--bg-elevated);color:var(--pearl)}

/* ─── Footer ────────────────────────────────────── */
.footer { background:var(--bg-card); border-top:var(--border-gold-hover); }
.footer-grid { display:grid; grid-template-columns: 1fr; gap:2rem; padding: 3rem 1.25rem 2rem; }
@media (min-width: 1024px) { .footer-grid { grid-template-columns: 1.5fr 1fr 1.25fr; gap: 3.5rem; padding: 5rem 0 3.5rem; } }

.footer-column { border-bottom: 1px solid rgba(201,168,76,0.1); padding-bottom: 2rem; }
.footer-column:last-child { border-bottom: none; }
@media (min-width: 1024px) { .footer-column { border-bottom: none; padding-bottom: 0; } }

.footer-logo-name { font-family:var(--font-display); font-size: 18px; font-weight:500; letter-spacing:.25em; color:var(--gold); text-transform:uppercase; margin-bottom:.4rem; }
@media (min-width: 1024px) { .footer-logo-name { font-size: 1.35rem; } }

.footer-tagline { font-family:var(--font-display); font-style:italic; font-size:.93rem; color:var(--muted); margin-bottom:1rem; }
.footer-desc { font-size:.82rem; color:var(--muted); line-height:1.9; }
.footer-heading { font-family:var(--font-mono); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:1.25rem; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:.85rem; }
.footer-links a { font-size:15px; line-height: 2; color:var(--muted); transition:color var(--transition-fast); }
@media (min-width: 1024px) { .footer-links a { font-size: .82rem; } }

.footer-address { font-size:.8rem; color:var(--muted); line-height:2; }
.footer-bottom { border-top:var(--border-gold); padding:1rem; display:flex; flex-direction: column; align-items:center; text-align: center; gap:.75rem; }
@media (min-width: 769px) { .footer-bottom { flex-direction: row; justify-content: space-between; padding: 1.25rem 0; } }
.footer-bottom-text { font-family:var(--font-mono); font-size:12px; letter-spacing:.1em; color:var(--muted); }

/* ─── Page Hero ─────────────────────────────────── */
.page-hero{position:relative;height:52vh;min-height:340px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;margin-top:72px}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(7,6,10,.5) 0%,rgba(7,6,10,.82) 100%)}
.page-hero-content{position:relative;z-index:2;padding:2rem}
.overlay-dark{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(7,6,10,.35) 0%,rgba(7,6,10,.85) 100%)}

/* ─── Responsive ─────────────────────────────────── */
@media (max-width: 768.8px) {
  .hide-mobile { display: none !important; }
}

@media(max-width:1024px){.container{padding:0 1.5rem}}

@media (min-width: 769px) { .btn { padding:.85rem 1.75rem; } }

/* CSS-Only Hamburger Nav */
#nav-toggle:checked ~ .nav-mobile {
  transform: translateX(0);
}
#nav-toggle:checked ~ .nav-mobile-overlay {
  opacity: 1;
  visibility: visible;
}
.nav-mobile {
  transform: translateX(100%);
  transition: transform 0.3s ease;
}
.nav-mobile-overlay {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

/* 6.3 Native CSS Scroll Animations */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
.reveal {
  animation: fadeUp 0.6s ease-out both;
  animation-timeline: view();
  animation-range: entry 0% entry 30%;
}
/* Fallback for browsers not supporting animation-timeline handled gracefully by default parsing */

/* 7.1 Accessible Focus State */
*:focus-visible {
  outline: 2px solid #C9A84C;
  outline-offset: 3px;
  border-radius: 4px;
}
*:focus:not(:focus-visible) { outline: none; }


/* Override jewel-image-wrap for strict containment so product images zoom out perfectly */
.insta-item.jewel-image-wrap img { object-fit: contain !important; }
