/* Aroma & Touch — storefront. Base: design system (Lenvie DNA + luxe). */
:root{
  --font-base:"Jost","Inter",sans-serif;
  --font-luxe:"Playfair Display",serif;
  --font-editorial:"Cormorant Garamond",serif;
  --musgo:#4e513b; --ambar:#b9956b; --forest:#2f3e34; --sage:#e8ebe1;
  --ink:#1d201c; --gray:#707070; --line:#e4e2dc; --bg:#fff; --soft:#fafaf8;
  --radius:14px; --radius-lg:22px; --transition:all .4s ease;
  --ease:cubic-bezier(.22,.61,.36,1); --wrap:1240px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:62.5%;scroll-behavior:smooth}
body{font-family:var(--font-base);font-size:1.6rem;line-height:1.6;color:var(--gray);background:var(--bg);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-luxe);color:var(--ink);font-weight:500;line-height:1.1;letter-spacing:.01em}
::selection{background:var(--musgo);color:#fff}
.eyebrow{font-family:var(--font-base);font-size:1.2rem;letter-spacing:.36em;text-transform:uppercase;color:var(--musgo);font-weight:500}
.muted{color:var(--gray)}
em{font-family:var(--font-editorial);font-style:italic;color:var(--musgo)}

/* ---------- Botões ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.8rem;cursor:pointer;border:none;
  font-family:var(--font-base);font-size:1.3rem;letter-spacing:.16em;text-transform:uppercase;
  padding:1.4rem 2.8rem;border-radius:50px;transition:var(--transition);position:relative;overflow:hidden}
.btn-sm{padding:1rem 1.8rem;font-size:1.15rem}
.btn-solid{background:var(--ink);color:#fff}
.btn-solid::before{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(120deg,var(--musgo),var(--ambar));opacity:0;transition:var(--transition)}
.btn-solid:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(78,81,59,.3)}
.btn-solid:hover::before{opacity:1}
.btn-solid > *{position:relative;z-index:1}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-ghost span{position:relative;z-index:1;transition:var(--transition)}
.btn-ghost::after{content:"";position:absolute;inset:0;background:var(--musgo);transform:translateY(101%);transition:var(--transition)}
.btn-ghost:hover{color:#fff;border-color:var(--musgo)}
.btn-ghost:hover::after{transform:translateY(0)}
.link-arrow{display:inline-flex;align-items:center;font-size:1.3rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);font-weight:500}
.link-arrow i{width:8px;height:8px;border-right:2px solid var(--musgo);border-bottom:2px solid var(--musgo);transform:rotate(-45deg);margin-left:10px;transition:var(--transition)}
.link-arrow:hover i{margin-left:18px}

/* ---------- Header ---------- */
.hdr{position:sticky;top:0;z-index:90;background:rgba(255,255,255,.82);backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid transparent;transition:var(--transition)}
.hdr.scrolled{background:rgba(255,255,255,.94);border-bottom-color:var(--line)}
.hdr-bar{max-width:var(--wrap);margin:0 auto;display:flex;align-items:center;gap:2rem;padding:1.6rem 3vw}
.hdr-brand{font-family:var(--font-luxe);font-size:2rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);white-space:nowrap}
.hdr-brand b{color:var(--musgo);font-weight:500}
.hdr-nav{display:flex;gap:2.4rem;margin-left:2rem;flex:1}
.hdr-nav a{font-size:1.3rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);position:relative;padding:.4rem 0}
.hdr-nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--musgo);transition:var(--transition)}
.hdr-nav a:hover::after{width:100%}
.hdr-actions{display:flex;align-items:center;gap:1.4rem;margin-left:auto}
.hdr-ico{position:relative;background:none;border:none;cursor:pointer;color:var(--ink);display:grid;place-items:center}
.hdr-ico svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.hdr-cart-count{position:absolute;top:-6px;right:-8px;background:var(--ambar);color:#3a2c19;font-size:1rem;font-weight:600;min-width:17px;height:17px;border-radius:10px;display:grid;place-items:center;padding:0 4px}
.hdr-burger{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer}
.hdr-burger i{width:22px;height:2px;background:var(--ink);display:block}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:8rem 3vw;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,#fff,var(--soft) 60%,#fff)}
.hero-bg::before,.hero-bg::after{content:"";position:absolute;width:55vw;height:55vw;border-radius:50%;filter:blur(90px);opacity:.5}
.hero-bg::before{background:radial-gradient(circle,var(--sage),transparent 65%);top:-12%;left:-8%;animation:drift 18s var(--ease) infinite alternate}
.hero-bg::after{background:radial-gradient(circle,#e7d8c4,transparent 65%);bottom:-16%;right:-10%;animation:drift2 22s var(--ease) infinite alternate}
.hero-inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:2.2rem}
.hero-inner .eyebrow{opacity:0;animation:fadeUp 1s var(--ease) .2s forwards}
.hero-title{display:flex;flex-direction:column;align-items:center;line-height:.9}
.luxe{font-family:var(--font-luxe);font-weight:500;text-transform:uppercase;font-size:clamp(5rem,13vw,15rem);letter-spacing:.05em;
  background:linear-gradient(100deg,#b78f54,#f3e6c7 22%,#cdb285 45%,#f0dca8 68%,#b9956b);background-size:220% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;
  animation:shimmerText 9s linear infinite,fadeUp 1.2s var(--ease) .4s both}
.touch{font-family:var(--font-base);font-weight:400;text-transform:uppercase;font-size:clamp(3.4rem,9vw,9rem);letter-spacing:.04em;color:var(--musgo);margin-top:.3rem;
  animation:fadeUp 1.2s var(--ease) .7s both}
.hero-sub{font-family:var(--font-editorial);font-style:italic;font-size:clamp(1.7rem,2.2vw,2.4rem);color:var(--gray);max-width:46ch;opacity:0;animation:fadeUp 1s var(--ease) 1s forwards}
.hero-cta{display:flex;gap:1.4rem;flex-wrap:wrap;justify-content:center;opacity:0;animation:fadeUp 1s var(--ease) 1.2s forwards}
.hero-scroll{position:absolute;bottom:2.4rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.8rem;font-size:1.1rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gray)}
.hero-scroll i{width:1px;height:40px;background:linear-gradient(var(--musgo),transparent);animation:scrollLine 2.2s ease-in-out infinite}

/* ---------- Strip ---------- */
.strip{display:flex;flex-wrap:wrap;justify-content:center;gap:2.5rem 4rem;padding:2.4rem 3vw;background:var(--forest);color:rgba(255,255,255,.85);font-size:1.3rem;letter-spacing:.06em}
.strip-item b{color:#fff;font-weight:500}

/* ---------- Sections ---------- */
.section{max-width:var(--wrap);margin:0 auto;padding:7rem 3vw}
.section-alt{max-width:none;background:var(--soft)}
.section-head{text-align:center;margin-bottom:4rem;display:flex;flex-direction:column;gap:1rem;align-items:center}
.section-head h1,.section-head h2{font-size:clamp(2.8rem,4vw,4.2rem)}
.page-head{max-width:var(--wrap);margin:0 auto;padding:5rem 3vw 0}

/* ---------- Product grid + cards ---------- */
.grid-products{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:2.4rem}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:transform .5s var(--ease),box-shadow .5s var(--ease);display:flex;flex-direction:column}
.card-media{position:relative;aspect-ratio:4/5;overflow:hidden;display:block;background:var(--soft)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.card-tag{position:absolute;top:1.2rem;left:1.2rem;z-index:2;font-size:1rem;letter-spacing:.14em;text-transform:uppercase;background:rgba(255,255,255,.92);color:var(--musgo);padding:.4rem 1rem;border-radius:40px}
.card-off{position:absolute;top:1.2rem;right:1.2rem;z-index:2;font-size:1.1rem;font-weight:600;background:var(--ambar);color:#3a2c19;padding:.4rem .9rem;border-radius:40px}
.card-body{padding:1.6rem 1.6rem 1.8rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.card-cat{font-size:1rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ambar)}
.card-name{font-family:var(--font-base);font-size:1.5rem;font-weight:500;color:var(--ink);letter-spacing:0;line-height:1.3}
.card-price{display:flex;align-items:baseline;gap:.8rem;margin-top:auto}
.card-price s{color:var(--gray);font-size:1.3rem}
.card-price strong{color:var(--musgo);font-size:1.7rem;font-weight:600}
.card-add{margin-top:1rem;width:100%}
.card:hover{transform:translateY(-8px);box-shadow:0 28px 56px rgba(47,62,52,.16)}
.card:hover .card-media img{transform:scale(1.07)}

/* ---------- Band (história) ---------- */
.band{max-width:var(--wrap);margin:0 auto;padding:7rem 3vw;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.band-text{display:flex;flex-direction:column;gap:1.6rem;align-items:flex-start}
.band-text h2{font-size:clamp(2.8rem,4vw,4rem)}
.band-media{aspect-ratio:4/3;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--sage),#e7d8c4);position:relative;overflow:hidden}
.band-media::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 30%,rgba(185,149,107,.4),transparent 60%)}

/* ---------- PDP ---------- */
.pdp{max-width:var(--wrap);margin:0 auto;padding:3rem 3vw 6rem}
.crumbs{font-size:1.2rem;color:var(--gray);margin-bottom:2.4rem;letter-spacing:.04em}
.crumbs a:hover{color:var(--musgo)}
.pdp-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:4rem}
.pdp-gallery img{width:100%;border-radius:var(--radius-lg);background:var(--soft);object-fit:cover}
.pdp-thumbs{display:flex;gap:1rem;margin-top:1rem}
.pdp-thumbs img{width:74px;height:74px;border-radius:10px;cursor:pointer;border:1px solid var(--line)}
.pdp-info{display:flex;flex-direction:column;gap:1.4rem}
.pdp-info h1{font-size:clamp(2.6rem,3.5vw,3.6rem)}
.pdp-price{display:flex;align-items:baseline;gap:1rem}
.pdp-price s{color:var(--gray)}
.pdp-price strong{font-size:2.8rem;color:var(--musgo);font-weight:600}
.pdp-short{font-family:var(--font-editorial);font-style:italic;font-size:1.9rem;color:var(--gray)}
.pdp-buy{display:flex;gap:1.2rem;align-items:center;margin-top:1rem;flex-wrap:wrap}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:50px;overflow:hidden}
.qty button{width:42px;height:46px;background:none;border:none;font-size:1.8rem;cursor:pointer;color:var(--ink)}
.qty input{width:46px;text-align:center;border:none;font-size:1.6rem;font-family:var(--font-base)}
.pdp-out{color:#a23b3b}
.pdp-desc{margin-top:1.6rem;border-top:1px solid var(--line);padding-top:1.6rem}
.pdp-desc h4{font-family:var(--font-base);text-transform:uppercase;letter-spacing:.16em;font-size:1.3rem;margin-bottom:.8rem;color:var(--ink)}

/* ---------- Footer ---------- */
.ft{background:var(--ink);color:rgba(255,255,255,.72);margin-top:4rem}
.ft-grid{max-width:var(--wrap);margin:0 auto;padding:6rem 3vw 3rem;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:3rem}
.ft-mark{font-family:var(--font-luxe);font-size:2.4rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:1.2rem}
.ft-col h4{font-family:var(--font-base);color:#fff;font-size:1.3rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1.4rem;font-weight:500}
.ft-col a{display:block;padding:.5rem 0;font-size:1.4rem;transition:var(--transition)}
.ft-col a:hover{color:var(--ambar)}
.ft-news{display:flex;gap:.8rem;margin-top:1rem}
.ft-news input{flex:1;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:40px;padding:1rem 1.4rem;color:#fff;font-family:var(--font-base)}
.ft-news button{background:var(--ambar);color:#3a2c19;border:none;border-radius:40px;padding:0 1.8rem;cursor:pointer;font-weight:500}
.ft-base{border-top:1px solid rgba(255,255,255,.12);padding:2rem 3vw;text-align:center;font-size:1.2rem;letter-spacing:.08em}

/* ---------- Cart drawer ---------- */
.cart-drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,92vw);background:#fff;z-index:120;transform:translateX(100%);transition:transform .45s var(--ease);display:flex;flex-direction:column;box-shadow:-20px 0 60px rgba(0,0,0,.12)}
body.cart-open .cart-drawer{transform:none}
.cart-head{display:flex;justify-content:space-between;align-items:center;padding:2rem;border-bottom:1px solid var(--line);font-family:var(--font-luxe);font-size:1.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink)}
.cart-head button{background:none;border:none;font-size:2.6rem;cursor:pointer;color:var(--gray);line-height:1}
.cart-body{flex:1;overflow-y:auto;padding:2rem}
.cart-empty{text-align:center;color:var(--gray);margin-top:3rem}
.overlay{position:fixed;inset:0;background:rgba(47,62,52,.45);backdrop-filter:blur(3px);z-index:110;opacity:0;pointer-events:none;transition:var(--transition)}
body.cart-open .overlay,body.nav-open .overlay{opacity:1;pointer-events:auto}

/* ---------- Error ---------- */
.errpage{min-height:70vh;display:grid;place-items:center;text-align:center;padding:4rem 3vw}
.errpage-inner{display:flex;flex-direction:column;align-items:center;gap:1.6rem}
.errpage .luxe{font-size:clamp(8rem,18vw,16rem)}

/* ---------- Busca no header ---------- */
.hdr-search{max-height:0;overflow:hidden;transition:max-height .4s var(--ease);border-top:1px solid transparent}
body.search-open .hdr-search{max-height:90px;border-top-color:var(--line)}
.hdr-search-form{max-width:var(--wrap);margin:0 auto;display:flex;align-items:center;gap:1rem;padding:1.4rem 3vw}
.hdr-search-form svg{stroke:var(--gray);flex:none}
.hdr-search-form input{flex:1;border:none;background:none;font-family:var(--font-base);font-size:1.6rem;color:var(--ink);padding:.4rem 0}
.hdr-search-form input:focus{outline:none}
.hdr-search-form button{background:var(--ink);color:#fff;border:none;border-radius:50px;padding:1rem 2rem;font-size:1.2rem;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:var(--transition)}
.hdr-search-form button:hover{background:var(--musgo)}

/* ---------- Listing (catálogo/categoria/busca) ---------- */
.listing{max-width:var(--wrap);margin:0 auto;padding:2rem 3vw 6rem;display:grid;grid-template-columns:248px 1fr;gap:3rem;align-items:start}
.filters-toggle{display:none;align-items:center;gap:.8rem;background:#fff;border:1px solid var(--line);border-radius:50px;padding:1rem 1.8rem;font-size:1.3rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;color:var(--ink);margin-bottom:1.6rem}
.filters{position:sticky;top:96px}
.filter-head{display:none;justify-content:space-between;align-items:center;font-family:var(--font-luxe);font-size:1.6rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);margin-bottom:2rem}
.filter-close{background:none;border:none;font-size:2.4rem;cursor:pointer;color:var(--gray)}
.filter-group{padding:1.8rem 0;border-bottom:1px solid var(--line)}
.filter-group:first-of-type{padding-top:0}
.filter-group h4{font-family:var(--font-base);font-size:1.2rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);margin-bottom:1.2rem;font-weight:500}
.filter-cats{list-style:none;display:flex;flex-direction:column;gap:.3rem}
.filter-cats a{display:flex;justify-content:space-between;align-items:center;padding:.7rem 1rem;border-radius:10px;font-size:1.4rem;color:var(--gray);transition:var(--transition)}
.filter-cats a span{font-size:1.1rem;color:var(--ambar)}
.filter-cats a:hover{background:var(--soft);color:var(--ink)}
.filter-cats a.on{background:var(--sage);color:var(--forest);font-weight:500}
.filter-price{display:flex;align-items:center;gap:.8rem}
.filter-price input{width:100%;border:1px solid var(--line);border-radius:10px;padding:1rem;font-family:var(--font-base);font-size:1.4rem;color:var(--ink)}
.filter-price input:focus{outline:none;border-color:var(--musgo)}
.filter-check{display:flex;align-items:center;gap:.8rem;padding:.6rem 0;font-size:1.4rem;cursor:pointer;color:var(--gray)}
.filter-check input{width:17px;height:17px;accent-color:var(--musgo)}
.filter-form .btn{margin-top:1.8rem}
.filter-clear{display:block;text-align:center;margin-top:1rem;font-size:1.2rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray)}
.filter-clear:hover{color:var(--musgo)}

.listing-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.2rem;gap:1rem;flex-wrap:wrap}
.listing-count{font-size:1.3rem;color:var(--gray);letter-spacing:.04em}
.sort{display:flex;align-items:center;gap:.8rem;font-size:1.2rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray)}
.sort select{border:1px solid var(--line);border-radius:50px;padding:.9rem 2.4rem .9rem 1.4rem;font-family:var(--font-base);font-size:1.3rem;color:var(--ink);background:#fff;cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%234e513b' stroke-width='2'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1.2rem center}
.sort select:focus{outline:none;border-color:var(--musgo)}

.empty-state{text-align:center;padding:5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1.8rem;color:var(--gray)}

.pagination{display:flex;justify-content:center;align-items:center;gap:.6rem;margin-top:4rem}
.pg{min-width:42px;height:42px;display:grid;place-items:center;border:1px solid var(--line);border-radius:50px;padding:0 1.2rem;font-size:1.4rem;color:var(--ink);transition:var(--transition)}
.pg:hover{border-color:var(--musgo);color:var(--musgo)}
.pg.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.pg-dots{color:var(--gray);padding:0 .4rem}

body.filters-open .overlay{opacity:1;pointer-events:auto}

@media(max-width:860px){
  .listing{grid-template-columns:1fr;gap:0}
  .filters-toggle{display:inline-flex}
  .filters{position:fixed;top:0;left:0;bottom:0;width:84vw;max-width:340px;background:#fff;z-index:120;padding:2.4rem;overflow-y:auto;transform:translateX(-100%);transition:transform .4s var(--ease)}
  body.filters-open .filters{transform:none}
  .filter-head{display:flex}
}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.visible{opacity:1;transform:none}

/* ---------- Keyframes ---------- */
@keyframes shimmerText{0%{background-position:0 50%}100%{background-position:220% 50%}}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@keyframes drift{to{transform:translate(7vw,5vh) scale(1.15)}}
@keyframes drift2{to{transform:translate(-6vw,-4vh) scale(1)}}
@keyframes scrollLine{0%,100%{transform:scaleY(.3);transform-origin:top}50%{transform:scaleY(1)}}

/* ---------- Responsivo ---------- */
@media(max-width:900px){
  .pdp-grid,.band{grid-template-columns:1fr;gap:2.4rem}
  .ft-grid{grid-template-columns:1fr 1fr}
  .hdr-nav{position:fixed;top:0;left:0;bottom:0;width:80vw;max-width:320px;background:#fff;flex-direction:column;gap:1.4rem;padding:7rem 2.4rem;transform:translateX(-100%);transition:transform .4s var(--ease);z-index:120;margin:0}
  body.nav-open .hdr-nav{transform:none}
  .hdr-burger{display:flex}
  .hdr-nav{flex:none}
}
@media(max-width:560px){
  .ft-grid{grid-template-columns:1fr}
  .strip{gap:1.4rem 2.4rem;font-size:1.2rem}
}
/* ---------- Drawer: itens ---------- */
.ci-list{display:flex;flex-direction:column;gap:1.4rem}
.ci{display:grid;grid-template-columns:56px 1fr auto;gap:1.2rem;align-items:start;padding-bottom:1.4rem;border-bottom:1px solid var(--line)}
.ci img{border-radius:8px;object-fit:cover}
.ci-info strong{display:block;font-family:var(--font-base);font-size:1.4rem;color:var(--ink);font-weight:500;line-height:1.3}
.ci-q{display:flex;align-items:center;gap:.8rem;margin-top:.6rem}
.ci-q button{width:26px;height:26px;border:1px solid var(--line);background:#fff;border-radius:50%;cursor:pointer;font-size:1.5rem;line-height:1;color:var(--ink)}
.ci-q b{min-width:20px;text-align:center;font-weight:500}
.ci-q span{margin-left:auto;color:var(--musgo);font-weight:500}
.ci-rm{background:none;border:none;font-size:2rem;color:var(--gray);cursor:pointer;line-height:1}
.ci-rm:hover{color:var(--ink)}
.ci-foot{margin-top:auto;padding-top:1.6rem;border-top:1px solid var(--line)}
.ci-sub{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.4rem;font-size:1.5rem}
.ci-sub strong{font-size:1.9rem;color:var(--musgo)}
.cart-body{display:flex;flex-direction:column}
.card-add.is-loading{opacity:.6;pointer-events:none}

/* ---------- Página do carrinho ---------- */
.cart-page{max-width:var(--wrap);margin:0 auto;padding:4rem 3vw 6rem}
.cart-layout{display:grid;grid-template-columns:1fr 380px;gap:3.4rem;align-items:start}
.freebar{background:var(--sage);border-radius:var(--radius);padding:1.4rem 1.8rem;margin-bottom:2rem}
.freebar[data-free="1"]{background:#e7f0e2}
.freebar-txt{font-size:1.4rem;color:var(--forest);margin-bottom:.9rem}
.freebar-track{height:6px;background:rgba(47,62,52,.14);border-radius:6px;overflow:hidden}
.freebar-track i{display:block;height:100%;background:linear-gradient(90deg,var(--musgo),var(--ambar));transition:width .5s var(--ease)}
.cart-item{display:grid;grid-template-columns:90px 1fr auto auto auto;gap:1.6rem;align-items:center;padding:1.8rem 0;border-bottom:1px solid var(--line)}
.cart-item-img img{border-radius:10px;object-fit:cover}
.cart-item-name{font-family:var(--font-base);font-size:1.5rem;color:var(--ink);font-weight:500;display:block}
.cart-item-unit{font-size:1.3rem;color:var(--gray)}
.cart-item-line{font-size:1.6rem;color:var(--musgo);min-width:90px;text-align:right}
.cart-item-rm{background:none;border:none;font-size:2.2rem;color:var(--gray);cursor:pointer;line-height:1}
.cart-item-rm:hover{color:var(--ink)}
.cart-item .qty input.cart-item-qty{width:42px}

.cart-summary{background:var(--soft);border:1px solid var(--line);border-radius:var(--radius-lg);padding:2.6rem;position:sticky;top:96px}
.cart-summary h3{font-size:2rem;margin-bottom:1.8rem}
.cart-coupon,.cart-cep{display:flex;gap:.8rem;margin-bottom:.6rem}
.cart-coupon input,.cart-cep input{flex:1;border:1px solid var(--line);border-radius:50px;padding:1.1rem 1.6rem;font-family:var(--font-base);font-size:1.4rem;color:var(--ink);background:#fff}
.cart-coupon input:focus,.cart-cep input:focus{outline:none;border-color:var(--musgo)}
.cart-msg{font-size:1.25rem;min-height:1.6rem;margin:.4rem 0 0}
.cart-msg.ok{color:#3a6b3a}.cart-msg.err{color:#a23b3b}
.cart-ship{margin:2rem 0;padding-top:2rem;border-top:1px solid var(--line)}
.cart-ship>label{display:block;font-size:1.2rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin-bottom:1rem}
.ship-options{margin-top:1rem;display:flex;flex-direction:column;gap:.8rem}
.ship-loc{font-size:1.3rem;color:var(--gray);margin-bottom:.4rem}
.ship-opt{display:flex;align-items:center;gap:1rem;border:1px solid var(--line);border-radius:12px;padding:1.1rem 1.4rem;cursor:pointer;background:#fff;transition:var(--transition)}
.ship-opt:hover{border-color:var(--musgo)}
.ship-opt input{accent-color:var(--musgo)}
.ship-name{display:flex;flex-direction:column;font-size:1.4rem;color:var(--ink)}
.ship-name small{color:var(--gray);font-size:1.15rem}
.ship-price{margin-left:auto;color:var(--musgo);font-weight:500}
.cart-totals{margin:2rem 0;display:flex;flex-direction:column;gap:1rem}
.cart-totals>div{display:flex;justify-content:space-between;align-items:baseline;font-size:1.5rem}
.cart-totals dt{color:var(--gray)}.cart-totals dd{color:var(--ink)}
.cart-totals .t-discount dd{color:#3a6b3a}
.cart-totals .t-total{border-top:1px solid var(--line);padding-top:1.4rem;margin-top:.4rem}
.cart-totals .t-total dt{color:var(--ink);font-family:var(--font-luxe);font-size:1.8rem;text-transform:uppercase;letter-spacing:.06em}
.cart-totals .t-total dd{font-size:2.2rem;color:var(--musgo);font-weight:600}
.cart-continue{display:block;text-align:center;margin-top:1.4rem;font-size:1.3rem;color:var(--gray)}
.cart-continue:hover{color:var(--musgo)}
@media(max-width:860px){.cart-layout{grid-template-columns:1fr;gap:2.4rem}.cart-summary{position:static}}

/* ---------- Flash ---------- */
.flash-stack{display:flex;flex-direction:column;gap:.8rem;margin-bottom:1.8rem}
.flash{padding:1.2rem 1.6rem;border-radius:12px;font-size:1.4rem}
.flash-ok{background:#e7f0e2;color:#3a6b3a}
.flash-err{background:#f6e3e0;color:#a23b3b}

/* ---------- Auth ---------- */
.auth{min-height:74vh;display:grid;place-items:center;padding:5rem 3vw;background:linear-gradient(180deg,#fff,var(--soft))}
.auth-card{width:100%;max-width:440px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:3.4rem;box-shadow:0 30px 70px rgba(47,62,52,.08)}
.auth-brand{font-family:var(--font-luxe);font-size:2.2rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);text-align:center;margin-bottom:2.4rem}
.auth-brand b{color:var(--musgo)}
.auth-tabs{display:flex;gap:.6rem;background:var(--soft);border-radius:50px;padding:.4rem;margin-bottom:2.4rem}
.auth-tabs a{flex:1;text-align:center;padding:1rem;border-radius:50px;font-size:1.3rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gray);transition:var(--transition)}
.auth-tabs a.on{background:#fff;color:var(--ink);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.auth-form{display:flex;flex-direction:column;gap:1.6rem}
.auth-form label,.acc-form label{display:flex;flex-direction:column;gap:.6rem;font-size:1.3rem;color:var(--ink);font-weight:500}
.auth-form input,.acc-form input{border:1px solid var(--line);border-radius:12px;padding:1.3rem 1.5rem;font-family:var(--font-base);font-size:1.5rem;color:var(--ink);font-weight:400}
.auth-form input:focus,.acc-form input:focus{outline:none;border-color:var(--musgo)}
.auth-form small,.acc-form small{color:var(--gray);font-weight:400}
.auth-form button{margin-top:.6rem}
.auth-alt{text-align:center;font-size:1.3rem;color:var(--gray)}
.auth-alt a{color:var(--musgo);font-weight:500}

/* ---------- Área da conta ---------- */
.acc-layout{max-width:var(--wrap);margin:0 auto;padding:4rem 3vw 6rem;display:grid;grid-template-columns:260px 1fr;gap:3.4rem;align-items:start}
.acc-nav{position:sticky;top:96px;background:var(--soft);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.acc-hi{padding:2.2rem;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:.3rem}
.acc-hi strong{font-size:1.6rem;color:var(--ink);font-family:var(--font-base);font-weight:500}
.acc-hi small{color:var(--gray);font-size:1.25rem}
.acc-nav nav{display:flex;flex-direction:column;padding:1rem}
.acc-nav nav a{padding:1.1rem 1.4rem;border-radius:10px;font-size:1.4rem;color:var(--gray);transition:var(--transition)}
.acc-nav nav a:hover{background:#fff;color:var(--ink)}
.acc-nav nav a.on{background:var(--sage);color:var(--forest);font-weight:500}
.acc-out{margin-top:.6rem;border-top:1px solid var(--line);color:#a23b3b!important;border-radius:0!important}
.acc-main h1{font-size:clamp(2.6rem,3.6vw,3.6rem);margin-bottom:.8rem}
.acc-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:2.4rem}
.acc-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem;display:flex;flex-direction:column;gap:.6rem;align-items:flex-start;transition:var(--transition)}
.acc-card:hover{border-color:var(--musgo);transform:translateY(-4px)}
.acc-card-n{font-family:var(--font-luxe);font-size:3rem;color:var(--musgo);line-height:1}
.acc-card-i{font-size:2.4rem}
.acc-card span:last-child{font-size:1.3rem;color:var(--gray);text-transform:uppercase;letter-spacing:.1em}
.acc-empty{text-align:center;padding:4rem 2rem;background:var(--soft);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;gap:1.6rem;color:var(--gray)}
.acc-back{font-size:1.3rem;color:var(--gray);display:inline-block;margin-bottom:1.4rem}
.acc-back:hover{color:var(--musgo)}

/* listas de pedidos */
.order-list{display:flex;flex-direction:column;gap:1rem}
.order-row{display:grid;grid-template-columns:1fr auto auto;gap:1.6rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem 2rem;transition:var(--transition)}
.order-row:hover{border-color:var(--musgo);transform:translateX(3px)}
.order-row small{display:block;color:var(--gray);font-size:1.2rem}
.order-status{font-size:1.15rem;letter-spacing:.06em;text-transform:uppercase;padding:.4rem 1rem;border-radius:40px;background:var(--gray-1);color:var(--gray-5)}
.order-status.s-paid,.order-status.s-delivered{background:#e7f0e2;color:#3a6b3a}
.order-status.s-pending{background:#faf0dd;color:#8a6a2b}
.order-status.s-canceled,.order-status.s-refunded{background:#f6e3e0;color:#a23b3b}
.order-head{display:flex;align-items:center;gap:1.4rem;margin-bottom:.4rem}
.order-items{margin:2rem 0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.order-item{display:grid;grid-template-columns:auto 1fr auto;gap:1.4rem;padding:1.4rem 1.8rem;border-bottom:1px solid var(--line)}
.order-item:last-child{border-bottom:none}
.oi-name{color:var(--ink)}
.order-totals{max-width:360px;margin-left:auto;display:flex;flex-direction:column;gap:.8rem}
.order-totals>div{display:flex;justify-content:space-between;font-size:1.5rem}
.order-totals dt{color:var(--gray)}.order-totals dd{color:var(--ink)}
.order-totals .t-total{border-top:1px solid var(--line);padding-top:1rem;font-weight:500}
.order-totals .t-total dd{color:var(--musgo);font-size:1.9rem}

/* formulários da conta */
.acc-form{display:flex;flex-direction:column;gap:1.6rem;max-width:560px}
.acc-form input[disabled]{background:var(--soft);color:var(--gray)}
.acc-form-row{display:flex;gap:1.4rem}
.acc-form-row label{flex:1}
.acc-check{flex-direction:row!important;align-items:center;gap:.8rem!important;font-weight:400!important}
.acc-check input{width:17px;height:17px;accent-color:var(--musgo)}
.addr-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.6rem;margin-bottom:1rem}
.addr-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem}
.addr-card strong{display:block;margin-bottom:.6rem;color:var(--ink)}
.addr-card p{font-size:1.35rem;color:var(--gray)}
.addr-tag{position:absolute;top:1.4rem;right:1.4rem;font-size:1.05rem;letter-spacing:.1em;text-transform:uppercase;background:var(--sage);color:var(--forest);padding:.3rem .8rem;border-radius:40px}
.addr-rm{margin-top:1.2rem;background:none;border:none;color:#a23b3b;font-size:1.25rem;cursor:pointer;padding:0}
.addr-rm:hover{text-decoration:underline}

@media(max-width:860px){.acc-layout{grid-template-columns:1fr;gap:2rem}.acc-nav{position:static}.acc-cards{grid-template-columns:1fr}.acc-form-row{flex-direction:column;gap:1.6rem}}

/* ---------- Checkout ---------- */
.checkout{max-width:var(--wrap);margin:0 auto;padding:4rem 3vw 6rem}
.ck-layout{display:grid;grid-template-columns:1fr 400px;gap:3.4rem;align-items:start}
.ck-login-hint{background:var(--sage);color:var(--forest);padding:1.2rem 1.6rem;border-radius:12px;font-size:1.35rem;margin-bottom:2rem}
.ck-login-hint a{color:var(--musgo);font-weight:500}
.ck-block{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:2.6rem;margin-bottom:2rem}
.ck-block h3{font-size:1.8rem;margin-bottom:1.8rem}
.ck-block h4{font-family:var(--font-base);text-transform:uppercase;letter-spacing:.14em;font-size:1.2rem;color:var(--ink);margin:1.8rem 0 1rem}
.ck-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.ck-grid label,.ck-saved{display:flex;flex-direction:column;gap:.6rem;font-size:1.25rem;color:var(--ink);font-weight:500}
.ck-grid .ck-street{grid-column:1 / -1}
.ck-grid input,.ck-saved select{border:1px solid var(--line);border-radius:10px;padding:1.2rem 1.4rem;font-family:var(--font-base);font-size:1.5rem;color:var(--ink);font-weight:400}
.ck-grid input:focus,.ck-saved select:focus{outline:none;border-color:var(--musgo)}
.ck-saved{margin-bottom:1.6rem}
.ck-staging{background:var(--soft);border-radius:12px;padding:2rem;text-align:center}
.ck-staging p{font-size:1.4rem;color:var(--gray);margin-bottom:1.6rem}
.ck-pay-status{margin-top:1.2rem}
#paymentBrick_container{min-height:60px}

.ck-summary{background:var(--soft);border:1px solid var(--line);border-radius:var(--radius-lg);padding:2.6rem;position:sticky;top:96px}
.ck-summary h3{font-size:1.8rem;margin-bottom:1.6rem}
.ck-items{display:flex;flex-direction:column;gap:1.2rem;margin-bottom:1.6rem;max-height:280px;overflow-y:auto}
.ck-item{display:grid;grid-template-columns:48px 1fr auto;gap:1rem;align-items:center;font-size:1.3rem}
.ck-item img{border-radius:8px;object-fit:cover}
.ck-item strong{color:var(--musgo)}

/* ---------- Confirmação ---------- */
.ck-done{max-width:680px;margin:0 auto;padding:5rem 3vw 6rem;text-align:center}
.ck-done-head{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:3rem}
.ck-done-ico{width:72px;height:72px;border-radius:50%;display:grid;place-items:center;font-size:3rem;margin-bottom:.6rem}
.ck-done-ico.ok{background:#e7f0e2;color:#3a6b3a}
.ck-done-ico.wait{background:#faf0dd;color:#8a6a2b}
.ck-done-ico.no{background:#f6e3e0;color:#a23b3b}
.ck-done-head h1{font-size:clamp(2.6rem,4vw,3.6rem)}
.pix-box{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:2.6rem;margin-bottom:2.4rem;display:flex;flex-direction:column;align-items:center;gap:1.2rem}
.pix-qr{border:1px solid var(--line);border-radius:12px;padding:8px;background:#fff}
.pix-copy{display:flex;gap:.8rem;width:100%;max-width:420px}
.pix-copy input{flex:1;border:1px solid var(--line);border-radius:50px;padding:1.1rem 1.4rem;font-family:var(--font-mono);font-size:1.2rem;color:var(--gray-5)}
.ck-done-card{background:var(--soft);border-radius:var(--radius-lg);padding:2rem;text-align:left;margin-bottom:2.4rem}
.ck-done-card .order-totals{margin-top:1.4rem}
.ck-done-actions{display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap}
@media(max-width:860px){.ck-layout{grid-template-columns:1fr;gap:2rem}.ck-summary{position:static}.ck-grid{grid-template-columns:1fr}}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}
