/* =============================================
   LEVY JEWELERS — Savannah Emerald Palette
   ============================================= */
:root {
  --emerald:      #1C3A2B;
  --emerald-mid:  #274E3A;
  --emerald-deep: #0F2218;
  --champagne:    #C8A96A;
  --champ-pale:   #E4D0A0;
  --champ-light:  #F0E5C8;
  --ivory:        #F5EDE0;
  --ivory-warm:   #FAF8F3;
  --ink:          #1A1A17;
  --ink-soft:     #3A3A35;
  --ash:          #8A8A80;
  --white:        #FFFFFF;
  --ff-display:   'Fraunces', serif;
  --ff-body:      'Inter', sans-serif;
  --ff-mono:      'JetBrains Mono', monospace;
  --max:          1280px;
  --pad:          clamp(1.25rem, 4vw, 3rem);
}

/* RESET */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--ff-body); background: var(--ivory-warm); color: var(--ink); line-height: 1.6; overflow-x: hidden; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
address { font-style: normal; }

/* TYPOGRAPHY */
h1, h2, h3, h4 { font-family: var(--ff-display); font-weight: 400; line-height: 1.1; }
h1 { font-size: clamp(2.6rem, 6vw, 5.5rem); }
h2 { font-size: clamp(2rem, 4vw, 3.2rem); }
h3 { font-size: clamp(1.3rem, 2.5vw, 1.8rem); }
h4 { font-size: 1.1rem; }
p  { max-width: 62ch; }
.mono { font-family: var(--ff-mono); font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; }
em  { font-style: italic; color: var(--champagne); }

/* LAYOUT */
.container { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }
.section    { padding: clamp(4rem, 8vw, 7rem) 0; }
.section--ivory  { background: var(--ivory); }
.section--emerald { background: var(--emerald); color: var(--ivory); }
.section--deep  { background: var(--emerald-deep); color: var(--ivory); }

.section-head { text-align: center; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.section-head .mono { color: var(--champagne); margin-bottom: 0.75rem; }
.eyebrow { font-family: var(--ff-mono); font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--champagne); display: block; margin-bottom: 0.75rem; }

/* CHAMPAGNE UNDERLINE DRAW */
.underline-draw { position: relative; display: inline-block; }
.underline-draw::after { content: ''; position: absolute; left: 0; bottom: -4px; width: 0; height: 2px; background: var(--champagne); transition: width 0.8s cubic-bezier(0.4,0,0.2,1); }
.underline-draw.is-visible::after { width: 100%; }

/* BUTTONS */
.btn { display: inline-block; padding: 0.85rem 2rem; font-family: var(--ff-mono); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; border: 1.5px solid transparent; transition: all 0.25s; cursor: pointer; }
.btn--champagne { background: var(--champagne); color: var(--emerald-deep); border-color: var(--champagne); }
.btn--champagne:hover { background: var(--champ-pale); border-color: var(--champ-pale); }
.btn--emerald { background: var(--emerald); color: var(--ivory); border-color: var(--emerald); }
.btn--emerald:hover { background: var(--emerald-mid); }
.btn--outline { background: transparent; color: var(--emerald); border-color: var(--emerald); }
.btn--outline:hover { background: var(--emerald); color: var(--ivory); }
.btn--outline-ivory { background: transparent; color: var(--ivory); border-color: rgba(245,237,224,0.6); }
.btn--outline-ivory:hover { background: rgba(245,237,224,0.15); border-color: var(--ivory); }

/* NAVIGATION */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; transition: background 0.4s, box-shadow 0.4s; }
.nav.scrolled { background: var(--emerald-deep); box-shadow: 0 2px 20px rgba(0,0,0,0.25); }
.nav__inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; padding: 1.25rem var(--pad); max-width: var(--max); margin: 0 auto; }
.nav__logo img { height: 36px; filter: brightness(10); }
.nav__links { display: flex; gap: 2rem; list-style: none; }
.nav__links a { font-family: var(--ff-mono); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(245,237,224,0.85); transition: color 0.2s; }
.nav__links a:hover { color: var(--champagne); }
.nav__phone { font-family: var(--ff-mono); font-size: 0.68rem; letter-spacing: 0.08em; color: var(--champagne); white-space: nowrap; }
.nav__burger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; }
.nav__burger span { display: block; width: 22px; height: 1.5px; background: var(--ivory); transition: all 0.3s; }
.nav__drawer { display: none; flex-direction: column; gap: 1.25rem; padding: 1.5rem var(--pad); background: var(--emerald-deep); border-top: 1px solid rgba(200,169,106,0.2); }
.nav__drawer.open { display: flex; }
.nav__drawer a { font-family: var(--ff-mono); font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ivory); }

/* HERO */
.hero { position: relative; min-height: 100svh; display: flex; align-items: center; overflow: hidden; }
.hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; transform: scale(1.06); transition: transform 12s ease-out; }
.hero.loaded .hero__bg { transform: scale(1); }
.hero__overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(15,34,24,0.85) 0%, rgba(28,58,43,0.7) 60%, rgba(28,58,43,0.4) 100%); }
.hero__inner { position: relative; z-index: 2; padding-top: 5rem; max-width: 700px; }
.hero__eyebrow { color: var(--champagne); margin-bottom: 1.5rem; }
.hero__seal { width: 120px; height: 120px; margin-bottom: 2rem; }
.hero__title { color: var(--ivory); margin-bottom: 1.25rem; }
.hero__title em { display: block; }
.hero__sub { color: rgba(245,237,224,0.8); font-size: 1.05rem; line-height: 1.7; margin-bottom: 2.5rem; max-width: 52ch; }
.hero__ctas { display: flex; flex-wrap: wrap; gap: 1rem; }
.hero__scroll-hint { position: absolute; bottom: 2.5rem; left: var(--pad); z-index: 2; display: flex; align-items: center; gap: 1rem; }
.hero__scroll-hint .mono { color: rgba(245,237,224,0.5); font-size: 0.6rem; }
.hero__scroll-line { width: 40px; height: 1px; background: rgba(200,169,106,0.5); }

/* TRUST STRIP */
.trust-strip { background: var(--emerald); border-top: 1px solid rgba(200,169,106,0.2); border-bottom: 1px solid rgba(200,169,106,0.2); }
.trust-strip__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
.trust-strip__item { padding: 2rem 1.5rem; text-align: center; border-right: 1px solid rgba(200,169,106,0.15); display: flex; flex-direction: column; align-items: center; gap: 0.5rem; }
.trust-strip__item:last-child { border-right: none; }
.trust-strip__item img { height: 36px; width: auto; filter: brightness(10) sepia(1) saturate(0.3); margin-bottom: 0.25rem; }
.trust-strip__item .trust__number { font-family: var(--ff-display); font-size: 2.5rem; color: var(--champagne); line-height: 1; }
.trust-strip__item .trust__label { font-family: var(--ff-display); font-size: 1rem; color: var(--champagne); font-style: italic; }
.trust-strip__item .trust__sub { font-family: var(--ff-mono); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(245,237,224,0.65); line-height: 1.5; }

/* COLLECTIONS GRID */
.coll-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.coll-card { position: relative; overflow: hidden; aspect-ratio: 3/4; }
.coll-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s cubic-bezier(0.4,0,0.2,1); }
.coll-card:hover .coll-card__img { transform: scale(1.06); }
.coll-card__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(15,34,24,0.85) 0%, transparent 55%); }
.coll-card__label { position: absolute; bottom: 0; left: 0; right: 0; padding: 1.5rem 1.25rem; }
.coll-card__label .mono { color: rgba(200,169,106,0.8); margin-bottom: 0.3rem; }
.coll-card__label h3 { color: var(--ivory); font-size: 1.3rem; }
.coll-card__cta { position: absolute; top: 1rem; right: 1rem; font-family: var(--ff-mono); font-size: 0.6rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--champagne); opacity: 0; transition: opacity 0.3s; }
.coll-card:hover .coll-card__cta { opacity: 1; }

/* STORY SPREAD */
.story-spread { display: grid; grid-template-columns: 1fr 1fr; min-height: 600px; }
.story-spread__media { overflow: hidden; }
.story-spread__media img { width: 100%; height: 100%; object-fit: cover; }
.story-spread__content { background: var(--emerald); padding: clamp(3rem, 6vw, 6rem); display: flex; flex-direction: column; justify-content: center; gap: 1.5rem; }
.story-spread__content .eyebrow { color: var(--champagne); }
.story-spread__content h2 { color: var(--ivory); font-size: clamp(1.8rem, 3.5vw, 2.8rem); }
.story-spread__content p { color: rgba(245,237,224,0.8); line-height: 1.8; }

/* EDITORIAL BAND */
.editorial-band { background: var(--emerald-deep); padding: clamp(3rem, 6vw, 5rem) 0; text-align: center; }
.editorial-band .container { max-width: 800px; }
.editorial-band .mono { color: rgba(200,169,106,0.7); margin-bottom: 1.5rem; }
.editorial-band__quote { font-family: var(--ff-display); font-size: clamp(1.5rem, 3vw, 2.4rem); color: var(--ivory); font-weight: 300; line-height: 1.4; font-style: italic; }
.editorial-band__quote::before, .editorial-band__quote::after { content: '\201C'; color: var(--champagne); }
.editorial-band__quote::after { content: '\201D'; }

/* PIECES GRID */
.pieces-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.piece-card { cursor: pointer; }
.piece-card__img { aspect-ratio: 1; overflow: hidden; background: var(--ivory); margin-bottom: 1rem; }
.piece-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.piece-card:hover .piece-card__img img { transform: scale(1.08); }
.piece-card__label .mono { color: var(--ash); margin-bottom: 0.25rem; }
.piece-card__label h4 { font-family: var(--ff-display); color: var(--ink); }

/* BRANDS MARQUEE */
.brands-section { background: var(--emerald); padding: clamp(2.5rem, 5vw, 4rem) 0; }
.brands-section .section-head h2 { color: var(--ivory); }
.brands-bar { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.5rem 2rem; padding-top: 1rem; }
.brands-bar__name { font-family: var(--ff-display); font-size: clamp(1rem, 2vw, 1.3rem); color: rgba(245,237,224,0.55); font-style: italic; transition: color 0.3s; }
.brands-bar__name:hover { color: var(--champagne); }
.brands-sep { color: rgba(200,169,106,0.3); align-self: center; }

/* TESTIMONIALS */
.testi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.testi-card { background: var(--white); padding: 2rem; border-left: 3px solid var(--champagne); }
.testi-card__img { width: 100%; border-radius: 2px; }
.testi-card__quote { font-family: var(--ff-display); font-size: 1rem; color: var(--ink); line-height: 1.7; margin-bottom: 1rem; font-style: italic; }
.testi-card__author { font-family: var(--ff-mono); font-size: 0.68rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ash); }

/* LOCATIONS */
.locations-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.location-card { background: var(--white); padding: 2.5rem; border-top: 3px solid var(--champagne); }
.location-card__tag { font-family: var(--ff-mono); font-size: 0.65rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--champagne); margin-bottom: 0.75rem; }
.location-card h3 { font-family: var(--ff-display); font-size: 1.6rem; color: var(--emerald); margin-bottom: 1rem; }
.location-card address { color: var(--ink-soft); line-height: 1.8; margin-bottom: 1rem; }
.location-card .phone-link { font-family: var(--ff-mono); font-size: 0.8rem; color: var(--emerald); border-bottom: 1px solid var(--champagne); padding-bottom: 2px; transition: color 0.2s; }
.location-card .phone-link:hover { color: var(--champagne); }

/* PRESIDENT QUOTE BAND */
.president-quote { background: var(--ivory); padding: clamp(3rem, 6vw, 5rem) 0; }
.president-quote__inner { display: flex; align-items: center; gap: 4rem; }
.president-quote blockquote { font-family: var(--ff-display); font-size: clamp(1.3rem, 2.5vw, 2rem); color: var(--emerald); font-style: italic; line-height: 1.5; flex: 1; }
.president-quote blockquote::before { content: '"'; color: var(--champagne); font-size: 3rem; line-height: 0; vertical-align: -0.3em; margin-right: 0.2em; }
.president-quote__attr { min-width: 200px; text-align: right; }
.president-quote__attr .name { font-family: var(--ff-display); font-size: 1.1rem; color: var(--ink); }
.president-quote__attr .title { font-family: var(--ff-mono); font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ash); margin-top: 0.3rem; }

/* TIMELINE */
.timeline { position: relative; padding-left: 2rem; }
.timeline::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 1px; background: linear-gradient(to bottom, var(--champagne), transparent); }
.timeline__item { position: relative; padding: 0 0 2.5rem 2rem; }
.timeline__item::before { content: ''; position: absolute; left: -2.3rem; top: 0.4rem; width: 8px; height: 8px; border-radius: 50%; background: var(--champagne); border: 2px solid var(--emerald); }
.timeline__year { font-family: var(--ff-mono); font-size: 0.68rem; letter-spacing: 0.1em; color: var(--champagne); margin-bottom: 0.4rem; }
.timeline__text { color: rgba(245,237,224,0.8); line-height: 1.7; }

/* FOOTER */
.footer { background: var(--emerald-deep); color: rgba(245,237,224,0.65); padding: clamp(3rem, 6vw, 5rem) 0 2rem; }
.footer__grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; margin-bottom: 3rem; }
.footer__logo img { height: 32px; filter: brightness(10); margin-bottom: 1rem; }
.footer__tagline { font-family: var(--ff-display); font-size: 0.95rem; font-style: italic; color: rgba(245,237,224,0.5); line-height: 1.6; }
.footer__col h5 { font-family: var(--ff-mono); font-size: 0.65rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--champagne); margin-bottom: 1.25rem; }
.footer__col ul { list-style: none; display: flex; flex-direction: column; gap: 0.6rem; }
.footer__col ul a { font-size: 0.88rem; color: rgba(245,237,224,0.6); transition: color 0.2s; }
.footer__col ul a:hover { color: var(--champagne); }
.footer__col address { font-size: 0.88rem; line-height: 1.8; color: rgba(245,237,224,0.6); }
.footer__bottom { border-top: 1px solid rgba(200,169,106,0.15); padding-top: 1.5rem; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 0.5rem; }
.footer__bottom p { font-family: var(--ff-mono); font-size: 0.65rem; letter-spacing: 0.06em; color: rgba(245,237,224,0.35); }
.footer__bottom a { color: rgba(200,169,106,0.7); }

/* SCROLL REVEALS */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.75s ease, transform 0.75s ease; }
.reveal.is-visible { opacity: 1; transform: none; }
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }
.reveal-delay-5 { transition-delay: 0.5s; }

/* ABOUT PAGE */
.about-hero { background: var(--emerald); padding: clamp(8rem, 14vw, 12rem) 0 clamp(4rem, 8vw, 7rem); }
.about-hero__inner { max-width: 720px; }
.about-hero h1 { color: var(--ivory); }
.about-hero .lead { font-family: var(--ff-display); font-size: clamp(1.1rem, 2vw, 1.4rem); color: rgba(245,237,224,0.75); font-style: italic; line-height: 1.7; margin-top: 1.5rem; }

.gen-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; margin-top: 3rem; }
.gen-card { background: rgba(200,169,106,0.08); border: 1px solid rgba(200,169,106,0.2); padding: 2rem; }
.gen-card__gen { font-family: var(--ff-mono); font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--champagne); margin-bottom: 0.5rem; }
.gen-card h3 { color: var(--ivory); margin-bottom: 0.75rem; font-size: 1.3rem; }
.gen-card p { color: rgba(245,237,224,0.7); font-size: 0.92rem; line-height: 1.7; }

/* BRIDAL PAGE */
.bridal-hero { position: relative; min-height: 80vh; display: flex; align-items: center; }
.bridal-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.bridal-hero__overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(15,34,24,0.9) 40%, rgba(15,34,24,0.4) 100%); }
.bridal-hero__inner { position: relative; z-index: 2; padding-top: 5rem; max-width: 600px; }
.bridal-hero h1 { color: var(--ivory); }
.bridal-hero p { color: rgba(245,237,224,0.8); margin: 1.5rem 0 2.5rem; font-size: 1.05rem; }

/* CONTACT PAGE */
.contact-hero { background: var(--emerald); padding: clamp(7rem, 12vw, 10rem) 0 clamp(3rem, 6vw, 5rem); }
.contact-hero h1 { color: var(--ivory); }
.contact-form { background: var(--white); padding: 2.5rem; }
.contact-form__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.form-field { display: flex; flex-direction: column; gap: 0.4rem; }
.form-field.full { grid-column: 1 / -1; }
.form-field label { font-family: var(--ff-mono); font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ash); }
.form-field input, .form-field select, .form-field textarea { border: 1px solid #D8D0C4; padding: 0.75rem 1rem; font-family: var(--ff-body); font-size: 0.92rem; outline: none; transition: border-color 0.2s; background: var(--ivory-warm); }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { border-color: var(--champagne); }
.form-field textarea { height: 120px; resize: vertical; }

/* COLLECTIONS PAGE */
.coll-page-hero { background: var(--emerald-deep); padding: clamp(7rem, 12vw, 10rem) 0 clamp(3rem, 6vw, 5rem); }
.coll-page-hero h1 { color: var(--ivory); }
.coll-full-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.coll-full-card { background: var(--white); overflow: hidden; }
.coll-full-card__img { aspect-ratio: 4/3; overflow: hidden; }
.coll-full-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.coll-full-card:hover .coll-full-card__img img { transform: scale(1.06); }
.coll-full-card__body { padding: 1.5rem; }
.coll-full-card__body .mono { color: var(--champagne); margin-bottom: 0.4rem; }
.coll-full-card__body h3 { font-size: 1.2rem; color: var(--emerald); margin-bottom: 0.5rem; }
.coll-full-card__body p { font-size: 0.88rem; color: var(--ink-soft); }

/* RESPONSIVE */
@media (max-width: 1024px) {
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .trust-strip__grid { grid-template-columns: repeat(2, 1fr); }
  .trust-strip__item { border-right: none; border-bottom: 1px solid rgba(200,169,106,0.15); }
  .trust-strip__item:nth-child(2n) { border-right: none; }
  .coll-grid { grid-template-columns: repeat(2, 1fr); }
  .pieces-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .nav__links, .nav__phone { display: none; }
  .nav__burger { display: flex; }
  .hero__ctas { flex-direction: column; max-width: 280px; }
  .story-spread { grid-template-columns: 1fr; }
  .story-spread__media { aspect-ratio: 16/9; max-height: 300px; }
  .locations-grid { grid-template-columns: 1fr; }
  .testi-grid { grid-template-columns: 1fr; }
  .gen-grid { grid-template-columns: 1fr; }
  .contact-form__grid { grid-template-columns: 1fr; }
  .coll-full-grid { grid-template-columns: 1fr 1fr; }
  .president-quote__inner { flex-direction: column; gap: 2rem; }
  .president-quote__attr { text-align: left; }
  .footer__grid { grid-template-columns: 1fr; gap: 2rem; }
}
@media (max-width: 480px) {
  .coll-grid { grid-template-columns: 1fr; }
  .pieces-grid { grid-template-columns: 1fr 1fr; }
  .coll-full-grid { grid-template-columns: 1fr; }
  .trust-strip__grid { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  .reveal, .hero__bg, .coll-card__img, .piece-card__img img { transition: none; }
}
