:root {
  --bege: #f5e8d3;
  --bege-soft: #fbf4e8;
  --carvao: #2d2926;
  --carvao-muted: rgba(45, 41, 38, .74);
  --tulipa: #c8322d;
  --dourado: #d4af37;
  --verde: #5e7d52;
  --line: rgba(212, 175, 55, .28);
  --shadow: 0 18px 45px rgba(45, 41, 38, .13);
  --display: "Playfair Display", Georgia, serif;
  --body: "Inter", system-ui, sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bege); color: var(--carvao); font-family: var(--body); }
a { color: inherit; text-decoration: none; }
img, svg { display: block; }
svg { fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
button { font: inherit; }
.container { width: min(1120px, calc(100% - 32px)); margin: 0 auto; }
.center { text-align: center; }
.narrow { max-width: 880px; }
.site-header { position: sticky; top: 0; z-index: 40; background: rgba(245,232,211,.92); border-bottom: 1px solid var(--line); backdrop-filter: blur(12px); }
.topbar { height: 34px; padding: 0 32px; border-bottom: 1px solid rgba(212,175,55,.2); display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: var(--carvao-muted); }
.topbar__info, .socials { display: flex; align-items: center; gap: 16px; }
.topbar span { display: inline-flex; align-items: center; gap: 6px; }
.topbar svg { width: 16px; height: 16px; color: var(--verde); }
.socials a svg { color: var(--carvao); transition: color .2s ease; }
.socials a:hover svg { color: var(--tulipa); }
.navbar { min-height: 88px; padding: 12px 32px; display: flex; align-items: center; justify-content: space-between; gap: 28px; }
.brand img { height: 64px; width: auto; }
.desktop-nav { display: flex; align-items: center; gap: 32px; font-size: 14px; font-weight: 600; }
.desktop-nav a { transition: color .2s ease; }
.desktop-nav a:hover { color: var(--tulipa); }
.desktop-cta, .primary-btn, .mobile-cta { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; background: var(--tulipa); color: white; font-size: 14px; font-weight: 700; padding: 12px 22px; box-shadow: var(--shadow); transition: transform .2s ease, opacity .2s ease; }
.desktop-cta:hover, .primary-btn:hover, .mobile-cta:hover { transform: translateY(-1px); opacity: .92; }
.hamburger, .mobile-spacer { display: none; }
.hero { overflow: hidden; background: var(--bege); }
.hero__frame { position: relative; width: 100%; aspect-ratio: 1920 / 675; }
.hero__frame.is-mobile { aspect-ratio: 3 / 4; }
.slides, .slide { position: absolute; inset: 0; width: 100%; height: 100%; }
.slide { object-fit: cover; opacity: 0; transition: opacity .7s ease; }
.slide.is-active { opacity: 1; }
.slider-btn { position: absolute; top: 50%; transform: translateY(-50%); width: 46px; height: 46px; border: 0; border-radius: 50%; background: rgba(255,255,255,.72); color: var(--carvao); display: grid; place-items: center; cursor: pointer; backdrop-filter: blur(8px); transition: background .2s ease; }
.slider-btn:hover { background: white; }
.slider-btn svg { width: 24px; height: 24px; }
.slider-btn--prev { left: 24px; }
.slider-btn--next { right: 24px; }
.dots { position: absolute; left: 50%; bottom: 24px; transform: translateX(-50%); display: flex; gap: 8px; }
.dot { width: 8px; height: 8px; padding: 0; border: 0; border-radius: 999px; background: rgba(255,255,255,.72); cursor: pointer; transition: width .2s ease, background .2s ease; }
.dot.is-active { width: 32px; background: var(--tulipa); }
.differentials { padding: 56px 0; background: rgba(251,244,232,.52); border-block: 1px solid var(--line); }
.differentials__grid { width: min(1120px, calc(100% - 32px)); margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.differentials article { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 10px; }
.differentials span { width: 52px; height: 52px; border: 1px solid rgba(212,175,55,.42); border-radius: 50%; background: var(--bege); color: var(--verde); display: grid; place-items: center; }
.differentials svg { width: 23px; height: 23px; }
h1, h2, h3, h4 { margin: 0; font-family: var(--display); font-weight: 600; letter-spacing: 0; }
.differentials h3 { font-size: 17px; }
.differentials p { margin: 0; max-width: 18ch; font-size: 14px; color: var(--carvao-muted); line-height: 1.5; }
.collection { padding: 76px 0 84px; }
.eyebrow { margin: 0 0 12px; color: var(--dourado); font-size: 12px; font-weight: 700; letter-spacing: .28em; text-transform: uppercase; }
h1 { font-size: clamp(36px, 5vw, 60px); line-height: 1.04; }
.lead { max-width: 680px; margin: 16px auto 44px; color: var(--carvao-muted); line-height: 1.7; }
.category-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px; }
.category-grid a { min-height: 146px; padding: 24px 16px; border: 1px solid var(--line); border-radius: 18px; background: var(--bege-soft); color: var(--verde); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; box-shadow: 0 10px 25px rgba(45,41,38,.06); transition: transform .2s ease, border-color .2s ease, color .2s ease; }
.category-grid a:hover { transform: translateY(-4px); border-color: var(--tulipa); color: var(--tulipa); }
.category-grid svg { width: 44px; height: 44px; }
.category-grid span { color: var(--carvao); font-size: 14px; font-weight: 700; }
.about { padding: 76px 0 88px; background: rgba(251,244,232,.54); }
.ornament { width: 84px; height: 26px; margin: 0 auto 24px; color: var(--dourado); }
.ornament path:last-child { fill: currentColor; }
.about h2, .location h2 { font-size: clamp(32px, 4vw, 54px); line-height: 1.08; margin-bottom: 24px; }
.about h2 span, .location h2 span { color: var(--tulipa); font-family: "Dancing Script", cursive; font-size: 1.14em; }
.about p:not(.eyebrow) { margin: 0 auto 16px; color: rgba(45,41,38,.82); font-size: 17px; line-height: 1.8; }
.values { margin-top: 28px; display: flex; justify-content: center; gap: 18px; color: var(--carvao-muted); font-size: 14px; }
.values i { color: var(--dourado); font-style: normal; }
.location { padding: 76px 0 88px; }
.location__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 42px; align-items: center; }
.contact-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 16px; color: rgba(45,41,38,.82); line-height: 1.55; }
.contact-list li { display: flex; gap: 12px; align-items: flex-start; }
.contact-list svg { width: 22px; height: 22px; color: var(--verde); flex: 0 0 auto; margin-top: 2px; }
.actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.outline-btn { display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--verde); border-radius: 999px; color: var(--verde); padding: 12px 22px; font-size: 14px; font-weight: 700; transition: background .2s ease, color .2s ease; }
.outline-btn:hover { background: var(--verde); color: white; }
.map-card { display: block; overflow: hidden; border: 1px solid rgba(212,175,55,.42); border-radius: 18px; box-shadow: var(--shadow); }
.map-card iframe { display: block; width: 100%; height: 400px; border: 0; }
.footer { padding: 56px 0 24px; background: var(--carvao); color: rgba(245,232,211,.9); }
.footer__grid { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 42px; }
.footer img { height: 64px; width: auto; padding: 8px; border-radius: 10px; background: var(--bege); margin-bottom: 16px; }
.footer p, .footer a { display: block; margin: 0 0 10px; color: rgba(245,232,211,.72); font-size: 14px; line-height: 1.6; }
.footer a:hover { color: var(--tulipa); }
.footer h4 { margin-bottom: 16px; color: var(--dourado); font-size: 20px; }
.copyright { margin-top: 36px; padding-top: 22px; border-top: 1px solid rgba(245,232,211,.1); display: flex; justify-content: space-between; gap: 12px; color: rgba(245,232,211,.52); font-size: 12px; }
.whatsapp-fab { position: fixed; right: 20px; bottom: 20px; z-index: 50; width: 58px; height: 58px; border-radius: 50%; background: #25d366; color: white; display: grid; place-items: center; box-shadow: 0 14px 34px rgba(0,0,0,.24); transition: transform .2s ease; }
.whatsapp-fab:hover { transform: scale(1.08); }
.whatsapp-fab svg { width: 30px; height: 30px; fill: currentColor; stroke: none; }
.menu-overlay { position: fixed; inset: 0; z-index: 80; background: rgba(45,41,38,.52); }
.mobile-menu { position: fixed; inset: 0 auto 0 0; z-index: 90; width: min(80vw, 320px); background: var(--bege); box-shadow: 18px 0 45px rgba(0,0,0,.24); padding: 24px; display: flex; flex-direction: column; transform: translateX(-105%); transition: transform .25s ease; }
.mobile-menu[aria-hidden="false"] { transform: translateX(0); }
.mobile-menu__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.mobile-menu__head img { height: 52px; width: auto; }
.menu-close { width: 40px; height: 40px; border: 0; background: transparent; color: var(--carvao); display: grid; place-items: center; cursor: pointer; }
.menu-close svg { width: 26px; height: 26px; }
.mobile-menu nav { display: grid; }
.mobile-menu nav a { padding: 14px 0; border-bottom: 1px solid var(--line); font-weight: 700; }
.mobile-cta { margin-top: 24px; width: 100%; padding-block: 14px; }
.mobile-socials { margin-top: auto; padding-top: 24px; display: flex; align-items: center; gap: 16px; color: rgba(45,41,38,.72); }
.mobile-socials svg { width: 22px; height: 22px; }
.mobile-socials span { margin-left: auto; font-size: 12px; }
.menu-open { overflow: hidden; }
@media (max-width: 900px) {
  .category-grid { grid-template-columns: repeat(3, 1fr); }
  .location__grid, .footer__grid { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
  .topbar, .desktop-nav, .desktop-cta { display: none; }
  .navbar { min-height: 74px; padding: 10px 16px; display: grid; grid-template-columns: 1fr auto 1fr; gap: 0; }
  .hamburger { display: grid; justify-self: start; place-items: center; width: 42px; height: 42px; border: 0; background: transparent; color: var(--carvao); cursor: pointer; }
  .hamburger svg { width: 28px; height: 28px; }
  .brand { justify-self: center; }
  .brand img { height: 52px; }
  .mobile-spacer { display: block; }
  .slider-btn { width: 38px; height: 38px; }
  .slider-btn--prev { left: 8px; }
  .slider-btn--next { right: 8px; }
  .dots { bottom: 14px; }
  .differentials { padding: 44px 0; }
  .differentials__grid { grid-template-columns: repeat(2, 1fr); gap: 24px 16px; }
  .differentials h3 { font-size: 15px; }
  .differentials p { font-size: 12px; }
  .collection, .about, .location { padding: 58px 0 64px; }
  .category-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .category-grid a { min-height: 132px; padding: 20px 12px; border-radius: 16px; }
  .lead { margin-bottom: 34px; }
  .about p:not(.eyebrow) { font-size: 16px; }
  .values { flex-wrap: wrap; gap: 10px 14px; }
  .actions { flex-direction: column; }
  .primary-btn, .outline-btn { width: 100%; }
  .map-card iframe { height: 330px; }
  .copyright { flex-direction: column; }
  .whatsapp-fab { width: 54px; height: 54px; right: 16px; bottom: 16px; }
}
