@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@500;600;700;800;900&family=Rubik:wght@500;600;700;800;900&display=swap');

:root {
  --color-gold: #C5A059;
  --color-gold-light: #D4B57A;
  --color-dark: #1A1A1A;
  --color-light: #FAFAFA;
  --font-serif: 'Rubik', sans-serif;
  --font-sans: 'Montserrat', sans-serif;
}

body {
  font-family: var(--font-sans);
  background-color: var(--color-light);
  color: var(--color-dark);
  overflow-x: hidden;
  font-weight: 600;
}

h1, h2, h3, h4, h5, h6, .font-serif {
  font-family: var(--font-serif);
  font-weight: 800;
}

/* Force tailwind's font-light to be bolder to match the request */
.font-light {
    font-weight: 600 !important;
}

.font-sans {
  font-family: var(--font-sans);
}

.text-gold { color: var(--color-gold); }
.bg-gold { background-color: var(--color-gold); }
.border-gold { border-color: var(--color-gold); }

/* Playful Spacing Utilities */
.section-padding {
  padding: 6rem 2rem;
}

/* Custom Nav Hover */
.nav-link {
  position: relative;
  transition: color 0.3s ease;
}

.nav-link::after {
  content: '';
  position: absolute;
  width: 0;
  height: 1px;
  bottom: 0;
  left: 0;
  background-color: var(--color-gold);
  transition: width 0.3s ease;
}

.nav-link:hover::after {
  width: 100%;
}

.btn-gold {
  display: inline-block;
  padding: 1rem 2.5rem;
  background-color: var(--color-gold);
  color: white;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.875rem;
  transition: all 0.3s ease;
  border: 1px solid var(--color-gold);
}

.btn-gold:hover {
  background-color: white;
  color: var(--color-gold);
  border-color: var(--color-gold);
}

.btn-outline {
  display: inline-block;
  padding: 1rem 2.5rem;
  background-color: transparent;
  color: var(--color-gold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.875rem;
  transition: all 0.3s ease;
  border: 1px solid var(--color-gold);
}

.btn-outline:hover {
  background-color: var(--color-gold);
  color: white;
}

/* Masonry grid for portfolio */
.masonry-grid {
  column-count: 1;
  column-gap: 2rem;
}

@media (min-width: 640px) {
  .masonry-grid { column-count: 2; }
}

@media (min-width: 1024px) {
  .masonry-grid { column-count: 3; }
}

.masonry-item {
  break-inside: avoid;
  margin-bottom: 2rem;
}

/* Hide translate banner if possible */
.goog-te-banner-frame {
    display: none !important;
}
}
.goog-te-gadget .goog-te-combo:hover, .goog-te-gadget .goog-te-combo:focus {
    border-color: #D4AF37 !important;
    background-color: #ffffff !important;
}

/* Hide the Google Logo & text */
.goog-logo-link {
    display: none !important;
}
.goog-te-gadget > span > a {
    display: none !important;
}
.goog-te-gadget img {
    display: none !important;
}

/* Hide the top translation banner that sometimes appears */
.goog-te-banner-frame.skiptranslate, .goog-te-banner-frame {
    display: none !important;
}
body {
    top: 0px !important; 
}
/* Google Translate Widget Integration */
.goog-te-gadget {
    font-family: 'Inter', sans-serif !important;
    color: transparent !important;
    font-size: 0px !important;
}
.goog-te-gadget .goog-te-combo {
    font-family: 'Inter', sans-serif !important;
    color: #1f2937 !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    padding: 6px 32px 6px 12px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 4px !important;
    background-color: #f9fafb !important;
    outline: none !important;
    margin: 0 !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231f2937' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e") !important;
    background-repeat: no-repeat !important;
    background-position: right 8px center !important;
    background-size: 14px !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
}
.goog-te-gadget .goog-te-combo:hover, .goog-te-gadget .goog-te-combo:focus {
    border-color: #D4AF37 !important;
    background-color: #ffffff !important;
}

/* Hide the Google Logo & text */
.goog-logo-link {
    display: none !important;
}
.goog-te-gadget > span > a {
    display: none !important;
}
.goog-te-gadget img {
    display: none !important;
}

/* Hide the top translation banner that sometimes appears */
.goog-te-banner-frame.skiptranslate, .goog-te-banner-frame {
    display: none !important;
}
body {
    top: 0px !important; 
}


/* Aggressive GT Banner Hide */
body { top: 0px !important; position: static !important; }
.skiptranslate iframe, .goog-te-banner-frame, #goog-gt-tt { display: none !important; visibility: hidden !important; }

/* --- Mobile Cart and Filter Modals --- */
@media (max-width: 1023px) {
    aside {
        display: none;
    }
    
    body.mobile-cart-open aside,
    body.mobile-filter-open aside {
        display: flex !important;
        justify-content: center;
        align-items: center;
        position: fixed;
        inset: 0;
        z-index: 60;
        background: rgba(0,0,0,0.6);
        backdrop-filter: blur(4px);
        padding: 1rem;
    }

    body.mobile-cart-open aside > div,
    body.mobile-filter-open aside > div {
        width: 100%;
        max-width: 28rem;
        max-height: 85vh;
        overflow-y: auto;
        background: white;
        border-radius: 1rem;
        padding: 1.5rem;
        position: relative;
        top: auto;
    }

    body.mobile-cart-open aside > div > div:not(:first-child) {
        display: none !important;
    }
    
    body.mobile-filter-open aside > div > div:first-child {
        display: none !important;
    }
}

/* Partner Marquee */
@keyframes scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.animate-scroll {
  animation: scroll 120s linear infinite;
  display: flex;
  width: max-content;
}
.animate-scroll:hover {
  animation-play-state: paused;
}
.logo-black {
  filter: grayscale(100%) brightness(0);
}
