:root{
  --brand:#6c63ff; --brand2:#ff4fa3;
  --bg:#f6f7fb; --text:#1b2430; --muted:#6b7280; --card:#fff; --ring:rgba(108,99,255,.18);
  --blue:#0d61ff; --footer:#0c2144;
}

/* Base / tipografia */
*{box-sizing:border-box}
html{-webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale}
body{
  margin:0;
  font-family:"Poppins", system-ui, Segoe UI, Roboto, Arial, sans-serif;
  font-weight:400; line-height:1.5; letter-spacing:.2px;
  background:var(--bg); color:var(--text);
}
.container{max-width:1100px;margin:0 auto;padding:0 16px}

/* ===== Top bar ===== */
.top-bar{position:sticky;top:0;z-index:60;background:#0d5bd7;color:#fff}
.top-bar-inner{height:32px;display:flex;align-items:center;justify-content:center}
.top-bar-center{display:flex;align-items:center;gap:10px}
.top-bar-text{font-weight:800;letter-spacing:.2px}
.icon-flag{height:16px;width:auto;display:inline-block}

/* ===== HEADER ===== */
.topbar{
  position:relative;
  top:auto;
  z-index:50;
  background:linear-gradient(90deg,var(--brand),#8a7bff);
  color:#fff;
  padding:6px 0;
  box-shadow:0 2px 10px rgba(0,0,0,.06);
}
.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:0;
  min-height:unset;
}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fff}
.brand-logo{max-width:150px;height:auto;display:block;object-fit:contain}
.brand-name{display:none}
.right-wrap{display:flex;align-items:center;gap:16px;flex:1;justify-content:flex-end}

/* ===== Busca ===== */
.search{
  display:flex; align-items:center; gap:8px;
  background:#fff; border-radius:999px; overflow:hidden;
  height:40px;
  padding:0 8px 0 12px;
  box-shadow:0 6px 16px rgba(0,0,0,.10);
  border:1px solid rgba(0,0,0,.06);
  min-width:320px;
  flex:1; max-width:640px; margin:0 24px;
}
.search input{border:0; outline:0; flex:1; font-size:14px; background:transparent; color:#1f2a37;}
.search input::placeholder{color:#9aa4b2}
.search-btn{
  border:0; cursor:pointer; display:flex; align-items:center; justify-content:center;
  width:32px; height:32px; border-radius:999px; background:#fff; color:#0f172a;
  box-shadow:0 2px 6px rgba(0,0,0,.12);
}

/* Acesso / Menu */
.account-only a{color:#fff;text-decoration:none;font-weight:700;font-size:.93rem}
.sep{opacity:.7;margin:0 6px;color:#fff}
.menu a{color:#fff;text-decoration:none;margin-left:12px;font-weight:800;opacity:.95;font-size:.93rem}
.menu a:hover{opacity:1;text-decoration:underline}
.cart-link{position:relative;padding-right:6px}
.cart-icon{margin-right:4px}
.cart-badge{
  position:absolute;right:-10px;top:-6px;min-width:18px;height:18px;
  background:#00d084;border-radius:999px;color:#013;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;padding:0 5px;border:2px solid rgba(255,255,255,.9)
}

/* Pulso do carrinho */
@keyframes pulseCart {0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)}}
.cart-link.pulse{animation:pulseCart .35s ease-in-out 1}

/* ===== Promo: faixa inteira pulsando ===== */
.promo-strip{
  display:flex; align-items:center; justify-content:center; text-align:center; gap:10px;
  background:#fff; border:1px solid #eee; padding:12px 16px; margin:16px 0;
  border-radius:16px; text-decoration:none; color:inherit;
  box-shadow:0 6px 18px rgba(0,0,0,.05);
  animation:pulseGlow 2s ease-in-out infinite;
}
@keyframes pulseGlow{
  0%{transform:scale(1); box-shadow:0 6px 18px rgba(108,99,255,.18)}
  50%{transform:scale(1.02); box-shadow:0 12px 28px rgba(108,99,255,.28)}
  100%{transform:scale(1); box-shadow:0 6px 18px rgba(108,99,255,.18)}
}

/* ===== Grid / Cards ===== */
.sec-title{margin:18px 0 10px}
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:28px}
.card{
  background:var(--card);
  border:1px solid #eceff3;
  border-radius:14px;
  padding:12px;
  box-shadow:0 2px 8px rgba(0,0,0,.03);
  transition:.18s;
}
.card:hover{transform:translateY(-3px);box-shadow:0 12px 28px var(--ring)}
.thumb{position:relative;border-radius:12px;overflow:hidden;background:#f7f7fb}
.thumb img{width:100%;height:180px;object-fit:contain;display:block}
.badge{position:absolute;top:10px;left:10px;background:var(--brand2);color:#fff;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800}
.card h3{margin:10px 0 6px;font-weight:600;font-size:1rem}
.rating{color:#ffb703;font-weight:800;font-size:.95rem}
.rating span{color:var(--muted);font-weight:600;margin-left:6px}
.price{display:flex;gap:10px;align-items:baseline;margin:6px 0 10px}
.price-now{color:var(--brand);font-weight:800}
.price-old{text-decoration:line-through;color:#99a1b3;font-size:.9rem}
.btn{
  background:var(--brand);color:#fff;border:0;padding:9px 12px;border-radius:10px;
  font-weight:800;cursor:pointer;box-shadow:0 8px 16px var(--ring);transition:filter .2s,transform .05s;font-size:.95rem
}
.btn:hover{filter:brightness(.95)}
.btn:active{transform:translateY(1px)}
.btn-clear{background:#ececec;color:#111}

/* ===== WhatsApp / FAB ===== */
.whatsapp-btn{
  position:fixed;bottom:18px;right:18px;width:54px;height:54px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;background:#25D366;color:#fff;
  font-size:22px;text-decoration:none;box-shadow:0 10px 28px rgba(0,0,0,.28);z-index:40
}
/* sobe um pouco no mobile para não sobrepor botões fixos */
@media (max-width:768px){
  .whatsapp-btn{ bottom:72px; right:18px; }
}
/* se marcar o body dessas páginas com as classes abaixo, sobe mais ainda */
.cart-page .whatsapp-btn,
.checkout-page .whatsapp-btn{ bottom:110px; }

/* ===== Footer ===== */
.footer .top{background:#1e6fbf;color:#fff}
.footer .top .container{display:flex;gap:10px;align-items:center;justify-content:center;padding:16px}
.footer .top input{border-radius:999px;border:0;padding:10px 14px}
.footer .top button{border:0;background:#072e63;color:#fff;border-radius:999px;padding:10px 18px;cursor:pointer}
.footer .mid{background:var(--footer);color:#e4edff}
.footer .cols{display:grid;gap:28px;grid-template-columns:1.2fr 1fr 1.2fr;max-width:1100px;margin:0 auto;padding:28px 16px}
.footer h4{margin:0 0 10px 0;color:#fff}
.footer a{color:#dbe8ff;text-decoration:none}
.footer a:hover{text-decoration:underline}
.pay-sec section{margin-bottom:22px}
.pay-logos,.sec-logos{display:flex;gap:14px;flex-wrap:wrap}
.pay-logos img{height:44px;border-radius:12px;background:#fff;padding:8px}
.sec-logos img{height:44px;border-radius:12px;background:#fff;padding:8px}
.footer-socialbar{background:#2a79b0; padding:14px 0;}
.footer-socialbar .container{display:flex;justify-content:center;align-items:center;}
.social-icons{display:flex;gap:22px}
.social-icons a{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);transition:transform .2s, background .2s}
.social-icons a:hover{transform:translateY(-2px);background:rgba(255,255,255,.16)}
.social-icons a img{width:22px;height:22px;filter:brightness(0) invert(1)}
.footer .bottom{background:#06182f;color:#9fb5d9}
.footer .bottom .container{padding:14px 16px;text-align:center;max-width:1100px;margin:0 auto}

/* ===== Checkout ===== */
.checkout-form{
  background:#fff;
  border:1px solid #eceff3;
  border-radius:16px;
  padding:18px;
  margin:12px 0 28px;
  box-shadow:0 6px 18px rgba(0,0,0,.05);
  display:grid;
  grid-template-columns:220px 1fr;
  column-gap:16px;
  row-gap:14px;
}
.checkout-form label{
  align-self:center;
  text-align:right;
  color:var(--muted);
  font-size:.95rem;
  font-weight:600;
  padding-right:4px;
}
.checkout-form input,
.checkout-form select{
  width:100%;
  height:44px;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid #dde1ea;
  outline:none;
  font-size:15px;
  background:#fbfcff;
  transition:border-color .15s, box-shadow .15s;
}
.checkout-form input:focus,
.checkout-form select:focus{
  border-color:var(--brand);
  box-shadow:0 0 0 4px var(--ring);
}
.checkout-actions{
  grid-column:1 / -1;
  display:flex; gap:10px; flex-wrap:wrap; margin-top:6px;
}
@media (max-width:700px){
  .checkout-form{grid-template-columns:1fr}
  .checkout-form label{text-align:left;margin-top:6px}
}

/* ===== Responsivo ===== */
@media (max-width:1100px){.search{min-width:320px}}
@media (max-width:900px){
  .grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .thumb img{height:170px}
}
@media (max-width:640px){
  .grid{grid-template-columns:1fr}
  .thumb img{height:160px}
  .topbar-inner{flex-direction:column;align-items:stretch;gap:10px}
  .right-wrap{flex-direction:column;align-items:stretch}
  .search{ min-width:unset;width:100%; max-width:100%; margin:0; }
  .menu{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
  .footer .cols{grid-template-columns:1fr}
}

/* ===== HEADER / NAVBAR (slim opcional) ===== */
.navbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 4px 14px;
  background: linear-gradient(90deg, var(--brand), #8a7bff);
  color: #fff;
  font-weight: 600;
}
.navbar-logo { display:flex; align-items:center; gap:6px; font-size:15px; }
.navbar-search { flex:1; max-width:300px; margin:0 12px; }
.navbar-search input { padding:4px 10px; border-radius:16px; border:none; outline:none; width:100%; font-size:13px; }
.navbar-search button { padding:4px 8px; border-radius:50%; background:#fff; border:none; cursor:pointer; margin-left:-30px; box-shadow:0 1px 3px rgba(0,0,0,0.15); }
.navbar-links { display:flex; align-items:center; gap:14px; font-size:13px; }
.navbar-links a { color:#fff; text-decoration:none; font-weight:600; opacity:.9; }
.navbar-links a:hover { opacity:1; text-decoration:underline; }

/* ========= TOPBAR SLIM (overrides) ========= */
.topbar{ padding: 3px 0; }
.topbar-inner{ gap: 8px; }
.brand-logo{ max-width: 128px; }
.search{ height: 34px; min-width: 280px; padding: 0 8px 0 10px; }
.search input{ font-size: 13px; }
.search-btn{ width: 28px; height: 28px; box-shadow: 0 1px 4px rgba(0,0,0,.12); }
.account-only a, .menu a{ font-size: .88rem; }
.menu a{ margin-left: 10px; }
.sep{ margin: 0 4px; }
.cart-badge{ right: -8px; top: -6px; min-width: 16px; height: 16px; font-size: 11px; }
@media (max-width: 900px){
  .brand-logo{ max-width: 118px; }
  .search{ min-width: 240px; height: 32px; }
  .search-btn{ width: 26px; height: 26px; }
  .account-only a, .menu a{ font-size: .85rem; }
}

/* ===== Splash / Tela de Boas‑vindas ===== */
#welcome-overlay{
  position:fixed;
  inset:0;
  width:100%;
  height:100dvh;                          /* viewport dinâmica no mobile */
  background:linear-gradient(135deg,#4f46e5,#3b82f6);
  display:grid; place-items:center;        /* centralização real */
  padding:24px;
  z-index:9999;
  animation:welcomeFade 2s ease forwards;
  animation-delay:2.5s;
}
.welcome-content{
  text-align:center;
  color:#fff;
  animation:welcomeScale 1s ease;
  max-width:min(92vw, 960px);
  text-wrap:balance;
}
.welcome-content h1{
  white-space:nowrap;                      /* manter em uma linha */
  font-size:clamp(18px, 5.2vw, 56px);      /* mais agressivo no mobile p/ não cortar */
  line-height:1.08;
  margin:0 0 10px 0;
}
@media (max-width:480px){
  .welcome-content h1{ font-size:clamp(16px, 5vw, 34px); }
}
.welcome-content span{ color:#ffd700; }
.welcome-content p{
  font-size:clamp(14px,3.6vw,20px);
  opacity:.9; margin:0;
}
@keyframes welcomeFade{ to{ opacity:0; visibility:hidden; } }
@keyframes welcomeScale{ from{ transform:scale(.7); opacity:0; } to{ transform:scale(1); opacity:1; } }

/* ====== MiniStore — responsividade mobile sem mexer no desktop ====== */
:root{ --fs-base: clamp(14px, 2.6vw, 16px); --radius: 14px; }
html{ font-size: var(--fs-base); }
img{ max-width:100%; height:auto; display:block; }
.container{ padding-left:16px; padding-right:16px; }
button, .btn, input, select{ min-height:44px; }

/* Top bar: central no mobile */
@media (max-width:768px){
  .top-bar{ font-size:.95rem; }
  .top-bar .top-bar-inner{ justify-content:center; }
  .top-bar .top-bar-center{ gap:8px; }
}

/* Header empilhado no mobile */
@media (max-width:992px){
  header.topbar{ padding:10px 0; }
  header.topbar .container{ display:flex; flex-direction:column; gap:10px; }
  .topbar .brand, .topbar .search, .topbar .actions{ width:100%; }
  .topbar .search input{ width:100%; }
  .topbar .actions{ display:flex; justify-content:space-between; }
}

/* Navbar quebra de linha */
@media (max-width:768px){
  .nav, .nav ul{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px; }
  .nav a{ padding:10px 12px; border-radius:12px; }
}

/* Centralizar “Cadastre‑se | Fazer login” no mobile */
@media (max-width:768px){
  .account-only{
    width:100%;
    display:flex; justify-content:center; align-items:center; gap:10px;
  }
}

/* Hero */
@media (max-width:768px){
  .hero{ display:flex; flex-direction:column; gap:14px; text-align:center; padding:18px; }
  .hero .hero-media{ order:-1; }
  .hero .hero-title{ font-size:clamp(1.25rem,5.4vw,2rem); line-height:1.2; }
  .hero .hero-sub{ font-size:1rem; opacity:.9; }
  .hero .hero-cta .btn{ width:100%; }
}

/* Grade de produtos original (outra grid) */
.products-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
@media (max-width:1200px){ .products-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:900px){  .products-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){  .products-grid{ grid-template-columns:1fr; } }

/* Cards */
.product-card{ border-radius:var(--radius); overflow:hidden; }
.product-card .price{ font-size:1.05rem; }
.product-card .actions .btn{ width:100%; }

/* Seções 2 colunas -> 1 coluna */
.split, .grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
@media (max-width:768px){ .split, .grid-2{ grid-template-columns:1fr; } }

/* Carrinho lateral */
@media (max-width:768px){
  .cart-drawer{ width:100vw; max-width:none; left:0; right:0; border-radius:16px 16px 0 0; }
}

/* Formulários genéricos */
@media (max-width:768px){
  .form-grid{ display:grid; grid-template-columns:1fr; gap:12px; }
  .form-grid input, .form-grid select, .form-grid textarea{ width:100%; }
  .form-actions .btn{ width:100%; }
}

/* Tabelas */
@media (max-width:768px){
  .table-wrapper{ overflow:auto; -webkit-overflow-scrolling: touch; }
  table{ min-width:600px; }
}

/* Rodapé stack */
@media (max-width:768px){
  footer .footer-grid{ display:grid; grid-template-columns:1fr; gap:16px; text-align:center; }
}

/* Utilitários */
@media (max-width:768px){ .hide-sm{ display:none !important; } }
@media (min-width:769px){ .show-sm{ display:none !important; } }

/* Evita “estouro” de textos longos */
.product-card .title, .hero .hero-title{ word-wrap:break-word; overflow-wrap:anywhere; }

/* ===== AJUSTES FINOS EXTRA ===== */

/* Header centralizado no mobile */
@media (max-width:768px){
  header, .topbar, .topbar .container{ display:flex; flex-direction:column; align-items:center; gap:8px; }
  .topbar .brand, .brand, .site-logo, header .logo{ width:100%; display:flex; justify-content:center; text-align:center; }
  .brand-logo{ margin:0 auto; }
  .topbar .search{ width:100%; }
  .topbar .actions{ width:100%; display:flex; justify-content:space-between; }
  .menu{ justify-content:center; }
}

/* Promo mais “clean” e em 2 linhas no mobile */
@media (max-width:768px){
  .promo-strip{
    display:grid; grid-template-columns:1fr; row-gap:8px;
    padding:10px 12px; margin:12px 0;
  }
  .promo-strip .btn{
    justify-self:center;
    font-size:.9rem; padding:8px 12px; border-radius:12px;
    width:auto; min-width:unset;
  }
}

/* Newsletter footer empilhada */
@media (max-width:768px){
  .footer .top .container{ flex-direction:column; align-items:stretch; gap:10px; }
  .footer .top input, .footer .top button{ width:100%; }
}

/* Forçar 2 colunas na .grid (produtos) no celular */
@media (max-width:640px){ .grid{ grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (max-width:380px){ .grid{ grid-template-columns:1fr; } }

/* Cards mais compactos no mobile */
@media (max-width:768px){
  .card{ border-radius:16px; }
  .card h3{ font-size:1rem; line-height:1.25; }
  .btn{ width:100%; }
}

/* Modais sempre visíveis/roláveis */
.modal-backdrop{
  position:fixed; inset:0; display:none; align-items:center; justify-content:center;
  background:rgba(0,0,0,.45); padding:16px; z-index:1000;
}
.modal-backdrop.is-open{ display:flex; }
.modal, .modal-dialog, .modal-content{
  width:min(92vw,560px); max-height:85vh; overflow:auto; border-radius:16px;
}
.modal-header{ position:sticky; top:0; background:inherit; z-index:1; }
@media (max-width:768px){
  .modal-header .close, .modal .btn-close{ width:36px; height:36px; display:grid; place-items:center; border-radius:12px; }
}

/* Segurança extra */
html, body{ overflow-x:hidden; }
