/* ============================================================================
   GRAND COMPLICATION WATCHES — STYLES
   Palette: cream/white background · near-black ink · metallic gold accent
   Type:    Cormorant Garamond (display) · Cinzel (engraved caps) · EB Garamond (body)
   ========================================================================== */

:root {
  --cream:      #F7F3EA;
  --cream-deep: #EFE8D8;
  --white:      #FFFFFF;
  --ink:        #121212;
  --ink-soft:   #2c2c2c;
  --muted:      #6b665c;
  --gold:       #B8923E;
  --gold-light: #C9A24B;
  --gold-dark:  #9C7A2E;
  --gold-grad:  linear-gradient(180deg, #D4B25E 0%, #B8923E 48%, #9C7A2E 100%);
  --line:       rgba(18, 18, 18, .12);

  --serif-display: "Cormorant Garamond", Georgia, serif;
  --serif-caps:    "Cinzel", "Cormorant Garamond", serif;
  --serif-body:    "EB Garamond", Georgia, serif;

  --container: 1140px;
}

/* --------------------------------- Reset -------------------------------- */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--cream);
  color: var(--ink);
  font-family: var(--serif-body);
  font-size: 18px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 clamp(20px, 5vw, 48px); }
.narrow { max-width: 760px; }

/* ------------------------------ Shared bits ----------------------------- */
.eyebrow {
  font-family: var(--serif-caps);
  font-size: .8rem;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold-dark);
  margin: 0 0 1rem;
}
.eyebrow--center { text-align: center; }

.section { padding: clamp(64px, 9vw, 116px) 0; }
.section--cream { background: var(--cream); }
.section--white { background: var(--white); }
.section--dark  { background: var(--ink); color: var(--cream); }

.section__title {
  font-family: var(--serif-display);
  font-weight: 500;
  font-size: clamp(2rem, 5vw, 3.1rem);
  line-height: 1.1;
  margin: 0 0 1.4rem;
  text-align: center;
}
.section--cream .section__title, .section--white .section__title { color: var(--ink); }

.section__note {
  max-width: 620px;
  margin: -.4rem auto 2.6rem;
  text-align: center;
  color: var(--muted);
  font-size: 1.05rem;
}
.lead { font-size: 1.18rem; color: var(--ink-soft); margin: 0 0 1.2rem; }
.narrow .lead { text-align: center; }

/* --------------------------------- Buttons ------------------------------ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  font-family: var(--serif-caps);
  font-size: .82rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: .95em 1.9em;
  border: 1px solid transparent;
  border-radius: 2px;
  cursor: pointer;
  transition: all .25s ease;
}
.btn--solid { background: var(--ink); color: var(--cream); }
.btn--solid:hover { background: var(--gold-dark); color: var(--white); }
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--gold); }
.btn--ghost:hover { background: var(--gold); color: var(--white); }
.section--dark .btn--ghost { color: var(--cream); }
.btn__icon { flex: none; }

/* ------------------------------ Header / nav ---------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(247, 243, 234, .92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 76px;
  gap: 1rem;
}
.brand { display: flex; flex-direction: column; line-height: 1; }
.brand__name {
  font-family: var(--serif-display);
  font-weight: 600;
  font-size: 1.5rem;
  letter-spacing: .02em;
  background: var(--gold-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.brand__sub {
  font-family: var(--serif-caps);
  font-size: .62rem;
  letter-spacing: .46em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: .28em;
  padding-left: .1em;
}

.primary-nav { display: flex; align-items: center; gap: 2rem; }
.primary-nav a {
  font-family: var(--serif-caps);
  font-size: .76rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink-soft);
  transition: color .2s ease;
}
.primary-nav a:hover { color: var(--gold-dark); }
.primary-nav__ig { display: inline-flex; color: var(--ink-soft); }
.primary-nav__ig:hover { color: var(--gold-dark); }

/* Hamburger (mobile only) */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 42px; height: 42px;
  background: none; border: none; cursor: pointer;
}
.nav-toggle span { display: block; height: 1.5px; width: 24px; background: var(--ink); transition: .25s; }

/* --------------------------------- Hero --------------------------------- */
.hero {
  background:
    radial-gradient(120% 90% at 50% -10%, rgba(184,146,62,.10), transparent 60%),
    var(--cream);
  padding: clamp(72px, 13vw, 150px) 0 clamp(60px, 9vw, 110px);
  text-align: center;
}
.hero .eyebrow { text-align: center; }
.wordmark { margin: 0 auto; max-width: 820px; }
.wordmark__name {
  display: block;
  font-family: var(--serif-display);
  font-weight: 600;
  font-style: italic;
  font-size: clamp(2.7rem, 9vw, 6rem);
  line-height: .98;
  letter-spacing: .005em;
  background: var(--gold-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.flourish { display: block; width: min(440px, 78%); margin: clamp(.5rem, 2vw, 1.1rem) auto; }
.wordmark__watches {
  display: block;
  font-family: var(--serif-caps);
  font-weight: 500;
  font-size: clamp(1rem, 3.4vw, 2rem);
  letter-spacing: clamp(.3em, 1.4vw, .62em);
  text-transform: uppercase;
  color: var(--ink);
  padding-left: clamp(.3em, 1.4vw, .62em); /* optical centering for tracking */
}
.hero__tagline {
  max-width: 540px;
  margin: 1.8rem auto 0;
  font-size: 1.2rem;
  font-style: italic;
  color: var(--muted);
}
.hero__cta { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; margin-top: 2.4rem; }

/* ------------------------------- Brand strip ---------------------------- */
.brand-strip {
  list-style: none;
  margin: 0; padding: 0;
  display: flex; flex-wrap: wrap;
  align-items: center; justify-content: center;
  gap: clamp(1.2rem, 4vw, 3.2rem);
}
.brand-strip li {
  font-family: var(--serif-display);
  font-weight: 500;
  font-size: clamp(1.25rem, 3vw, 1.9rem);
  color: var(--ink-soft);
  position: relative;
}
.brand-strip li:not(:last-child)::after {
  content: "•";
  position: absolute; right: clamp(-.85rem, -2vw, -1.7rem); top: 50%;
  transform: translateY(-50%);
  color: var(--gold); font-size: .7em;
}
.brand-strip__more { font-style: italic; color: var(--gold-dark) !important; }

/* -------------------------------- Filters ------------------------------- */
.filters {
  display: flex; flex-wrap: wrap;
  justify-content: center; gap: .6rem;
  margin-bottom: 2.8rem;
}
.chip {
  font-family: var(--serif-caps);
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: .58em 1.25em;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--ink-soft);
  cursor: pointer;
  transition: all .2s ease;
}
.chip:hover { border-color: var(--gold); color: var(--gold-dark); }
.chip[aria-pressed="true"] { background: var(--ink); color: var(--cream); border-color: var(--ink); }

/* ------------------------------ Watch grid ------------------------------ */
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(248px, 1fr));
  gap: clamp(1.2rem, 2.5vw, 2rem);
}
.card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 4px;
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .25s ease, box-shadow .25s ease;
}
.card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px -22px rgba(18,18,18,.4); }
.card__media {
  background: linear-gradient(180deg, #fbf8f1, #f1ead9);
  padding: 1.4rem;
  display: flex; align-items: center; justify-content: center;
  aspect-ratio: 4 / 3.4;
}
.card__media img { height: 100%; width: auto; object-fit: contain; }
.card__body { padding: 1.2rem 1.3rem 1.4rem; display: flex; flex-direction: column; flex: 1; }
.card__brand {
  font-family: var(--serif-caps);
  font-size: .68rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold-dark); margin-bottom: .35rem;
}
.card__model { font-family: var(--serif-display); font-size: 1.5rem; font-weight: 600; line-height: 1.1; margin: 0; }
.card__ref { color: var(--muted); font-size: .92rem; margin: .2rem 0 .9rem; }
.card__tags { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 1rem; }
.tag {
  font-family: var(--serif-caps);
  font-size: .6rem; letter-spacing: .12em; text-transform: uppercase;
  padding: .35em .7em; border-radius: 999px; border: 1px solid var(--line); color: var(--ink-soft);
}
.tag--new { border-color: var(--gold); color: var(--gold-dark); }
.card__foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: .6rem; }
.card__price { font-family: var(--serif-display); font-size: 1.3rem; font-weight: 600; }
.card__price--enquire { font-style: italic; color: var(--muted); font-size: 1.1rem; }
.card__enquire {
  font-family: var(--serif-caps);
  font-size: .66rem; letter-spacing: .14em; text-transform: uppercase;
  padding: .55em 1em; border: 1px solid var(--gold); border-radius: 2px; color: var(--gold-dark);
  transition: all .2s ease; white-space: nowrap;
}
.card__enquire:hover { background: var(--gold); color: var(--white); }

.collection__cta { text-align: center; margin-top: 3rem; }

/* -------------------------------- Values -------------------------------- */
.values {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.5rem, 4vw, 3.5rem); text-align: center;
}
.values__mark { color: var(--gold-light); font-size: 1.3rem; display: block; margin-bottom: .8rem; }
.values h3 { font-family: var(--serif-display); font-weight: 500; font-size: 1.7rem; margin: 0 0 .5rem; }
.values p { color: rgba(247,243,234,.7); margin: 0; font-size: 1.02rem; }

/* --------------------------------- Visit -------------------------------- */
.visit { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.visit__info h3 {
  font-family: var(--serif-caps); font-size: .8rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold-dark); margin: 1.6rem 0 .4rem;
}
.visit__info h3:first-child { margin-top: 0; }
.visit__info p { margin: 0 0 .4rem; color: var(--ink-soft); }
.visit__info .btn { margin-top: 1.6rem; }
.visit__map {
  border-radius: 4px; overflow: hidden; border: 1px solid var(--line);
  box-shadow: 0 24px 50px -32px rgba(18,18,18,.4);
}
.visit__map iframe { width: 100%; height: 380px; border: 0; display: block; }

/* -------------------------------- Contact ------------------------------- */
.contact-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.contact-card {
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: .4rem;
  padding: 2rem 1rem; background: var(--white); border: 1px solid var(--line); border-radius: 4px;
  color: var(--ink); transition: all .25s ease;
}
.contact-card:hover { border-color: var(--gold); transform: translateY(-3px); }
.contact-card svg { color: var(--gold-dark); margin-bottom: .4rem; }
.contact-card__label { font-family: var(--serif-caps); font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); }
.contact-card__value { font-family: var(--serif-display); font-size: 1.25rem; font-weight: 500; }

/* --------------------------------- Footer ------------------------------- */
.site-footer { background: var(--ink); color: var(--cream); padding: clamp(48px, 7vw, 76px) 0; text-align: center; }
.footer-brand { margin: 0 0 1rem; }
.footer-brand__name {
  font-family: var(--serif-display); font-weight: 600; font-style: italic; font-size: 2rem;
  background: var(--gold-grad); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.footer-brand__sub {
  display: block; font-family: var(--serif-caps); font-size: .62rem; letter-spacing: .46em;
  text-transform: uppercase; color: rgba(247,243,234,.65); margin-top: .3em;
}
.footer-legal { color: rgba(247,243,234,.85); margin: 0 0 1.4rem; letter-spacing: .04em; }
.footer-disclaimer { max-width: 640px; margin: 0 auto 1.4rem; color: rgba(247,243,234,.5); font-size: .9rem; line-height: 1.6; }
.footer-copy { color: rgba(247,243,234,.5); font-size: .85rem; margin: 0; }

/* ----------------------------- Scroll reveal ---------------------------- */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

/* ------------------------------ Responsive ------------------------------ */
@media (max-width: 760px) {
  body { font-size: 17px; }

  .nav-toggle { display: flex; }
  .primary-nav {
    position: absolute; top: 76px; left: 0; right: 0;
    flex-direction: column; align-items: flex-start; gap: 0;
    background: var(--cream); border-bottom: 1px solid var(--line);
    padding: 0 clamp(20px, 5vw, 48px);
    max-height: 0; overflow: hidden; transition: max-height .3s ease;
  }
  .primary-nav.is-open { max-height: 380px; padding-top: .5rem; padding-bottom: 1.2rem; }
  .primary-nav a { width: 100%; padding: .85rem 0; border-bottom: 1px solid var(--line); }
  .primary-nav a:last-child { border-bottom: none; }
  .nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
  .nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

  .visit { grid-template-columns: 1fr; }
  .values { grid-template-columns: 1fr; gap: 2.2rem; }
  .contact-grid { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .card:hover, .contact-card:hover { transform: none; }
}
