/* ============================================================
   ALO YOGA — style.css (base, header, mega-menu, footer, overlays)
   Compartilhado entre páginas
   ============================================================ */

:root{
  --sans:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
  --ink:#1a1a1a;            /* texto principal */
  --ink-soft:#4a4a4a;
  --gray:#6b6b6b;           /* texto secundário */
  --gray-2:#9a9a9a;
  --border:#e4e4e4;
  --border-soft:#efefef;
  --bg:#ffffff;
  --bg-soft:#f4f3f1;        /* cards / fundos suaves */
  --pink:#f57aa7;           /* announcement (Paradise Pink) */
  --container:1480px;
  --pad:16px;
  --pad-lg:32px;
  --header-h:74px;
  --t:.25s ease;
  --z-header:100;
  --z-mega:90;
  --z-overlay:200;
  --z-drawer:210;
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:clip;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  font-size:15px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
.page-wrapper{overflow-x:clip}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;background:none;border:none;color:inherit}
ul{list-style:none}
input{font-family:inherit}

/* ---------- helpers ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--pad-lg)}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;color:var(--ink);transition:opacity var(--t)}
.icon-btn:hover{opacity:.6}
.link-underline{display:inline-block;font-size:13px;text-decoration:underline;text-underline-offset:3px}

/* botões */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;
  padding:14px 30px;border:1px solid var(--ink);background:var(--ink);color:#fff;
  transition:background var(--t),color var(--t);white-space:nowrap;
}
.btn:hover{background:#fff;color:var(--ink)}
.btn--light{background:#fff;color:var(--ink);border-color:#fff}
.btn--light:hover{background:transparent;color:#fff;border-color:#fff}
.btn--outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--outline:hover{background:var(--ink);color:#fff}

/* ============================================================
   PRODUCT CARD (compartilhado: home carrossel + category grid)
   ============================================================ */
.product-card-media{position:relative;background:var(--bg-soft);aspect-ratio:248/320;overflow:hidden}
.product-card-media img{width:100%;height:100%;object-fit:cover;transition:opacity var(--t)}
.product-card:hover .product-card-media img{opacity:.92}
.product-card.is-placeholder .product-card-media{
  background:linear-gradient(110deg,#f1efed 30%,#e9e7e4 50%,#f1efed 70%);
  background-size:200% 100%;animation:shimmer 1.4s linear infinite
}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
.pc-wish,.pc-bag{position:absolute;width:30px;height:30px;display:flex;align-items:center;justify-content:center;color:var(--ink);transition:opacity var(--t)}
.pc-wish{top:10px;right:10px}
.pc-wish:hover{opacity:.6}
.pc-bag{bottom:10px;right:10px;background:#fff;border-radius:50%;box-shadow:0 1px 6px rgba(0,0,0,.12)}
.pc-bag:hover{opacity:.8}
.product-card.is-placeholder .pc-wish,.product-card.is-placeholder .pc-bag{display:none}
.pc-swatches{display:flex;align-items:center;gap:6px;margin-top:12px;flex-wrap:wrap;min-height:14px}
.pc-swatch{width:14px;height:14px;border-radius:50%;border:1px solid var(--border);flex:0 0 auto}
.pc-swatch-more{font-size:11px;color:var(--gray);margin-left:2px}
.pc-badge{display:inline-block;margin-top:9px;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--ink)}
.pc-name{display:block;font-size:13px;font-weight:600;margin-top:8px;line-height:1.4}
.pc-color{font-size:13px;color:var(--gray);margin-top:3px}
.pc-price{font-size:13px;margin-top:3px}
.pc-price .pc-was{color:var(--gray-2);margin-left:6px;font-size:12px}
.product-card.is-placeholder .pc-line{height:11px;border-radius:3px;background:var(--bg-soft);margin-top:10px}
.product-card.is-placeholder .pc-line.short{width:55%}

/* ============================================================
   ANNOUNCEMENT
   ============================================================ */
.announcement{background:var(--pink);color:var(--ink);text-align:center}
.announcement p{font-size:12px;font-weight:600;letter-spacing:.6px;padding:9px 16px;text-transform:uppercase}
.announcement a{text-decoration:underline;text-underline-offset:2px;margin-left:4px}

/* ============================================================
   HEADER
   ============================================================ */
.header{position:sticky;top:0;z-index:var(--z-header);background:#fff;border-bottom:1px solid var(--border-soft);transition:transform .3s ease}
.header.is-hidden{transform:translateY(-100%)}
.header-inner{
  position:relative;display:flex;align-items:center;gap:34px;
  max-width:var(--container);margin:0 auto;height:var(--header-h);padding:0 var(--pad-lg);
}
.header-logo img{width:60px;height:auto}
.header-burger{display:none}

/* nav desktop */
.nav-list{display:flex;align-items:center;gap:28px;height:100%}
.nav-item{height:100%;display:flex;align-items:center}
.nav-link{
  font-size:13px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;
  padding:4px 0;border-bottom:1.5px solid transparent;transition:border-color var(--t)
}
.nav-item:hover .nav-link{border-bottom-color:var(--ink)}

.header-actions{display:flex;align-items:center;gap:20px;margin-left:auto}
.header-login{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;letter-spacing:.6px;text-transform:uppercase}
.header-cart{position:relative}
.cart-count{
  position:absolute;top:-6px;right:-8px;min-width:16px;height:16px;padding:0 4px;
  background:var(--ink);color:#fff;border-radius:9px;font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center
}

/* ---------- mega-menu ---------- */
.mega{
  position:absolute;top:100%;left:0;width:100%;background:#fff;
  border-top:1px solid var(--border-soft);box-shadow:0 16px 24px -18px rgba(0,0,0,.25);
  opacity:0;visibility:hidden;transform:translateY(4px);
  transition:opacity var(--t),transform var(--t),visibility var(--t);
  z-index:var(--z-mega)
}
.nav-item:hover .mega{opacity:1;visibility:visible;transform:translateY(0)}
.mega-inner{max-width:var(--container);margin:0 auto;padding:38px var(--pad-lg) 46px;display:flex;gap:60px}
.mega-title{display:block;font-size:13px;font-weight:700;letter-spacing:.5px;margin-bottom:16px}
.mega-col{display:flex;flex-direction:column;gap:11px}
.mega-col a{font-size:13px;color:var(--gray);transition:color var(--t);width:fit-content}
.mega-col a:hover{color:var(--ink)}
.mega-cols .mega-col{min-width:120px}
/* variante lista + imagens (acessórios/calçados) */
.mega-list-imgs{align-items:flex-start}
.mega-col--list{min-width:150px}
.mega-imgs{display:flex;gap:14px}
.mega-img{width:170px}
.mega-img img{width:100%;aspect-ratio:1/1.3;object-fit:cover}
.mega-img span{display:block;font-size:13px;margin-top:8px}
.mega-img:hover span{text-decoration:underline;text-underline-offset:3px}

/* ---------- category pills (mobile only) ---------- */
.pills{display:none}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#000;color:#fff;padding:56px var(--pad-lg) 0}
.footer-cols{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr) 1.6fr;gap:40px;padding-bottom:48px
}
.footer-col-head{
  font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:18px;
  width:100%;display:flex;align-items:center;justify-content:space-between;pointer-events:none
}
.footer-col-head .acc-chev{display:none}
.footer-links{display:flex;flex-direction:column;gap:11px}
.footer-links a{font-size:13px;color:#bdbdbd;transition:color var(--t)}
.footer-links a:hover{color:#fff}

.footer-news-title{font-size:13px;color:#dcdcdc;margin-bottom:16px;max-width:340px}
.footer-news-form{display:flex;max-width:360px;border:1px solid #555}
.footer-news-form input{flex:1;background:transparent;border:none;color:#fff;padding:13px 14px;font-size:13px;outline:none}
.footer-news-form input::placeholder{color:#8a8a8a}
.footer-news-form button{width:48px;border-left:1px solid #555;color:#fff;font-size:20px}
.footer-news-legal{font-size:11px;line-height:1.7;color:#8f8f8f;margin-top:14px;max-width:430px}
.footer-social{margin-top:24px}
.footer-social-title{font-size:13px;font-weight:600;display:block;margin-bottom:12px}
.footer-social-icons{display:flex;gap:16px}
.footer-social-icons a{color:#fff;transition:opacity var(--t)}
.footer-social-icons a:hover{opacity:.6}

.footer-legal{
  max-width:var(--container);margin:0 auto;border-top:1px solid #2a2a2a;
  padding:22px 0 30px;text-align:center
}
.footer-legal p{font-size:11px;color:#8f8f8f;line-height:1.7}
.footer-legal-links{margin-top:8px}
.footer-legal-links a{text-decoration:underline;text-underline-offset:2px;margin:0 6px}

/* ============================================================
   OVERLAYS (backdrop, mobile menu, search, cart)
   ============================================================ */
.backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.4);opacity:0;visibility:hidden;
  transition:opacity var(--t),visibility var(--t);z-index:var(--z-overlay)
}
.backdrop.is-active{opacity:1;visibility:visible}
body.no-scroll{overflow:hidden}

/* mobile menu — full-screen, abas + grid de cards */
.mobile-menu{
  position:fixed;top:0;left:0;height:100%;width:100%;background:#fff;
  transform:translateX(-100%);transition:transform .3s ease;z-index:var(--z-drawer);
  display:flex;flex-direction:column
}
.mobile-menu.is-open{transform:translateX(0)}
.mm-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px}
.mm-account{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink);transition:opacity var(--t)}
.mm-account:hover{opacity:.6}

/* abas (scroll horizontal) */
.mm-tabs{
  display:flex;flex-wrap:nowrap;gap:22px;padding:0 18px;
  border-bottom:1px solid var(--border);overflow-x:auto;overflow-y:hidden;
  scrollbar-width:none;-webkit-overflow-scrolling:touch
}
.mm-tabs::-webkit-scrollbar{display:none}
.mm-tab{
  flex:0 0 auto;padding:14px 0;font-size:13px;font-weight:600;letter-spacing:.6px;
  color:var(--gray-2);border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:color var(--t),border-color var(--t);white-space:nowrap
}
.mm-tab.is-active{color:var(--ink);font-weight:700;border-bottom-color:var(--ink)}

/* painéis */
.mm-panels{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.mm-panel{display:none;grid-template-columns:1fr 1fr;gap:18px 12px;padding:18px}
.mm-panel.is-active{display:grid}
.mm-card img{width:100%;aspect-ratio:1/0.82;object-fit:cover;background:var(--bg-soft)}
.mm-card span{display:block;margin-top:8px;font-size:13px;letter-spacing:.3px;line-height:1.3}
.mm-card:hover span{text-decoration:underline;text-underline-offset:3px}

/* rodapé */
.mm-foot{margin-top:auto;border-top:1px solid var(--border);padding:14px 18px;display:flex;flex-direction:column;gap:14px}
.mm-foot-link{display:inline-flex;align-items:center;gap:12px;font-size:14px;color:var(--ink);transition:opacity var(--t)}
.mm-foot-link:hover{opacity:.6}

/* search overlay */
.search-overlay{
  position:fixed;top:0;left:0;width:100%;background:#fff;z-index:var(--z-drawer);
  transform:translateY(-100%);transition:transform .3s ease;box-shadow:0 8px 20px -12px rgba(0,0,0,.3)
}
.search-overlay.is-open{transform:translateY(0)}
.search-box{max-width:var(--container);margin:0 auto;padding:22px var(--pad-lg)}
.search-field{display:flex;align-items:center;gap:14px;border-bottom:1.5px solid var(--ink);padding-bottom:12px}
.search-field input{flex:1;border:none;outline:none;font-size:18px}
.search-field input::placeholder{color:var(--gray-2)}

/* cart drawer */
.cart-drawer{
  position:fixed;top:0;right:0;height:100%;width:90%;max-width:420px;background:#fff;
  transform:translateX(100%);transition:transform .3s ease;z-index:var(--z-drawer);
  display:flex;flex-direction:column
}
.cart-drawer.is-open{transform:translateX(0)}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--border-soft);font-size:14px;font-weight:600;letter-spacing:1px}
.cart-body{flex:1;padding:24px 22px;overflow-y:auto}
.cart-empty{color:var(--gray);font-size:14px;text-align:center;margin-top:40px}
/* itens do drawer (renderizados por main.js) */
.cd-row{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border-soft)}
.cd-thumb{width:64px;height:85px;flex:0 0 auto;background:var(--bg-soft);background-size:cover;background-position:center}
.cd-body{flex:1;min-width:0}
.cd-name{font-size:13px;font-weight:600;line-height:1.3}
.cd-meta{font-size:12px;color:var(--gray);margin-top:4px}
.cd-qty{display:inline-flex;align-items:center;border:1px solid var(--border);margin-top:10px}
.cd-qty button{width:28px;height:28px;font-size:14px;color:var(--ink)}
.cd-qty span{min-width:30px;text-align:center;font-size:13px}
.cd-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between}
.cd-price{font-size:13px;font-weight:600}
.cd-remove{font-size:12px;color:var(--gray);text-decoration:underline;text-underline-offset:2px}
.cd-remove:hover{color:var(--ink)}
.cd-foot{padding-top:18px}
.cd-subtotal{display:flex;justify-content:space-between;font-size:14px;font-weight:600;margin-bottom:14px}
.cd-foot .btn{width:100%}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  :root{--pad-lg:18px;--header-h:56px}
  .nav,.header-login span{display:none}
  .header-burger{display:inline-flex}
  .header-inner{gap:0}
  .header-logo{position:absolute;left:50%;transform:translateX(-50%)}
  .header-logo img{width:52px}
  .header-actions{gap:16px}
  .header-wish{display:none}

  /* pills */
  .pills{
    display:flex;gap:13px;overflow-x:auto;overflow-y:hidden;max-height:150px;
    padding:13px var(--pad-lg);border-top:1px solid var(--border-soft);
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
    transition:max-height .32s ease,opacity .24s ease,padding .32s ease,border-color .24s ease
  }
  .pills::-webkit-scrollbar{display:none}
  /* ao rolar (header condensado), as pills somem — só a barra fica */
  .header.is-condensed .pills{max-height:0;opacity:0;padding-top:0;padding-bottom:0;border-top-color:transparent;pointer-events:none}
  .pill{flex:0 0 auto;width:84px;text-align:center}
  .pill img{width:84px;height:84px;border-radius:0;object-fit:cover;margin:0}
  .pill span{display:block;font-size:10px;margin-top:7px;line-height:1.2;color:var(--ink);text-transform:uppercase;letter-spacing:.2px}

  /* footer accordion */
  .footer{padding:36px 0 0}
  .footer-cols{grid-template-columns:1fr;gap:0;padding:0 var(--pad-lg)}
  .footer-col{border-bottom:1px solid #2a2a2a}
  .footer-col-head{margin:0;padding:18px 0;pointer-events:auto}
  .footer-col-head .acc-chev{display:block;transition:transform var(--t)}
  .footer-col-head[aria-expanded="true"] .acc-chev{transform:rotate(180deg)}
  .footer-links{max-height:0;overflow:hidden;transition:max-height .3s ease}
  .footer-col.is-open .footer-links{max-height:340px}
  .footer-links{padding-bottom:0}
  .footer-col.is-open .footer-links{padding-bottom:18px}
  .footer-news{padding:28px 0}
  .footer-legal{padding:22px var(--pad-lg) 30px}
}

@media (max-width:600px){
  .mega-inner{gap:32px}
}
