/* Gump Canecas Landing - estilos */
:root{
  --bg:#ffffff;
  --fg:#111827;
  --muted:#6b7280;
  --card:#ffffff;
  --alt:#f7f7fb;
  --border:#e5e7eb;
  --shadow: 0 10px 30px rgba(0,0,0,.08);
  --radius:18px;
  --brand:#4b1d8a;
  --brand2:#ff2ea6;
  --brand3:#f4b400;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--fg);
  background:var(--bg);
  line-height:1.4;
}

a{color:inherit;text-decoration:none}
.container{width:min(1120px, 92vw); margin:0 auto}

/* ── Topbar ── */
.topbar{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.9);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--border);
}
.topbar__inner{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:12px 0}
.brand{display:flex; align-items:center; gap:10px}
.logo{height:44px; width:auto; display:block}

.nav{display:none; gap:14px; color:var(--muted); font-weight:600}
.nav a:hover{color:var(--fg)}

.topbar__actions{display:flex; align-items:center; gap:10px}

.icon-btn{
  border:1px solid var(--border);
  background:#fff;
  border-radius:999px;
  padding:10px 12px;
  cursor:pointer;
  display:flex; align-items:center; gap:8px;
}
.badge{
  background:var(--brand);
  color:#fff;
  border-radius:999px;
  padding:2px 8px;
  font-size:12px;
}

.btn{
  border:1px solid transparent;
  background:var(--brand);
  color:#fff;
  border-radius:999px;
  padding:11px 14px;
  font-weight:700;
  cursor:pointer;
  box-shadow: 0 10px 20px rgba(75,29,138,.15);
  font-size:14px;
}
.btn:hover{filter:brightness(0.96)}
.btn--ghost{
  background:#fff;
  border-color:var(--border);
  color:var(--fg);
  box-shadow:none;
}
.btn--full{width:100%}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.55; cursor:not-allowed}

/* ── Hero ── */
.hero{
  padding:46px 0 26px;
  background:
    radial-gradient(900px 400px at 20% 0%, rgba(255,46,166,.12), transparent 60%),
    radial-gradient(900px 400px at 90% 10%, rgba(244,180,0,.12), transparent 60%),
    radial-gradient(800px 400px at 50% 100%, rgba(75,29,138,.10), transparent 60%);
}
.hero__grid{display:grid; grid-template-columns:1fr; gap:18px;}
.pill{
  display:inline-block;
  padding:6px 10px;
  border:1px solid var(--border);
  border-radius:999px;
  background:#fff;
  color:var(--muted);
  font-weight:600;
  margin-bottom:12px;
}
h1{font-size:38px; line-height:1.08; margin:0 0 10px}
h2{font-size:28px; margin:0 0 14px}
h3{margin:0 0 8px}
.muted{color:var(--muted)}
.hero__cta{display:flex; gap:10px; flex-wrap:wrap; margin:16px 0}
.note{
  border-left:4px solid var(--brand3);
  padding:10px 12px;
  background:#fff;
  border-radius:12px;
  border:1px solid var(--border);
  max-width:520px;
}

.hero__card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  box-shadow: var(--shadow);
}
.checklist{margin:10px 0 14px; padding-left:18px; color:var(--muted)}
.checklist li{margin:6px 0}
.hero__mini{display:grid; gap:10px; margin-top:10px}

/* ── Sections ── */
.section{padding:34px 0}
.section--alt{background:var(--alt); border-top:1px solid var(--border); border-bottom:1px solid var(--border)}
.section__head{display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap}
.filters{display:flex; gap:10px; flex-wrap:wrap}

.label{font-size:13px; font-weight:700; color:var(--muted)}
.input{
  width:100%;
  border:1px solid var(--border);
  border-radius:14px;
  padding:12px 12px;
  font-size:14px;
  outline:none;
  background:#fff;
}
.input:focus{border-color:rgba(75,29,138,.35); box-shadow:0 0 0 4px rgba(75,29,138,.08)}
.input--small{width:260px; max-width:78vw}

/* ── Product Grid ── */
.grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  margin-top:12px;
}
.card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 10px 26px rgba(0,0,0,.06);
  display:flex;
  flex-direction:column;
}

/* ── Card Gallery ── */
.card__gallery{
  position:relative;
  width:100%;
  aspect-ratio:4/3;
  overflow:hidden;
  background:#f3f4f6;
}
.gallery__track{
  position:relative;
  width:100%;
  height:100%;
}
.gallery__img{
  position:absolute;
  inset:0;
  width:100%; height:100%;
  object-fit:cover;
  opacity:0;
  transition:opacity .28s ease;
}
.gallery__img.active{opacity:1;}

.gallery__dots{
  position:absolute;
  bottom:8px; left:50%; transform:translateX(-50%);
  display:flex; gap:5px;
  z-index:4;
}
.gallery__dot{
  width:7px; height:7px;
  border-radius:999px;
  border:none;
  background:rgba(255,255,255,.55);
  cursor:pointer;
  padding:0;
  transition:background .2s, transform .2s;
}
.gallery__dot.active{background:#fff; transform:scale(1.25);}

.gallery__arrow{
  position:absolute;
  top:50%; transform:translateY(-50%);
  z-index:4;
  background:rgba(255,255,255,.82);
  border:1px solid var(--border);
  border-radius:999px;
  width:32px; height:32px;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  font-size:17px;
  color:var(--fg);
  transition:background .15s;
  padding:0;
}
.gallery__arrow:hover{background:#fff;}
.gallery__arrow--prev{left:8px;}
.gallery__arrow--next{right:8px;}

/* ── Card Body ── */
.card__body{padding:14px}
.card__title{display:flex; align-items:flex-start; justify-content:space-between; gap:10px}
.price{font-weight:900; color:var(--brand); white-space:nowrap;}
.card__desc{margin:8px 0 12px}
.card__actions{display:flex; gap:10px; flex-wrap:wrap}
.small{font-size:12px; color:var(--muted);}

/* ── Steps ── */
.steps{display:grid; grid-template-columns:1fr; gap:12px; margin-top:12px}
.step{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
  display:flex; gap:12px;
  box-shadow:0 10px 26px rgba(0,0,0,.05);
}
.step__num{
  width:36px; height:36px;
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(75,29,138,.10);
  color:var(--brand);
  font-weight:900;
  flex-shrink:0;
}

/* ── FAQ ── */
.faq details{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:12px 14px;
  margin:10px 0;
}
.faq summary{cursor:pointer; font-weight:800}

/* ── Footer ── */
.footer{border-top:1px solid var(--border); padding:22px 0;}
.footer__inner{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap}

/* ── Cart Drawer ── */
.drawer{position:fixed; inset:0; display:none; z-index:80}
.drawer.show{display:block}
.drawer__backdrop{position:absolute; inset:0; background:rgba(0,0,0,.45)}
.drawer__panel{
  position:absolute; top:0; right:0;
  width:min(440px, 92vw);
  height:100%;
  background:#fff;
  border-left:1px solid var(--border);
  display:flex; flex-direction:column;
}
.drawer__head{
  padding:14px;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--border);
}
.drawer__body{padding:14px; overflow:auto; flex:1}
.drawer__footer{padding:14px; border-top:1px solid var(--border); display:flex; gap:10px;}

.cart{display:grid; gap:12px}
.cart-item{
  display:grid;
  grid-template-columns:64px 1fr;
  gap:10px;
  border:1px solid var(--border);
  border-radius:16px;
  padding:10px;
}
.cart-item img{width:64px; height:64px; border-radius:12px; object-fit:cover; background:#f3f4f6}
.cart-item__top{display:flex; justify-content:space-between; gap:10px}
.cart-item__vars{display:flex; flex-wrap:wrap; gap:4px; margin-top:5px;}
.var-tag{
  font-size:11px;
  background:rgba(75,29,138,.08);
  color:var(--brand);
  border-radius:999px;
  padding:2px 8px;
  font-weight:600;
}
.qty{display:flex; align-items:center; gap:8px; margin-top:8px;}
.qty button{
  width:34px; height:34px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  cursor:pointer;
  font-size:16px;
}
.qty span{min-width:18px; text-align:center; font-weight:800}
.cart__notes{margin-top:14px}
.cart__summary{margin-top:14px; border:1px solid var(--border); border-radius:16px; padding:12px}
.row{display:flex; align-items:center; justify-content:space-between; gap:10px; margin:6px 0}

.empty{
  border:1px dashed var(--border);
  border-radius:16px;
  padding:14px;
  color:var(--muted);
  text-align:center;
}

/* ── Product Modal ── */
.product-modal{
  position:fixed; inset:0;
  z-index:90;
  display:none;
  align-items:center; justify-content:center;
}
.product-modal.show{display:flex;}
.product-modal__backdrop{
  position:absolute; inset:0;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(4px);
}
.product-modal__panel{
  position:relative;
  z-index:1;
  background:#fff;
  border-radius:24px;
  width:min(900px, 96vw);
  max-height:90vh;
  overflow:auto;
  box-shadow:0 30px 80px rgba(0,0,0,.22);
  animation: modalIn .22s ease;
}
@keyframes modalIn{
  from{opacity:0; transform:scale(.96) translateY(12px)}
  to{opacity:1; transform:scale(1) translateY(0)}
}
.product-modal__close{
  position:absolute; top:14px; right:14px; z-index:2;
  background:#fff;
  border:1px solid var(--border);
  border-radius:999px;
  width:36px; height:36px;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  font-size:15px;
}
.product-modal__inner{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
}

/* Modal Gallery */
.modal-gallery{
  padding:20px 20px 0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.modal-gallery__main{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  background:#f3f4f6;
  aspect-ratio:4/3;
}
.modal-gallery__main img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  transition:opacity .2s;
}
.modal-gallery__thumbs{
  display:flex; gap:8px; overflow-x:auto; padding-bottom:2px;
}
.modal-gallery__thumbs::-webkit-scrollbar{height:4px}
.modal-gallery__thumbs::-webkit-scrollbar-track{background:transparent}
.modal-gallery__thumbs::-webkit-scrollbar-thumb{background:var(--border); border-radius:4px}

.modal-thumb{
  flex-shrink:0;
  width:62px; height:62px;
  border-radius:12px;
  overflow:hidden;
  border:2px solid var(--border);
  cursor:pointer;
  padding:0;
  background:#f3f4f6;
  transition:border-color .15s;
}
.modal-thumb img{width:100%; height:100%; object-fit:cover; display:block;}
.modal-thumb.active{border-color:var(--brand);}
.modal-thumb:hover{border-color:rgba(75,29,138,.4);}

/* Modal Info */
.modal-info{
  padding:20px;
  display:flex; flex-direction:column; gap:14px;
}
.modal-info h2{font-size:22px; margin:0;}
.modal-price{font-size:26px; font-weight:900; color:var(--brand);}

/* Variations */
.modal-variations{display:flex; flex-direction:column; gap:14px;}
.var-group{display:flex; flex-direction:column; gap:8px;}
.var-group__label{font-size:13px; font-weight:700; color:var(--fg);}
.var-group__options{display:flex; flex-wrap:wrap; gap:8px;}

.var-option{
  border:1.5px solid var(--border);
  background:#fff;
  border-radius:999px;
  padding:7px 16px;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  transition:all .15s;
  color:var(--fg);
}
.var-option:hover{border-color:rgba(75,29,138,.4); background:rgba(75,29,138,.04);}
.var-option.active{
  border-color:var(--brand);
  background:var(--brand);
  color:#fff;
  box-shadow:0 4px 12px rgba(75,29,138,.25);
}

.var-group--error .var-group__label{color:#e11d48;}
.var-group--error .var-option{border-color:#fca5a5; animation:shake .3s ease;}
@keyframes shake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-4px)}
  75%{transform:translateX(4px)}
}

/* Modal Qty */
.modal-qty{display:flex; align-items:center; gap:14px;}
.modal-qty .label{margin:0;}

/* Modal Actions */
.modal-actions{display:flex; flex-direction:column; gap:10px;}

/* Responsive */
@media (min-width:680px){
  .product-modal__inner{
    grid-template-columns:1fr 1fr;
  }
  .modal-gallery{padding:24px 0 24px 24px;}
  .modal-info{padding:24px;}
}

@media (min-width:860px){
  .nav{display:flex}
  .hero__grid{grid-template-columns:1.1fr .9fr; align-items:start}
  .grid{grid-template-columns:repeat(3,1fr)}
  h1{font-size:46px}
  .steps{grid-template-columns:repeat(3,1fr)}
}

@media (max-width:859px){
  .grid{grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px;}
  .card__body{padding:12px;}
  .card__title{flex-direction:column; gap:6px;}
  .card__actions{flex-direction:column;}
  .card__actions .btn{width:100%;}
}


.modal-actions:has(#modalAddToCart:only-child){
  grid-template-columns: 1fr;
}

/* Modal mobile proporcional e estável */
@media (max-width: 679px){
  .product-modal{
    align-items:flex-end;
    justify-content:center;
  }

  .product-modal__panel{
    width:100%;
    max-width:100%;
    max-height:92dvh;
    border-radius:24px 24px 0 0;
    overflow-y:auto;
    overflow-x:hidden;
  }

  .product-modal__inner{
    display:flex;
    flex-direction:column;
  }

  .modal-gallery{
    padding:14px 14px 0;
    gap:10px;
  }

  .modal-gallery__main{
    position:relative;
    width:100%;
    height:auto;
    min-height:unset;
    max-height:none;
    aspect-ratio:1 / 1;
    border-radius:18px;
    overflow:hidden;
    background:#f3f4f6;
  }

  .modal-gallery__main img{
    width:100%;
    height:100%;
    object-fit:contain;
    display:block;
    background:#f3f4f6;
  }

  .modal-gallery__thumbs{
    display:flex;
    gap:8px;
    overflow-x:auto;
    overflow-y:hidden;
    padding:2px 0 4px;
    -webkit-overflow-scrolling:touch;
    scroll-behavior:smooth;
  }

  .modal-thumb{
    width:58px;
    height:58px;
    min-width:58px;
    flex:0 0 58px;
    border-radius:12px;
    background:#fff;
  }

  .modal-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }

  .modal-info{
    padding:10px 14px 16px;
    gap:12px;
  }

  .modal-info h2{
    font-size:17px;
    line-height:1.25;
    margin:0;
  }

  .modal-price{
    font-size:18px;
    line-height:1.1;
  }

  .modal-info .muted{
    font-size:13px;
    line-height:1.45;
  }

  .modal-variations{
    gap:12px;
  }

  .var-group{
    min-width:0;
  }

  .var-group__label{
    font-size:13px;
  }

  .var-group__options{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
  }

  .var-option{
    font-size:13px;
    line-height:1.2;
    padding:8px 14px;
    max-width:100%;
    white-space:normal;
    word-break:break-word;
  }

  .modal-qty{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    flex-wrap:nowrap;
  }

  .modal-qty .qty{
    margin-top:0;
    flex-shrink:0;
  }

  .modal-actions{
    position:sticky;
    bottom:0;
    background:#fff;
    padding:10px 0 calc(10px + env(safe-area-inset-bottom));
    margin-top:2px;
    border-top:1px solid var(--border);
  }

  .modal-actions .btn{
    width:100%;
  }

  .gallery__arrow{
    width:34px;
    height:34px;
    top:50%;
    transform:translateY(-50%);
  }

  .gallery__arrow--prev{
    left:10px;
  }

  .gallery__arrow--next{
    right:10px;
  }
}


/* Cupom de desconto */
.coupon-box{
  border-bottom:1px solid var(--border);
  padding-bottom:12px;
  margin-bottom:12px;
}
.coupon-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  margin-top:6px;
}
.coupon-message{
  min-height:18px;
  margin-top:6px;
  font-size:12px;
  font-weight:700;
}
.coupon-message--success{color:#15803d;}
.coupon-message--error{color:#e11d48;}
.row--total{
  border-top:1px dashed var(--border);
  padding-top:10px;
  margin-top:10px;
  font-size:16px;
}
.row--total strong{
  color:var(--brand);
  font-size:18px;
}
@media (max-width:480px){
  .coupon-row{grid-template-columns:1fr;}
  .coupon-row .btn{width:100%;}
}

/* Melhorias de conversão e usabilidade */
.trust-list{
  display:grid;
  gap:8px;
  margin:14px 0;
}
.trust-list span{
  display:inline-flex;
  align-items:center;
  width:max-content;
  max-width:100%;
  padding:7px 10px;
  border:1px solid var(--border);
  border-radius:999px;
  background:#fff;
  font-size:13px;
  font-weight:700;
  color:var(--fg);
}

.promo-strip{
  padding:14px 0;
  background:linear-gradient(90deg, rgba(255,46,166,.12), rgba(244,180,0,.15));
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.promo-strip__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.promo-strip__inner div{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.promo-strip__inner strong{
  color:var(--brand);
  font-size:18px;
}
.promo-strip__inner span{
  color:var(--muted);
  font-weight:600;
}

.btn--more{
  display:block;
  margin:22px auto 0;
  min-width:180px;
}
.btn--more[hidden]{display:none;}

/* Mostra a caneca inteira no card, sem cortar a arte */
.gallery__img{
  object-fit:contain;
  background:#f3f4f6;
}

.card-tags{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-top:5px;
}
.card-tags span{
  font-size:11px;
  font-weight:800;
  color:var(--brand);
  background:rgba(75,29,138,.08);
  border-radius:999px;
  padding:3px 8px;
}

.cart-item__personalization{
  margin-top:6px;
  font-size:12px;
  color:var(--fg);
  background:#f9fafb;
  border:1px dashed var(--border);
  border-radius:10px;
  padding:7px 8px;
}
.modal-personalization{
  display:grid;
  gap:6px;
}

.floating-whats{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:70;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 16px;
  border-radius:999px;
  background:#25d366;
  color:#fff;
  font-weight:900;
  box-shadow:0 14px 34px rgba(0,0,0,.22);
  border:2px solid rgba(255,255,255,.85);
}
.floating-whats:hover{filter:brightness(.97)}

@media (max-width:480px){
  .footer{padding-bottom:78px;}
  .trust-list span{width:100%;}
}

/* No mobile, o WhatsApp fica discreto: apenas um botão redondo com ícone */
@media (max-width: 600px){
  .floating-whats{
    width:54px;
    height:54px;
    right:14px;
    bottom:14px;
    left:auto;
    padding:0;
    border-radius:50%;
    font-size:0;
    gap:0;
  }

  .floating-whats::before{
    content:"💬";
    font-size:24px;
    line-height:1;
  }
}