/* ============================================================
   MS Elegância — style.css (Nuvemshop)
   Versão: 1.0 · Marca: MS Elegância · Semijoias
   Importar Montserrat via Google Fonts em layout.tpl.
   @font-face para Galgony/Mansion também em layout.tpl (usa asset_url Liquid).
   ============================================================ */

/* ---- TOKENS ---------------------------------------------- */
:root {
  --magenta:     #963D68;
  --magenta-deep:#7E2F56;
  --magenta-dark:#6A2748;
  --magenta-100: #F4E6EC;
  --gold:        #C2A14D;
  --gold-deep:   #A6852F;
  --gold-light:  #DFC889;
  --gold-100:    #F4ECD4;
  --ivory:       #FBF7F0;
  --cream:       #F6F0E7;
  --sand:        #EDE3D4;
  --linen:       #E3D6C3;
  --taupe:       #D9CCBC;
  --ink:         #221A1F;
  --ink-2:       #5A4E54;
  --ink-3:       #8A7E84;
  --white:       #FFFFFF;
  --hairline:    rgba(154,122,46,.4);
  --focus-ring:  rgba(166,34,92,.35);
  --success:     #5E7C53;
  --danger:      #9E3B3B;

  --tracking-tight:  -0.02em;
  --tracking-wide:    0.08em;
  --tracking-wider:   0.18em;
  --tracking-widest:  0.32em;

  --font-display: "Galgony", Georgia, serif;
  --font-sans:    "Montserrat", system-ui, sans-serif;
  --font-alt:     "Montserrat Alternates", "Montserrat", sans-serif;
  --font-poster:  "Mansion", Impact, sans-serif;

  --radius-sm: 4px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-pill: 999px;

  --shadow-sm: 0 2px 10px rgba(58,40,30,.07);
  --shadow-md: 0 10px 30px rgba(58,40,30,.10);
  --ease:      cubic-bezier(.22,1,.36,1); /* @kind other */
  --dur:       240ms; /* @kind other */

  --max-w: 1200px; /* @kind spacing */
  --gutter: clamp(16px, 4vw, 40px); /* @kind spacing */
}

/* ---- RESET / BASE ---------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }

/* Acessibilidade: anel de foco da marca em navegação por teclado */
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, [tabindex]:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--focus-ring);
  border-radius: var(--radius-sm);
}
body { background: var(--cream); color: var(--ink); font-family: var(--font-sans); font-size: 15px; line-height: 1.6; -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; font-family: inherit; }

/* ---- UTILITÁRIOS ----------------------------------------- */
.container  { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--gutter); }
.sr-only    { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }
.eyebrow    { font-family:var(--font-alt); font-size:11px; font-weight:500; text-transform:uppercase; letter-spacing:.22em; color:var(--gold-deep); }
.display    { font-family:var(--font-display); font-weight:400; letter-spacing:-.01em; line-height:1.05; }
.hairline   { border:none; height:1px; background:var(--hairline); }

/* ============================================================
   HEADER & NAV
   ============================================================ */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(251,247,240,.88); backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(154,122,46,.2);
}
.promo-bar {
  background: var(--ink); color: var(--gold-light);
  font-family: var(--font-alt); font-size: 11px; letter-spacing: .18em;
  text-transform: uppercase; text-align: center; padding: 9px var(--gutter);
  white-space: nowrap; overflow: hidden;
}
.header-inner {
  display: flex; align-items: center; gap: 16px;
  padding: 14px var(--gutter);
  max-width: var(--max-w); margin: 0 auto;
}
.header-logo { flex: 1; display: flex; justify-content: center; }
.header-logo img.monogram { height: 38px; width: auto; }
.header-logo .wordmark { display:flex; align-items:center; gap:10px; }
.header-logo .wordmark-ms { font-family:var(--font-display); font-size:26px; color:var(--magenta); }
.header-logo .wordmark-bar { width:1px; height:22px; background:var(--gold); }
.header-logo .wordmark-name { font-family:var(--font-alt); font-size:14px; font-weight:500; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-deep); }

.header-left, .header-right { display:flex; gap:16px; align-items:center; width:120px; }
.header-right { justify-content: flex-end; }

.header-icon { background:none; border:none; padding:4px; line-height:0; color:var(--ink); transition:color var(--dur) var(--ease); }
.header-icon:hover { color:var(--magenta); }
.cart-btn { position:relative; }
.cart-count { position:absolute; top:-6px; right:-8px; background:var(--magenta); color:#fff; font-size:10px; font-weight:700; width:17px; height:17px; border-radius:50%; display:grid; place-items:center; font-family:var(--font-sans); }

.site-nav { border-top:1px solid rgba(154,122,46,.15); }
.site-nav ul { display:flex; justify-content:center; gap:32px; list-style:none; padding:11px var(--gutter); max-width:var(--max-w); margin:0 auto; }
.site-nav a { font-family:var(--font-display); font-size:15px; font-weight:400; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2); padding:4px 0; border-bottom:1.5px solid transparent; transition:all var(--dur) var(--ease); }
.site-nav a:hover { color:var(--ink); border-bottom-color:var(--gold); }

/* menu mobile */
.menu-toggle { display:none; background:none; border:none; padding:4px; line-height:0; color:var(--ink); }
.mobile-menu { display:none; position:fixed; inset:0; background:var(--ivory); z-index:200; flex-direction:column; padding:24px var(--gutter); }
.mobile-menu.open { display:flex; }
.mobile-menu ul { list-style:none; margin-top:40px; display:flex; flex-direction:column; gap:4px; }
.mobile-menu a { font-family:var(--font-display); font-size:36px; color:var(--ink); padding:10px 0; display:block; border-bottom:1px solid var(--hairline); }
.mobile-close { align-self:flex-end; background:none; border:none; font-size:28px; color:var(--ink); }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position:relative; overflow:hidden;
  height: clamp(420px, 60vh, 640px);
  background: var(--ink) url('hero-bg.jpg') center/cover no-repeat;
  color: var(--cream);
}
.hero-overlay { position:absolute; inset:0; background:linear-gradient(100deg,rgba(34,26,31,.78) 0%,rgba(34,26,31,.25) 60%,transparent 100%); }
.hero-content { position:relative; height:100%; display:flex; align-items:center; }
.hero-inner { max-width:480px; padding: 0 var(--gutter); margin:0 auto 0 max(var(--gutter),calc((100vw - var(--max-w))/2 + var(--gutter))); }
.hero-eyebrow { color:var(--gold-light); margin-bottom:16px; }
.hero-title { font-family:var(--font-display); font-size:clamp(40px,6vw,68px); line-height:1.04; color:var(--cream); margin-bottom:20px; }
.hero-title em { font-family:var(--font-display); font-style:italic; color:var(--gold-light); }
.hero-subtitle { font-size:16px; font-weight:300; color:rgba(255,255,255,.8); margin-bottom:30px; max-width:380px; }

/* ============================================================
   BOTÕES
   ============================================================ */
.btn { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-alt); font-size:12px; font-weight:500; letter-spacing:.14em; text-transform:uppercase; padding:14px 30px; border-radius:var(--radius-pill); border:1px solid transparent; transition:all var(--dur) var(--ease); }
.btn-primary { background:var(--magenta); color:#FBF1F5; border-color:var(--magenta); }
.btn-primary:hover { background:var(--magenta-dark); border-color:var(--magenta-dark); }
.btn-gold { background:var(--gold); color:var(--ink); }
.btn-gold:hover { background:var(--gold-deep); }
.btn-ghost { background:transparent; color:var(--ink); border-color:var(--taupe); }
.btn-ghost:hover { border-color:var(--gold); color:var(--gold-deep); }
.btn-ghost-light { background:transparent; color:var(--cream); border-color:rgba(223,200,137,.6); }
.btn-ghost-light:hover { background:rgba(223,200,137,.12); }
.btn-full { width:100%; justify-content:center; }
.btn-lg { padding:17px 36px; font-size:13px; }

/* ============================================================
   SEÇÃO: FEATURED / VITRINE
   ============================================================ */
.section { padding: clamp(48px,7vw,96px) 0; }
.section-header { text-align:center; margin-bottom:48px; }
.section-title { font-family:var(--font-display); font-size:clamp(28px,4vw,44px); color:var(--ink); margin-top:10px; }
.section-rule { width:72px; height:1px; background:var(--hairline); margin:20px auto 0; }

/* grade de produtos */
.product-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:28px; }

/* ============================================================
   CARD DE PRODUTO
   ============================================================ */
.product-card { background:var(--white); border:1px solid var(--taupe); border-radius:var(--radius-lg); overflow:hidden; transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.product-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.product-card__image { position:relative; aspect-ratio:1; overflow:hidden; background:var(--sand); }
.product-card__image img { width:100%; height:100%; object-fit:cover; transition:transform .4s var(--ease); }
.product-card:hover .product-card__image img { transform:scale(1.04); }
.product-card__badge { position:absolute; top:12px; left:12px; background:var(--gold-100); color:var(--ink); font-family:var(--font-alt); font-size:10px; font-weight:500; letter-spacing:.12em; text-transform:uppercase; padding:5px 12px; border-radius:var(--radius-pill); white-space:nowrap; }
.product-card__body { padding:16px 18px 20px; }
.product-card__cat { font-family:var(--font-alt); font-size:10px; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:5px; }
.product-card__name { font-family:var(--font-display); font-size:22px; color:var(--ink); line-height:1.2; margin-bottom:3px; }
.product-card__price { font-family:var(--font-display); font-size:20px; color:var(--magenta); }
.product-card__compare { font-size:13px; color:var(--ink-3); text-decoration:line-through; margin-left:8px; }
.product-card__footer { display:flex; align-items:center; justify-content:space-between; margin-top:12px; }
.product-card__link { font-family:var(--font-sans); font-size:12px; color:var(--ink-2); letter-spacing:.04em; border-bottom:1px solid var(--hairline); padding-bottom:2px; transition:color var(--dur); }
.product-card__link:hover { color:var(--magenta); }

/* ============================================================
   CATEGORY PAGE
   ============================================================ */
.category-header { padding:clamp(40px,5vw,72px) 0 32px; border-bottom:1px solid var(--hairline); }
.category-header h1 { font-family:var(--font-display); font-size:clamp(32px,4vw,52px); color:var(--ink); }
.category-count { font-size:13px; color:var(--ink-3); margin-top:6px; }
.category-layout { display:grid; grid-template-columns:220px 1fr; gap:40px; align-items:start; padding-top:40px; }
.filters h3 { font-family:var(--font-alt); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:14px; }
.filter-group { margin-bottom:28px; }
.filter-group ul { list-style:none; display:flex; flex-direction:column; gap:8px; }
.filter-group a { font-size:14px; color:var(--ink-2); transition:color var(--dur); display:flex; align-items:center; gap:8px; }
.filter-group a:hover, .filter-group a.active { color:var(--magenta); }
.pagination { display:flex; justify-content:center; gap:8px; padding:56px 0 0; }
.pagination a, .pagination span { width:40px; height:40px; display:grid; place-items:center; border-radius:var(--radius-md); font-size:14px; color:var(--ink-2); border:1px solid var(--taupe); transition:all var(--dur); }
.pagination a:hover, .pagination .current { background:var(--magenta); color:#fff; border-color:var(--magenta); }

/* ============================================================
   PRODUCT PAGE
   ============================================================ */
.product-layout { display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(32px,5vw,72px); align-items:start; padding:clamp(32px,4vw,56px) 0 clamp(64px,8vw,120px); }
.product-gallery__main { border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:1; background:var(--sand); }
.product-gallery__main img { width:100%; height:100%; object-fit:cover; }
.product-gallery__thumbs { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-top:12px; }
.product-gallery__thumb { aspect-ratio:1; border-radius:var(--radius-md); overflow:hidden; border:1px solid var(--taupe); cursor:pointer; transition:border-color var(--dur); }
.product-gallery__thumb:hover, .product-gallery__thumb.active { border-color:var(--gold); }
.product-gallery__thumb img { width:100%; height:100%; object-fit:cover; }
.product-info__cat { margin-bottom:6px; }
.product-info__name { font-family:var(--font-display); font-size:clamp(32px,3.5vw,52px); line-height:1.04; color:var(--ink); margin-bottom:6px; }
.product-info__note { font-size:14px; color:var(--ink-3); letter-spacing:.04em; }
.product-info__price { font-family:var(--font-display); font-size:38px; color:var(--magenta); margin:20px 0 4px; }
.product-info__installments { font-size:13px; color:var(--ink-3); }
.product-info__desc { font-size:15px; font-weight:300; line-height:1.7; color:var(--ink-2); margin-top:24px; max-width:440px; }
.product-info__variants { margin-top:26px; }
.product-info__variants label { font-family:var(--font-alt); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-2); display:block; margin-bottom:10px; }
.variant-btns { display:flex; flex-wrap:wrap; gap:8px; }
.variant-btn { padding:8px 18px; border-radius:var(--radius-pill); border:1px solid var(--taupe); font-size:13px; background:transparent; color:var(--ink); transition:all var(--dur); }
.variant-btn:hover, .variant-btn.selected { border-color:var(--gold); color:var(--gold-deep); }
.product-info__cta { display:flex; gap:12px; margin-top:28px; }
.product-info__meta { margin-top:24px; border-top:1px solid var(--hairline); }
.meta-row { display:flex; justify-content:space-between; padding:13px 0; border-bottom:1px solid var(--hairline); font-size:13px; }
.meta-row dt { font-family:var(--font-alt); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink); }
.meta-row dd { color:var(--ink-2); }

/* ============================================================
   CART DRAWER
   ============================================================ */
.cart-overlay { display:none; position:fixed; inset:0; background:rgba(34,26,31,.4); z-index:300; }
.cart-overlay.open { display:block; }
.cart-drawer { position:fixed; top:0; right:0; bottom:0; width:clamp(300px,90vw,400px); background:var(--ivory); z-index:301; transform:translateX(100%); transition:transform var(--dur) var(--ease); display:flex; flex-direction:column; }
.cart-drawer.open { transform:translateX(0); }
.cart-drawer__head { display:flex; justify-content:space-between; align-items:center; padding:22px 24px; border-bottom:1px solid var(--hairline); }
.cart-drawer__title { font-family:var(--font-display); font-size:24px; color:var(--ink); }
.cart-drawer__close { background:none; border:none; font-size:22px; color:var(--ink-3); }
.cart-drawer__body { flex:1; overflow-y:auto; padding:8px 24px; }
.cart-empty { text-align:center; padding:60px 0; color:var(--ink-3); font-size:14px; }
.cart-item { display:flex; gap:14px; padding:16px 0; border-bottom:1px solid var(--hairline); }
.cart-item__img { width:68px; height:68px; border-radius:var(--radius-md); background:var(--sand); overflow:hidden; flex:none; }
.cart-item__img img { width:100%; height:100%; object-fit:cover; }
.cart-item__info { flex:1; }
.cart-item__name { font-family:var(--font-display); font-size:17px; color:var(--ink); }
.cart-item__qty { font-size:12px; color:var(--ink-3); margin-top:3px; }
.cart-item__price { font-family:var(--font-display); font-size:16px; color:var(--magenta); margin-top:5px; }
.cart-drawer__foot { padding:20px 24px; border-top:1px solid var(--hairline); }
.cart-total { display:flex; justify-content:space-between; margin-bottom:14px; }
.cart-total dt { font-family:var(--font-alt); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-2); }
.cart-total dd { font-family:var(--font-display); font-size:22px; color:var(--ink); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { background:var(--ink); color:var(--cream); padding:clamp(56px,7vw,96px) 0 40px; }
.footer-inner { max-width:var(--max-w); margin:0 auto; padding:0 var(--gutter); display:grid; grid-template-columns:1.5fr repeat(3,1fr); gap:48px; }
.footer-brand p { font-size:13px; font-weight:300; color:rgba(255,255,255,.7); line-height:1.7; margin-top:14px; max-width:280px; }
.footer-col h4 { font-family:var(--font-alt); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-light); margin-bottom:16px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col a { font-size:13px; font-weight:300; color:rgba(255,255,255,.7); transition:color var(--dur); }
.footer-col a:hover { color:var(--cream); }
.footer-bottom { max-width:var(--max-w); margin:40px auto 0; padding:24px var(--gutter) 0; border-top:1px solid rgba(255,255,255,.1); display:flex; justify-content:space-between; align-items:center; font-size:12px; color:rgba(255,255,255,.45); }
.footer-spark { letter-spacing:.1em; }

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width: 900px) {
  .category-layout { grid-template-columns:1fr; }
  .filters { display:none; } /* em mobile use um botão de filtro */
  .product-layout { grid-template-columns:1fr; }
  .product-info__cta { flex-direction:column; }
  .footer-inner { grid-template-columns:1fr 1fr; }
}
@media (max-width: 640px) {
  .site-nav ul { display:none; }
  .menu-toggle { display:block; }
  .header-logo .wordmark-name { display:none; }
  .product-grid { grid-template-columns:repeat(2,1fr); gap:14px; }
  .footer-inner { grid-template-columns:1fr; }
}

/* ============================================================
   Complementos — versão Nuvemshop (busca no header, selects de
   variação, página da sacola)
   ============================================================ */

/* Busca no header */
.header-search { display:flex; align-items:center; gap:6px; }
.header-search__input { border:none; border-bottom:1px solid var(--taupe); background:transparent; font-family:var(--font-sans); font-size:13px; color:var(--ink); padding:4px 2px; width:0; opacity:0; transition:all var(--dur) var(--ease); }
.header-search:focus-within .header-search__input,
.header-search__input:not(:placeholder-shown) { width:130px; opacity:1; }
.header-search__input:focus { outline:none; border-bottom-color:var(--gold); }
@media (max-width: 720px) { .header-search:focus-within .header-search__input { width:90px; } }

/* Select de variações (produto) */
.variant-select { width:100%; max-width:280px; padding:12px 16px; border-radius:var(--radius-md); border:1px solid var(--taupe); background:transparent; font-family:var(--font-sans); font-size:14px; color:var(--ink); }
.variant-select:focus { outline:none; border-color:var(--gold); }

/* Página da sacola */
.cart-page { display:grid; grid-template-columns:1.6fr 1fr; gap:48px; align-items:start; padding-bottom:64px; }
@media (max-width: 880px) { .cart-page { grid-template-columns:1fr; } }
.cart-item--page { display:flex; gap:16px; padding:18px 0; border-bottom:1px solid var(--hairline); }
.cart-page__summary { background:var(--sand); border-radius:var(--radius-lg, 14px); padding:28px; }
.cart-total--final dd { color:var(--magenta); }
