*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --forest: #1A2B18;
  --gold:   #C4A35A;
  --khaki:  #B5A98A;
  --navy:   #0B1628;
  --mid:    #6B5F4E;
  --serif:  'Cormorant Garamond', Georgia, serif;
  --sans:   'Inter', Helvetica, sans-serif;
}

html { scroll-behavior: smooth; }
body { background: var(--forest); color: var(--forest); font-family: var(--sans); font-weight: 300; overflow-x: hidden; }

/* NAV */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 26px 52px; transition: background .4s;
}
nav.scrolled {
  background: rgba(26,43,24,.94);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(196,163,90,.12);
}
.logo { font-family: var(--serif); font-size: 15px; letter-spacing: .4em; text-transform: uppercase; color: #fff; text-decoration: none; }
.nav-r { display: flex; gap: 36px; }
.nav-r a { font-size: 9.5px; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.45); text-decoration: none; transition: color .3s; }
.nav-r a:hover { color: #fff; }

/* HERO */
.s-hero { height: 100vh; position: relative; overflow: hidden; background: var(--forest); }
.hero-img { width: 100%; height: 100%; object-fit: cover; object-position: center 20%; display: block; filter: saturate(.88); }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(26,43,24,.08) 0%, rgba(26,43,24,.18) 50%, rgba(26,43,24,.72) 100%); }
.hero-content { position: absolute; bottom: 64px; left: 52px; opacity: 0; transform: translateY(20px); transition: opacity 1.2s .5s, transform 1.2s .5s; }
.hero-content.show { opacity: 1; transform: none; }
.hero-title { font-family: var(--serif); font-size: clamp(54px, 7.5vw, 104px); font-weight: 300; color: #fff; line-height: .92; letter-spacing: -.01em; }
.hero-title em { font-style: italic; color: rgba(196,163,90,.85); display: block; }
.hero-sub { margin-top: 20px; font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.38); }

/* CONCEITO */
.s-conceito {
  background: var(--khaki);
  padding: 120px 52px 96px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 0; align-items: center;
}
.conceito-h { font-family: var(--serif); font-size: clamp(36px, 4.5vw, 64px); font-weight: 300; line-height: 1.08; color: var(--forest); }
.conceito-h em { font-style: italic; color: #4A3A20; }
.conceito-right { padding-left: 72px; }
.gold-rule { width: 30px; height: 1px; background: #4A3A20; opacity: .4; margin-bottom: 22px; }
.conceito-body { font-size: 14px; line-height: 1.85; color: var(--mid); max-width: 360px; }

/* FOTO */
.s-foto-full { position: relative; overflow: hidden; height: 90vh; }
.s-foto-full img { width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; filter: saturate(.85); }

/* PRODUTO */
.s-produto { display: grid; grid-template-columns: 1fr 1fr; min-height: 85vh; }
.s-produto-imgs { display: flex; flex-direction: column; }
.brooch-slot { flex: 1; overflow: hidden; }
.brooch-slot img { width: 100%; height: 100%; object-fit: cover; object-position: center 55%; display: block; filter: saturate(.83); }
.brooch-slot:first-child { border-bottom: 2px solid var(--khaki); }
.s-produto-right { padding: 80px 64px; display: flex; flex-direction: column; justify-content: center; background: var(--khaki); }
.produto-eyebrow { font-size: 9px; letter-spacing: .3em; text-transform: uppercase; color: #4A3A20; opacity: .7; margin-bottom: 24px; }
.produto-h { font-family: var(--serif); font-size: clamp(30px, 3.2vw, 48px); font-weight: 300; color: var(--forest); line-height: 1.1; margin-bottom: 18px; }
.produto-h em { font-style: italic; }
.produto-desc { font-size: 13.5px; line-height: 1.85; color: var(--mid); margin-bottom: 32px; max-width: 320px; }
.produto-preco { display: flex; align-items: baseline; gap: 10px; margin-bottom: 12px; }
.preco-val { font-family: var(--serif); font-size: 42px; font-weight: 300; color: var(--forest); line-height: 1; }
.preco-label { font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--mid); }
.produto-limitado { font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: #4A3A20; opacity: .65; margin-bottom: 36px; }
.cores-label { font-size: 9px; letter-spacing: .22em; text-transform: uppercase; color: var(--forest); opacity: .4; margin-bottom: 18px; }
.cores-list { display: flex; flex-direction: column; gap: 14px; margin-bottom: 48px; }
.core-item { display: flex; align-items: center; gap: 14px; }
.core-swatch { width: 34px; height: 34px; border-radius: 50%; flex-shrink: 0; border: 1px solid rgba(26,43,24,.15); overflow: hidden; }
.sw-vy { background: linear-gradient(135deg, #2A5C35 50%, #D4A017 50%); }
.sw-wb { background: linear-gradient(135deg, #E8E2D4 50%, #0B3A7A 50%); }
.core-name { font-family: var(--serif); font-size: 18px; font-weight: 300; color: var(--forest); }
.core-sub { font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--mid); opacity: .6; }
.btn-cta { display: inline-block; padding: 15px 42px; background: var(--forest); color: #fff; font-size: 10px; letter-spacing: .28em; text-transform: uppercase; text-decoration: none; font-family: var(--sans); font-weight: 300; transition: background .35s; align-self: flex-start; }
.btn-cta:hover { background: var(--navy); }

/* SPECS */
.s-specs { background: var(--navy); padding: 100px 52px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.specs-eyebrow { font-size: 9px; letter-spacing: .28em; text-transform: uppercase; color: var(--gold); margin-bottom: 28px; }
.specs-h { font-family: var(--serif); font-size: clamp(28px, 3vw, 44px); font-weight: 300; line-height: 1.18; color: #fff; }
.specs-h em { font-style: italic; }
.spec-list { display: flex; flex-direction: column; }
.spec-row { display: flex; justify-content: space-between; border-top: 1px solid rgba(255,255,255,.08); padding: 15px 0; }
.spec-k { font-size: 9px; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.3); }
.spec-v { font-family: var(--serif); font-size: 14px; color: #fff; font-weight: 300; }

/* FEITO AQUI */
.s-feito { background: var(--forest); padding: 120px 52px; display: grid; grid-template-columns: 1fr 1fr; gap: 0; align-items: center; }
.feito-h { font-family: var(--serif); font-size: clamp(44px, 6vw, 88px); font-weight: 300; line-height: .95; color: #fff; letter-spacing: -.01em; }
.feito-h em { font-style: italic; color: var(--gold); display: block; }
.feito-right { padding-left: 72px; }
.feito-rule { width: 30px; height: 1px; background: var(--gold); opacity: .5; margin-bottom: 22px; }
.feito-sub { font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.35); }

/* FOOTER */
footer { background: var(--forest); border-top: 1px solid rgba(196,163,90,.12); padding: 44px 52px; display: flex; justify-content: space-between; align-items: center; }
.footer-logo { font-family: var(--serif); font-size: 13px; letter-spacing: .34em; text-transform: uppercase; color: #fff; }
.footer-mid { font-size: 9px; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.22); }
.footer-links { display: flex; gap: 28px; }
.footer-links a { font-size: 9px; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.28); text-decoration: none; transition: color .3s; }
.footer-links a:hover { color: #fff; }

/* FADE */
.fade { opacity: 0; transform: translateY(16px); transition: opacity .85s ease, transform .85s ease; }
.fade.d1 { transition-delay: .14s; }
.fade.d2 { transition-delay: .26s; }
.fade.show { opacity: 1; transform: none; }
