/* Atelier Éclat — Boutique Demo
   Autor: entrega pronta para produção (HTML/CSS/JS puro)
   Observação: sem frameworks; foco em performance, SEO e sensação premium.
*/

:root{
  --bg: #FBFAF7;
  --bg2:#F4F2EE;
  --ink:#121316;
  --muted:#5B616B;
  --muted2:#7A818D;
  --line: rgba(18,19,22,.12);
  --line2: rgba(18,19,22,.08);
  --card:#FFFFFF;
  --shadow: 0 16px 40px rgba(0,0,0,.10);
  --shadow2: 0 10px 24px rgba(0,0,0,.08);
  --accent:#C7A56B; /* dourado discreto */
  --accent2:#E9DAB7;
  --radius: 18px;
  --radius2: 28px;

  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  --serif: ui-serif, "Iowan Old Style", "Palatino Linotype", Palatino, Garamond, "Times New Roman", serif;

  --container: min(1180px, calc(100vw - 48px));

  --step--1: clamp(12px, 1.1vw, 13px);
  --step-0: clamp(14px, 1.2vw, 16px);
  --step-1: clamp(16px, 1.6vw, 18px);
  --step-2: clamp(20px, 2.2vw, 24px);
  --step-3: clamp(28px, 3.2vw, 40px);
  --step-4: clamp(40px, 5vw, 62px);

  --ease: cubic-bezier(.2,.8,.2,1);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--ink);
  background:radial-gradient(1200px 600px at 30% -10%, rgba(199,165,107,.14), transparent 55%),
             radial-gradient(900px 520px at 95% 0%, rgba(18,19,22,.06), transparent 45%),
             linear-gradient(180deg, var(--bg), var(--bg));
  font-family:var(--sans);
  font-size:var(--step-0);
  line-height:1.55;
  text-rendering:optimizeLegibility;
}
img{max-width:100%; height:auto; display:block}
a{color:inherit; text-decoration:none}
button,input,select,textarea{font:inherit}

::selection{background:rgba(199,165,107,.35)}

/* Acessibilidade */
.skip{
  position:absolute; left:-999px; top:10px;
  background:var(--ink); color:var(--bg);
  padding:10px 12px; border-radius:12px;
  z-index:9999;
}
.skip:focus{left:10px}

.container{width:var(--container); margin:0 auto}

/* Header */
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(140%) blur(10px);
  background:rgba(251,250,247,.82);
  border-bottom:1px solid var(--line2);
}

/* Home: header sobre o hero imersivo (efeito editorial) */
body.home .site-header{
  position:fixed;
  left:0; right:0;
  background: rgba(10,12,14,.12);
  border-bottom: 1px solid rgba(255,255,255,.10);
  backdrop-filter: saturate(120%) blur(8px);
}
body.home .topbar{
  background: rgba(10,12,14,.18);
  border-bottom: 1px solid rgba(255,255,255,.12);
}
body.home .topbar-inner{ color: rgba(255,255,255,.78) }
body.home .topbar .toplink{ color: rgba(255,255,255,.82); text-decoration-color: rgba(255,255,255,.22) }
body.home .topbar .toplink:hover{ color: rgba(255,255,255,.96) }
body.home .brand .word span{ color: rgba(255,255,255,.72) }
body.home .nav a{ color: rgba(255,255,255,.88) }
body.home .nav a:hover{ background: rgba(255,255,255,.10) }
body.home .icon-btn{ background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.18); color: rgba(255,255,255,.92) }
body.home .badge{ background: rgba(255,255,255,.18); color: rgba(255,255,255,.96) }

/* Ao rolar: volta para o header claro (premium clean) */
body.home .site-header.is-solid{
  background: rgba(251,250,247,.88);
  border-bottom: 1px solid rgba(18,19,22,.08);
}
body.home .site-header.is-solid .topbar{ background: rgba(251,250,247,.62); border-bottom: 1px solid rgba(18,19,22,.08) }
body.home .site-header.is-solid .topbar-inner{ color: rgba(18,19,22,.66) }
body.home .site-header.is-solid .topbar .toplink{ color: rgba(18,19,22,.72); text-decoration-color: rgba(199,165,107,.32) }
body.home .site-header.is-solid .brand .word span{ color: var(--muted2) }
body.home .site-header.is-solid .nav a{ color: rgba(18,19,22,.86) }
body.home .site-header.is-solid .icon-btn{ background: rgba(255,255,255,.66); border-color: rgba(18,19,22,.10); color: rgba(18,19,22,.92) }
body.home .site-header.is-solid .badge{ background: rgba(18,19,22,.08); color: rgba(18,19,22,.92) }

/* Topbar (premium info strip) */
.topbar{
  border-bottom:1px solid rgba(18,19,22,.08);
  background: rgba(251,250,247,.62);
}
.topbar-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
  padding:8px 0;
  color: rgba(18,19,22,.66);
  font-size:12px;
  letter-spacing:.06em;
}
.topbar-left,.topbar-right{display:flex; align-items:center; gap:10px; flex-wrap:wrap}
.topbar .toplink{
  text-decoration: underline;
  text-decoration-color: rgba(199,165,107,.32);
  text-underline-offset: 3px;
  color: rgba(18,19,22,.72);
}
.topbar .toplink:hover{color: rgba(18,19,22,.92)}
.topbar .sep{opacity:.6}
.topbar .toptext{opacity:.92}
.header-inner{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  padding:14px 0;
  gap:14px;
}
.brand{
  display:flex; align-items:center; gap:10px;
  min-width: 220px;
}
.brand .mark{
  width:34px; height:34px; border-radius:12px;
  background:linear-gradient(135deg, #121316, #2A2D33);
  display:grid; place-items:center;
  box-shadow: var(--shadow2);
  border:1px solid rgba(199,165,107,.28);
}
.brand .mark img{width:20px; height:20px}
.brand .word{
  display:flex; flex-direction:column; line-height:1.05;
}
.brand .word strong{
  font-family:var(--serif);
  font-size: 18px;
  letter-spacing:.06em;
}
.brand .word span{
  font-size:12px;
  letter-spacing:.18em;
  color:var(--muted2);
}

.nav{
  display:flex; align-items:center; justify-content:center;
  gap:18px;
}
.nav a{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(18,19,22,.86);
  padding:10px 8px;
  border-radius:12px;
  transition:background .2s var(--ease), transform .2s var(--ease);
}
.nav a:hover{background:rgba(18,19,22,.06)}

.header-actions{
  display:flex; align-items:center; justify-content:flex-end; gap:10px;
}
.icon-btn{
  border:1px solid var(--line2);
  background:rgba(255,255,255,.66);
  border-radius:14px;
  padding:10px 12px;
  display:flex; align-items:center; gap:10px;
  cursor:pointer;
  transition: transform .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease);
}
.icon-btn:hover{transform:translateY(-1px); background:#fff; border-color:var(--line)}
.icon{
  width:18px; height:18px; opacity:.86;
}
.badge{
  min-width:20px; height:20px; border-radius:999px;
  padding:0 7px; display:inline-grid; place-items:center;
  font-size:12px; letter-spacing:.02em;
  background:rgba(199,165,107,.22);
  border:1px solid rgba(199,165,107,.35);
}

.mobile-toggle{display:none}

/* Mega */
.mega{
  position:absolute; left:0; right:0;
  top:100%;
  border-bottom:1px solid var(--line2);
  background:rgba(251,250,247,.92);
  backdrop-filter:saturate(140%) blur(10px);
  transform-origin: top;
  transform: scaleY(.98);
  opacity:0;
  pointer-events:none;
  transition:opacity .2s var(--ease), transform .2s var(--ease);
}
.mega.is-open{opacity:1; transform:scaleY(1); pointer-events:auto}
.mega-inner{
  width:var(--container);
  margin:0 auto;
  padding:18px 0 22px;
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr .9fr;
  gap:18px;
}
.mega h4{
  margin:0 0 10px;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted2);
}
.mega a{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid transparent;
  transition: background .18s var(--ease), border-color .18s var(--ease);
}
.mega a:hover{background:#fff; border-color:var(--line2)}
.mega a span{color:var(--muted)}

.mega-card{
  background:linear-gradient(135deg, rgba(18,19,22,.88), rgba(18,19,22,.76)),
             radial-gradient(600px 240px at 20% 0%, rgba(199,165,107,.35), transparent 55%);
  border:1px solid rgba(255,255,255,.10);
  border-radius: var(--radius2);
  padding:18px;
  color:#fff;
  box-shadow: var(--shadow);
  display:flex; flex-direction:column; justify-content:space-between;
  min-height: 220px;
}
.mega-card small{opacity:.82; letter-spacing:.16em; text-transform:uppercase}
.mega-card strong{font-family:var(--serif); font-size:28px; letter-spacing:.03em; line-height:1.12; margin:10px 0 6px}
.mega-card p{margin:0; opacity:.86; max-width: 34ch}
.mega-card .cta{
  margin-top:14px;
  display:inline-flex; align-items:center; justify-content:space-between;
  gap:10px;
  padding:12px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.20);
  transition: transform .18s var(--ease), background .18s var(--ease);
}
.mega-card .cta:hover{transform:translateY(-1px); background: rgba(255,255,255,.18)}

/* Hero */
.hero{
  padding: 56px 0 26px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:28px;
  align-items:stretch;
}
.kicker{
  display:flex; align-items:center; gap:10px;
  color:var(--muted2);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.kicker .dot{
  width:8px; height:8px; border-radius:999px;
  background:rgba(199,165,107,.9);
  box-shadow: 0 0 0 6px rgba(199,165,107,.18);
}
.h1{
  margin: 14px 0 10px;
  font-family:var(--serif);
  font-size: var(--step-4);
  letter-spacing: .02em;
  line-height:1.05;
}
.lead{
  margin:0 0 18px;
  color:var(--muted);
  font-size: var(--step-1);
  max-width: 52ch;
}

.hero-actions{display:flex; gap:12px; flex-wrap:wrap}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding: 12px 16px;
  border-radius: 999px;
  border:1px solid var(--line2);
  background:rgba(255,255,255,.86);
  cursor:pointer;
  transition: transform .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease);
}
.btn:hover{transform:translateY(-1px); background:#fff; border-color:var(--line)}
.btn.primary{
  background: linear-gradient(135deg, var(--ink), #2A2D33);
  color: var(--bg);
  border-color: rgba(0,0,0,.2);
}
.btn.primary:hover{background: linear-gradient(135deg, #0E0F12, #2C2F36)}
.btn .sub{font-size:12px; color:rgba(255,255,255,.75)}

.hero-panel{
  position:relative;
  border-radius: var(--radius2);
  overflow:hidden;
  border:1px solid var(--line2);
  background: linear-gradient(135deg, rgba(41, 56, 99, 0.92), rgba(18,19,22,.74)),
              radial-gradient(800px 320px at 18% 0%, rgba(199,165,107,.32), transparent 55%),
              radial-gradient(600px 260px at 90% 80%, rgba(233,218,183,.24), transparent 55%);
  color:#fff;
  box-shadow: var(--shadow);
  padding: 22px 22px 18px;
}
.hero-panel .panel-top{
  display:flex; align-items:flex-start; justify-content:space-between; gap:12px;
}
.hero-panel .panel-top .label{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.16);
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.hero-panel h2{
  margin: 14px 0 6px;
  font-family:var(--serif);
  font-size: var(--step-3);
  line-height:1.08;
  letter-spacing:.02em;
}
.hero-panel p{margin:0; opacity:.86; max-width: 46ch}

.panel-strip{
  margin-top: 18px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
.strip-card{
  background: rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  border-radius: 18px;
  padding: 12px 12px;
}
.strip-card strong{display:block; letter-spacing:.14em; text-transform:uppercase; font-size:12px}
.strip-card span{display:block; opacity:.82; font-size:13px; margin-top:3px}

/* Section base */
.section{padding: 44px 0}
.section.alt{background: linear-gradient(180deg, rgba(244,242,238,.85), rgba(244,242,238,.55)); border-top:1px solid var(--line2); border-bottom:1px solid var(--line2)}
.section-head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:14px;
  margin-bottom: 18px;
}
.section-head h3{
  margin:0;
  font-family:var(--serif);
  font-size: var(--step-2);
  letter-spacing:.02em;
}
.section-head p{margin:0; color:var(--muted); max-width: 58ch}

/* Collections tiles */
.tiles{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:14px;
}
.tile{
  grid-column: span 6;
  background: #fff;
  border: 1px solid var(--line2);
  border-radius: var(--radius2);
  overflow:hidden;
  box-shadow: 0 8px 26px rgba(0,0,0,.06);
  transition: transform .18s var(--ease), box-shadow .18s var(--ease);
}
.tile:hover{transform: translateY(-2px); box-shadow: var(--shadow2)}
.tile .media{
  aspect-ratio: 16/10;
  background:
    radial-gradient(900px 420px at 12% 20%, rgba(199,165,107,.20), transparent 56%),
    radial-gradient(840px 380px at 90% 80%, rgba(18,19,22,.06), transparent 55%),
    linear-gradient(180deg, #fff, #F4F2EE);
  position:relative;
}
.tile .media::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, transparent, rgba(18,19,22,.06));
}
.tile .content{padding:16px 16px 18px}
.tile .content .eyebrow{font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted2)}
.tile .content h4{margin:8px 0 6px; font-family:var(--serif); font-size: 26px; letter-spacing:.02em; line-height:1.12}
.tile .content p{margin:0; color:var(--muted); max-width: 54ch}
.tile .content .meta{margin-top:12px; display:flex; align-items:center; justify-content:space-between; gap:12px}
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding: 10px 12px;
  border-radius: 999px;
  border:1px solid var(--line2);
  background: rgba(244,242,238,.65);
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.pill .mini{width:8px; height:8px; border-radius:999px; background:rgba(199,165,107,.9); box-shadow:0 0 0 6px rgba(199,165,107,.16)}

/* Product grid */
.product-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.card{
  grid-column: span 3;
  border:1px solid var(--line2);
  border-radius: var(--radius);
  overflow:hidden;
  background: #fff;
  box-shadow: 0 8px 22px rgba(0,0,0,.05);
  transition: transform .18s var(--ease), box-shadow .18s var(--ease);
}
.card:hover{transform: translateY(-2px); box-shadow: var(--shadow2)}
.card .img{
  background: linear-gradient(180deg, #fff, #F4F2EE);
  padding: 12px;
}
.card .img img{border-radius: 14px; border:1px solid var(--line2)}
.card .info{padding: 12px 12px 14px}
.card .info .name{font-family:var(--serif); font-size:18px; letter-spacing:.01em; line-height:1.15; margin:0 0 4px}
.card .info .desc{margin:0 0 10px; color:var(--muted); font-size:13px}
.card .info .row{display:flex; align-items:center; justify-content:space-between; gap:10px}
.price{font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:rgba(18,19,22,.84)}
.tag{
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted2);
  border:1px solid var(--line2);
  background: rgba(244,242,238,.55);
  padding: 8px 10px;
  border-radius: 999px;
}

/* Editorial band */
.editorial{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
  align-items:stretch;
}
.editorial .frame{
  border-radius: var(--radius2);
  overflow:hidden;
  border:1px solid var(--line2);
  box-shadow: 0 10px 28px rgba(0,0,0,.06);
  background:
    radial-gradient(1000px 520px at 20% 10%, rgba(199,165,107,.22), transparent 55%),
    radial-gradient(840px 420px at 90% 80%, rgba(18,19,22,.08), transparent 58%),
    linear-gradient(135deg, #FFFFFF, #F4F2EE);
  position:relative;
}
.editorial .frame::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 45%, rgba(18,19,22,.08));
}
.editorial .note{
  background:#fff;
  border:1px solid var(--line2);
  border-radius: var(--radius2);
  padding: 18px;
  box-shadow: 0 10px 28px rgba(0,0,0,.06);
}
.editorial .note small{display:block; color:var(--muted2); letter-spacing:.18em; text-transform:uppercase}
.editorial .note h4{margin:10px 0 10px; font-family:var(--serif); font-size: 28px; line-height:1.14}
.editorial .note p{margin:0 0 14px; color:var(--muted)}

/* Breadcrumb */
.breadcrumb{
  padding: 18px 0 0;
  color: var(--muted2);
  font-size:12px;
  letter-spacing:.08em;
}
.breadcrumb a{color:rgba(18,19,22,.72)}
.breadcrumb .sep{opacity:.5; margin:0 8px}

/* Page hero */
.page-hero{padding: 34px 0 18px}
.page-hero h1{margin:10px 0 6px; font-family:var(--serif); font-size: var(--step-3); letter-spacing:.02em; line-height:1.08}
.page-hero p{margin:0; color:var(--muted); max-width: 70ch}

/* Filter bar */
.filters{
  margin-top: 16px;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  flex-wrap:wrap;
}
.filters .left{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.select, .search{
  border:1px solid var(--line2);
  background: rgba(255,255,255,.8);
  border-radius: 999px;
  padding: 10px 12px;
  min-height: 42px;
}
.search{min-width: min(420px, 100%)}

/* Product page */
.product{
  padding: 18px 0 54px;
}
.product-grid2{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 24px;
  align-items:start;
}
.gallery{
  border-radius: var(--radius2);
  border:1px solid var(--line2);
  background:#fff;
  box-shadow: 0 10px 28px rgba(0,0,0,.06);
  overflow:hidden;
}
.gallery .main{
  padding: 14px;
  background: linear-gradient(180deg, #fff, #F4F2EE);
}
.gallery .main img{border-radius: 18px; border:1px solid var(--line2)}
.thumbs{
  display:grid; grid-template-columns: repeat(4, 1fr);
  gap:10px;
  padding: 12px 14px 14px;
  border-top:1px solid var(--line2);
  background: rgba(244,242,238,.55);
}
.thumb{
  border:1px solid var(--line2);
  background:#fff;
  border-radius: 14px;
  overflow:hidden;
  cursor:pointer;
  transition: transform .18s var(--ease);
}
.thumb:hover{transform: translateY(-1px)}
.thumb img{width:100%; height:100%; object-fit:cover}

.pcard{
  background:#fff;
  border:1px solid var(--line2);
  border-radius: var(--radius2);
  box-shadow: 0 10px 28px rgba(0,0,0,.06);
  padding: 18px;
}
.pcard .k{
  color:var(--muted2);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:12px;
}
.pcard h1{margin:10px 0 8px; font-family:var(--serif); font-size: 40px; line-height:1.05}
.pcard .sub{margin:0 0 14px; color:var(--muted)}
.pcard .price-line{display:flex; align-items:baseline; justify-content:space-between; gap:10px; margin:12px 0 10px}
.pcard .price-line strong{letter-spacing:.16em; text-transform:uppercase; font-size:14px}

.variant-row{display:grid; grid-template-columns: 1fr 1fr; gap:10px; margin:12px 0}
.chip{
  border:1px solid var(--line2);
  background: rgba(244,242,238,.55);
  border-radius: 14px;
  padding: 12px;
  cursor:pointer;
  transition: transform .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease);
}
.chip:hover{transform: translateY(-1px); background:#fff; border-color: var(--line)}
.chip strong{display:block; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted2)}
.chip span{display:block; margin-top:4px; color:var(--ink)}

.actions-col{display:flex; gap:10px; flex-wrap:wrap; margin-top: 14px}
.actions-col .btn{flex:1; min-width: 180px}

.details{
  margin-top: 14px;
  border-top:1px solid var(--line2);
  padding-top: 14px;
  display:grid;
  gap:10px;
}
.accordion{
  border:1px solid var(--line2);
  border-radius: 18px;
  overflow:hidden;
}
.accordion button{
  width:100%;
  text-align:left;
  border:0;
  background: rgba(244,242,238,.55);
  padding: 14px 14px;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  cursor:pointer;
}
.accordion button span{font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:rgba(18,19,22,.78)}
.accordion .panel{padding: 0 14px 14px; display:none; background:#fff}
.accordion .panel p{margin:10px 0 0; color:var(--muted)}
.accordion.is-open .panel{display:block}

/* Bag drawer */
.overlay{
  position:fixed; inset:0;
  background: rgba(0,0,0,.42);
  opacity:0; pointer-events:none;
  transition: opacity .2s var(--ease);
  z-index:60;
}
.overlay.is-open{opacity:1; pointer-events:auto}
.drawer{
  position:fixed; top:0; right:0; height:100%; width:min(430px, 92vw);
  background: #fff;
  border-left:1px solid var(--line2);
  box-shadow: -20px 0 60px rgba(0,0,0,.18);
  transform: translateX(102%);
  transition: transform .26s var(--ease);
  z-index:70;
  display:flex; flex-direction:column;
}
.drawer.is-open{transform: translateX(0)}
.drawer header{
  padding: 16px 16px;
  border-bottom:1px solid var(--line2);
  display:flex; align-items:center; justify-content:space-between; gap:10px;
}
.drawer header strong{font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:rgba(18,19,22,.78)}
.drawer header button{border:1px solid var(--line2); background: rgba(244,242,238,.55); border-radius: 14px; padding:10px 12px; cursor:pointer}
.drawer .body{padding: 14px 16px; overflow:auto; flex:1}
.drawer .item{
  display:grid; grid-template-columns: 84px 1fr; gap:12px;
  padding: 12px 0;
  border-bottom:1px solid var(--line2);
}
.drawer .item img{border-radius:14px; border:1px solid var(--line2)}
.drawer .item h5{margin:0; font-family:var(--serif); font-size:16px; line-height:1.12}
.drawer .item p{margin:4px 0 8px; color:var(--muted); font-size:13px}
.drawer .item .minirow{display:flex; align-items:center; justify-content:space-between; gap:10px}
.qty{
  display:flex; align-items:center; gap:8px;
  border:1px solid var(--line2);
  background: rgba(244,242,238,.55);
  border-radius: 999px;
  padding: 8px 10px;
}
.qty button{border:0; background:transparent; cursor:pointer; font-size:16px; width:26px; height:26px; border-radius:999px}
.qty button:hover{background: rgba(18,19,22,.06)}
.qty span{min-width: 18px; text-align:center; font-size:13px}
.linklike{border:0; background:transparent; cursor:pointer; color:rgba(18,19,22,.72); text-decoration: underline; text-decoration-color: rgba(199,165,107,.35); text-underline-offset:3px}

.drawer footer{border-top:1px solid var(--line2); padding: 14px 16px; background: rgba(244,242,238,.55)}
.total{display:flex; align-items:baseline; justify-content:space-between; gap:10px; margin-bottom: 10px}
.total span{color:var(--muted2); font-size:12px; letter-spacing:.18em; text-transform:uppercase}
.total strong{letter-spacing:.16em; text-transform:uppercase; font-size:14px}

/* Footer */
.site-footer{
  padding: 46px 0 30px;
  border-top:1px solid var(--line2);
  background: radial-gradient(900px 420px at 20% 0%, rgba(199,165,107,.12), transparent 55%),
              linear-gradient(180deg, rgba(244,242,238,.7), rgba(244,242,238,.55));
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap: 18px;
}
.footer-brand{
  border:1px solid var(--line2);
  background: rgba(255,255,255,.8);
  border-radius: var(--radius2);
  padding: 16px;
}
.footer-brand p{margin:10px 0 0; color:var(--muted); max-width: 48ch}
.footer-col h5{
  margin:0 0 10px;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted2);
}
.footer-col a{display:block; padding:8px 0; color:rgba(18,19,22,.78)}
.footer-col a:hover{text-decoration:underline; text-decoration-color: rgba(199,165,107,.35); text-underline-offset:3px}
.footer-bottom{
  margin-top: 18px;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  flex-wrap:wrap;
  color:var(--muted2);
  font-size:12px;
  letter-spacing:.06em;
}

/* Utilities */
.reveal{opacity:0; transform: translateY(10px); transition: opacity .5s var(--ease), transform .5s var(--ease)}
.reveal.is-in{opacity:1; transform:none}

.notice{
  border:1px solid rgba(199,165,107,.35);
  background: rgba(199,165,107,.10);
  border-radius: var(--radius2);
  padding: 14px 16px;
  color: rgba(18,19,22,.86);
}
.notice strong{letter-spacing:.14em; text-transform:uppercase; font-size:12px}

/* Responsive */
@media (max-width: 980px){
  .header-inner{grid-template-columns: auto 1fr auto}
  .brand{min-width: unset}
  .nav{display:none}
  .mobile-toggle{display:inline-flex}

  .mega{display:none}

  .hero-grid{grid-template-columns: 1fr;}
  .panel-strip{grid-template-columns: 1fr}

  .tile{grid-column: span 12}
  .card{grid-column: span 6}

  .editorial{grid-template-columns: 1fr}

  .product-grid2{grid-template-columns: 1fr}

  .footer-grid{grid-template-columns: 1fr 1fr}
}

@media (max-width: 560px){
  .container{width: min(1180px, calc(100vw - 28px))}
  .card{grid-column: span 12}
  .thumbs{grid-template-columns: repeat(3, 1fr)}
  .footer-grid{grid-template-columns: 1fr}
  .search{min-width: 100%}
}

/* Mobile menu sheet */
.sheet{
  position:fixed; inset:0;
  background: rgba(0,0,0,.42);
  opacity:0; pointer-events:none;
  transition: opacity .2s var(--ease);
  z-index:80;
}
.sheet.is-open{opacity:1; pointer-events:auto}
.sheet .panel{
  position:absolute; left:0; top:0; height:100%; width:min(420px, 92vw);
  background:#fff;
  border-right:1px solid var(--line2);
  box-shadow: 20px 0 60px rgba(0,0,0,.18);
  transform: translateX(-102%);
  transition: transform .26s var(--ease);
  padding: 16px;
  display:flex; flex-direction:column;
}
.sheet.is-open .panel{transform: translateX(0)}
.sheet .panel header{display:flex; align-items:center; justify-content:space-between; gap:10px}
.sheet .panel header strong{font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:rgba(18,19,22,.78)}
.sheet .panel header button{border:1px solid var(--line2); background: rgba(244,242,238,.55); border-radius: 14px; padding:10px 12px; cursor:pointer}
.sheet nav{margin-top: 10px}
.sheet nav a{display:flex; justify-content:space-between; gap:10px; padding: 12px 12px; border-radius: 14px; border:1px solid transparent}
.sheet nav a:hover{border-color: var(--line2); background: rgba(244,242,238,.55)}
.sheet .panel footer{margin-top:auto; border-top:1px solid var(--line2); padding-top: 14px; color:var(--muted)}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important}
  .reveal{transition:none}
  .drawer,.sheet{transition:none}
}

/* ===== HERO v2 (editorial) ===== */
.hero.hero-v2{padding: 62px 0 34px;}
.hero.hero-v2 .hero-grid{grid-template-columns: 1.05fr .95fr; gap:34px; align-items:start;}
.hero-links{margin-top:18px; display:grid; gap:10px; max-width: 52ch;}
.link-cta{
  display:block;
  padding: 14px 16px;
  border-radius: 18px;
  border:1px solid var(--line2);
  background: rgba(255,255,255,.7);
  transition: transform .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease);
}
.link-cta:hover{transform: translateY(-1px); background: #fff; border-color: var(--line);}
.link-cta span.hint{display:block; margin-top:6px; color: var(--muted); font-size: 13px;}
.link-cta{font-weight:600;}
.link-cta > span[aria-hidden="true"]{opacity:.7; margin-left:6px; font-weight:700;}

.hero-badges{margin-top:14px; display:flex; gap:10px; flex-wrap:wrap;}

.hero-mini{margin-top:18px; display:grid; grid-template-columns: 1fr 1fr; gap:12px;}
.mini-card{
  border:1px solid var(--line2);
  background: rgba(255,255,255,.66);
  border-radius: 22px;
  padding: 14px 14px;
}
.mini-card strong{display:block; letter-spacing:.14em; text-transform:uppercase; font-size:12px; color: rgba(18,19,22,.78)}
.mini-card p{margin:8px 0 0; color: var(--muted); font-size: 14px; max-width: 48ch;}
.mini-actions{margin-top:10px; display:flex; gap:12px; flex-wrap:wrap;}
.mini-actions a{font-size:13px; text-decoration: underline; text-decoration-color: rgba(199,165,107,.35); text-underline-offset: 3px;}

.hero-visual{margin:0;}
.visual-frame{
  border-radius: var(--radius2);
  overflow:hidden;
  border:1px solid var(--line2);
  background: linear-gradient(180deg, rgba(255,255,255,.7), rgba(255,255,255,.4));
  box-shadow: var(--shadow);
}
.visual-frame img{width:100%; height:auto; display:block;}
.hero-visual figcaption{margin-top:10px; color: rgba(18,19,22,.72); font-size: 13px; max-width: 60ch;}
.cap-kicker{display:inline-block; margin-right:8px; letter-spacing:.16em; text-transform:uppercase; font-size:11px; color: rgba(18,19,22,.78)}

/* Tiles with real imagery */
.tile .media{position:relative; overflow:hidden;}
.tile .media img{width:100%; height:100%; object-fit:cover; display:block; transform: scale(1.02); transition: transform .6s var(--ease);}
.tile:hover .media img{transform: scale(1.06);} 

/* Editorial frame image */
.editorial .frame{position:relative; overflow:hidden;}
.editorial .frame img{width:100%; height:100%; object-fit:cover; display:block;}

@media (max-width: 860px){
  .hero.hero-v2 .hero-grid{grid-template-columns: 1fr;}
  .hero-mini{grid-template-columns: 1fr;}
}

/* ===== HERO v3 (editorial mosaic) ===== */
.hero.hero-v3{padding: 46px 0 28px; background: radial-gradient(1200px 520px at 20% 20%, rgba(199,165,107,.10), transparent 60%)}
.hero-v3 .hero-top{
  display:grid;
  grid-template-columns: 1fr 360px;
  gap: 26px;
  align-items:start;
  margin-bottom: 22px;
}
.hero-v3 .hero-copy .h1{font-size: clamp(42px, 4.8vw, 76px); line-height: .96; margin: 10px 0 12px;}
.hero-v3 .hero-copy .lead{max-width: 58ch;}

.hero-v3 .hero-actions{display:flex; gap:16px; flex-wrap:wrap; margin-top:16px}
.hero-v3 .hero-action{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:10px 0;
  border-bottom:1px solid rgba(18,19,22,.12);
  color: rgba(18,19,22,.88);
  transition: border-color .2s var(--ease), transform .2s var(--ease), color .2s var(--ease);
}
.hero-v3 .hero-action:hover{border-bottom-color: rgba(199,165,107,.55); transform: translateY(-1px)}
.hero-v3 .hero-action.subtle{color: rgba(18,19,22,.68)}

.hero-v3 .hero-notes{display:grid; gap: 12px;}
.hero-v3 .note-card{
  border:1px solid rgba(18,19,22,.10);
  background: rgba(255,255,255,.52);
  border-radius: 18px;
  padding: 14px 14px;
  box-shadow: var(--shadow1);
}
.hero-v3 .note-card small{display:block; font-size:11px; letter-spacing:.20em; text-transform:uppercase; color: rgba(18,19,22,.60)}
.hero-v3 .note-card strong{display:block; margin-top:6px; font-family: var(--serif); letter-spacing:.04em}
.hero-v3 .note-card p{margin:8px 0 10px; color: rgba(18,19,22,.70)}
.hero-v3 .note-links{display:flex; gap:14px; flex-wrap:wrap}
.hero-v3 .note-links a{font-size:12px; text-decoration: underline; text-decoration-color: rgba(199,165,107,.30); text-underline-offset: 3px}

.hero-v3 .hero-gallery{
  display:grid;
  grid-template-columns: 1.35fr .85fr .85fr;
  gap: 18px;
}
.hero-v3 .hero-shot{
  position:relative;
  border-radius: 22px;
  overflow:hidden;
  border: 1px solid rgba(18,19,22,.10);
  background: rgba(255,255,255,.50);
  box-shadow: var(--shadow2);
  min-height: 280px;
}
.hero-v3 .hero-shot.large{min-height: 360px}
.hero-v3 .hero-shot img{
  width:100%; height:100%; display:block; object-fit:cover;
  transform: scale(1.02);
  transition: transform .6s var(--ease), filter .6s var(--ease);
  filter: saturate(102%) contrast(102%);
}
.hero-v3 .hero-shot:hover img{transform: scale(1.06)}
.hero-v3 .hero-shot .label{
  position:absolute; left:14px; bottom:14px;
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 12px;
  border-radius: 999px;
  background: rgba(251,250,247,.84);
  border: 1px solid rgba(18,19,22,.10);
  color: rgba(18,19,22,.90);
  letter-spacing:.10em;
  font-size: 12px;
  box-shadow: var(--shadow1);
}
.hero-v3 .hero-shot .label .tag{
  font-size: 10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color: rgba(18,19,22,.58);
}

@media (max-width: 980px){
  .hero-v3 .hero-top{grid-template-columns: 1fr;}
  .hero-v3 .hero-gallery{grid-template-columns: 1fr;}
  .hero-v3 .hero-shot, .hero-v3 .hero-shot.large{min-height: 260px}
  .topbar-right{display:none}
}

/* ===== HERO v4 (imagem cheia, editorial) ===== */
.hero-immersive{
  position: relative;
  min-height: 100vh;
  display: grid;
  align-items: end;
  overflow: hidden;
  background: lch(0% 0 0);
}
.hero-immersive .hero-media{
  position: absolute;
  inset: 0;
  background-image: url('assets/img/hero/hero-immersive.jpg');
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
  filter: saturate(104%) contrast(104%);
}
.hero-immersive .hero-overlay{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(900px 520px at 50% 70%, rgba(10,12,14,.10), rgba(10,12,14,.56)),
    linear-gradient(to bottom, rgba(10,12,14,.18), rgba(10,12,14,.62));
}
.hero-immersive .hero-inner{
  position: relative;
  padding-top: 160px; /* espaço para header fixo */
  padding-bottom: 84px;
}
.hero-caption{
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
  color: rgba(255,255,255,.94);
}
.hero-caption .eyebrow{
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.78);
  margin-bottom: 16px;
}
.hero-title{
  font-family: var(--serif);
  font-size: clamp(42px, 5vw, 74px);
  line-height: 1.02;
  letter-spacing: -0.01em;
  text-shadow: 0 20px 60px rgba(0,0,0,.35);
}
.hero-link{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 22px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(10,12,14,.14);
  color: rgba(255,255,255,.94);
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.hero-link:hover{ background: rgba(255,255,255,.12) }

.hero-support{ padding: 26px 0 10px; background: var(--bg) }
.support-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: -44px; /* sobe para “encostar” no hero */
}
.support-card{
  background: rgba(251,250,247,.96);
  border: 1px solid rgba(18,19,22,.10);
  border-radius: 18px;
  padding: 18px;
  box-shadow: var(--shadow1);
}
.support-card small{ display:block; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color: rgba(18,19,22,.62) }
.support-card h2{ font-family: var(--serif); margin: 10px 0 10px; font-size: 22px; letter-spacing: .01em }
.support-card p{ margin:0; color: rgba(18,19,22,.70) }
.support-links{ display:flex; gap:14px; flex-wrap:wrap; margin-top: 12px }
.support-links a{ font-size:12px; letter-spacing:.12em; text-transform:uppercase; color: rgba(18,19,22,.84); text-decoration: underline; text-decoration-color: rgba(199,165,107,.28); text-underline-offset: 3px }
.support-links a:hover{ color: rgba(18,19,22,.96) }

@media (max-width: 980px){
  .hero-immersive .hero-inner{padding-top: 150px; padding-bottom: 72px;}
  .support-grid{grid-template-columns: 1fr; margin-top: -18px;}
}

/* Page hero media (Journal) */
.page-hero-media{margin-top:18px; border-radius: var(--radius2); overflow:hidden; border:1px solid var(--line2); background: rgba(255,255,255,.55); box-shadow: var(--shadow);}
.page-hero-media img{width:100%; height:auto; display:block;}
