/* assets/css/styles.css */
/* Reset y base minimal */
*{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden} /* evita desbordes horizontales */
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu}

/* ===== Variables de tema ===== */
:root{
  --global-header: #0d6efd;
  --global-footer: #111;
  --global-button: #0d6efd;
  --global-bg:     #f8f9fa;
}

/* Fondo del sitio */
body{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  background: var(--store-bg, var(--global-bg, #f8f9fa));
}

.container{max-width:1100px;margin:0 auto;padding:16px}

/* Topbar y botones */
.topbar{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  padding:10px 16px;
  background: var(--store-header, var(--global-header, #0d6efd));
  color:#fff;
}
.topbar .spacer{flex:1}

.btn{
  background: var(--store-button, var(--global-button, #0d6efd));
  color:#fff;
  border:1px solid var(--store-button, var(--global-button, #0d6efd));
  padding:10px 14px;border-radius:8px;cursor:pointer
}
.btn.ghost{
  background:#fff;
  color:var(--store-button, var(--global-button, #0d6efd));
  border:1px solid var(--store-button, var(--global-button, #0d6efd));
}
.btn.small{padding:6px 10px;font-size:.9rem}
.btn.danger{background:#dc3545;color:#fff;border-color:#dc3545}

.alert{padding:10px;border-radius:6px;margin:10px 0}
.alert.success{background:#d1e7dd;color:#0f5132}
.alert.error{background:#f8d7da;color:#842029}

.card{background:#fff;border:1px solid #eee;border-radius:14px;padding:16px;box-shadow:0 3px 10px rgba(0,0,0,.05)}
.card.link{text-decoration:none;display:block;color:inherit;transition:transform .1s}
.card.link:hover{transform:translateY(-2px)}
.grid-3{display:grid;grid-template-columns:repeat(auto-fill, minmax(260px,1fr));gap:16px}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid #eee;text-align:left}
.header-row{display:flex;align-items:center;justify-content:space-between}
.form input,.form textarea,.form select{width:100%;padding:10px;margin:6px 0 12px;border:1px solid #ddd;border-radius:8px}

/* Hero */
.hero{
  background:linear-gradient(135deg,var(--global-header,#0d6efd),#6f42c1);
  color:#fff;padding:30px 0
}

.search{display:flex;gap:8px;margin-top:12px}
.logo{width:100%;height:160px;object-fit:cover;border-radius:10px}
.thumb{width:100%;height:180px;object-fit:cover;border-radius:10px}

/* Cabecera tienda */
.store-header{background:#eef1f4;border-bottom:1px solid #e6e6e6;margin-bottom:12px}
.header-inner{display:flex;gap:16px;align-items:center;padding:16px 0}
.avatar img{width:96px;height:96px;border-radius:50%;object-fit:cover;border:3px solid #fff;box-shadow:0 3px 10px rgba(0,0,0,.1)}

/* FABs */
.fab{position:fixed;right:18px;bottom:18px;background:var(--store-button, var(--global-button, #0d6efd));color:#fff;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 20px rgba(0,0,0,.2);z-index:999}
.fab.whatsapp{bottom:80px;background:#25D366}

/* Cart panel */
.cart-panel{position:fixed;right:0;top:0;bottom:0;width:360px;max-width:90%;background:#fff;border-left:1px solid #eee;box-shadow:-6px 0 20px rgba(0,0,0,.1);transform:translateX(100%);transition:transform .2s;z-index:998;display:flex;flex-direction:column}
.cart-panel.open{transform:translateX(0)}
.cart-header,.cart-footer{padding:12px;border-bottom:1px solid #eee}

.cart-header{display:flex;align-items:center;justify-content:space-between}
.cart-close{border:0;background:transparent;font-size:22px;line-height:1;cursor:pointer;padding:4px 6px}
.cart-close:focus{outline:2px solid #000;outline-offset:2px}
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);display:none;z-index:996}
.backdrop.open{display:block}

.cart-footer{margin-top:auto;border-top:1px solid #eee;border-bottom:0}
#cartItems{padding:12px;overflow:auto;max-height:60vh}
.cart-item{display:flex;align-items:center;justify-content:space-between;border-bottom:1px dashed #eee;padding:8px 0}
.row{display:flex;gap:8px;align-items:center}
.row.end{justify-content:flex-end}

/* Modal genérico */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center}
.modal.hidden{display:none}
.modal-body{background:#fff;border-radius:12px;padding:16px;width:480px;max-width:95%}

/* Auth */
body.auth{display:grid;place-items:center;min-height:100vh;background:#f5f7fb}
.auth .card{width:420px;max-width:95%}

/* Autocomplete */
.autocomplete-list{position:relative}
.autocomplete-list{position:absolute;background:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 6px 20px rgba(0,0,0,.1);width:100%;max-width:420px;z-index:999;display:none}
.autocomplete-list.open{display:block}
.autocomplete-item{display:block;padding:8px 10px;text-decoration:none;color:#222}
.autocomplete-item:hover{background:#f6f6f6}

.dashboard .card canvas{width:100%;height:220px}

#storeSearchForm{position:relative}
#storeAutocomplete{position:absolute;background:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 6px 20px rgba(0,0,0,.1);width:100%;max-width:480px;z-index:999;display:none}
#storeAutocomplete.open{display:block}

/* Footer */
.site-footer{
  background: var(--store-footer, var(--global-footer, #111));
  color:#eee;padding:24px 0;margin-top:24px;position:relative;z-index:1
}
.site-footer .container{display:flex;justify-content:center}
.site-footer a{color:#ddd}

/* ====== Carrusel de banners (home) — sin distorsión ====== */
.banner-carousel{position:relative;overflow:hidden;border-radius:16px;margin:16px 0}
.banner-carousel .slides{display:flex;transition:transform .6s ease}
.banner-carousel .slide{flex:0 0 100%;position:relative;aspect-ratio: 21/9}
@media (max-width: 768px){ .banner-carousel .slide{ aspect-ratio: 16/9 } }
@supports not (aspect-ratio: 1 / 1){
  .banner-carousel .slide{ height:0; padding-top:42.857% }
  @media (max-width:768px){ .banner-carousel .slide{ padding-top:56.25% } }
}
.banner-carousel .slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.banner-carousel .slide-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#eef2ff;color:#667}
.banner-carousel .dots{position:absolute;left:0;right:0;bottom:10px;display:flex;gap:6px;justify-content:center}
.banner-carousel .dots button{width:10px;height:10px;border-radius:50%;border:0;background:#fff8;backdrop-filter:blur(6px);cursor:pointer}
.banner-carousel .dots button.active{background:#fff}

/* Topbar responsive */
.topbar .brand{font-weight:600}
.search-top{position:relative;flex:1 1 420px;order:2}
.top-actions{display:flex;gap:8px;order:3}
.topbar .search input{width:100%;height:38px;border:1px solid #ddd;border-radius:10px;padding:8px 12px;font-size:14px;background:#fff}
.topbar .search input::placeholder{color:#777}
.topbar .search .autocomplete-list{position:absolute;left:0;right:0;top:100%;margin-top:6px;z-index:1000}
@media (max-width: 992px){ .search-top{flex:1 1 360px} }
@media (max-width: 768px){ .search-top{order:3;flex:1 1 100%} .top-actions{order:2;margin-left:auto} }
@media (max-width: 480px){ .top-actions .btn.small{padding:8px 10px;font-size:.95rem} .search-top{margin-top:4px} }

.badge{position:absolute;top:-6px;right:-6px;background:#dc3545;color:#fff;font-size:12px;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px}

/* FABs (público) */
.fab{position:fixed;right:18px;background:var(--store-button, var(--global-button, #0d6efd));color:#fff;width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 20px rgba(0,0,0,.25);z-index:999}
.fab svg { width:26px;height:26px;display:block;fill:#fff;stroke:none; }
.fab.cart{bottom:20px;background:#1863ff}
.fab.main{bottom:86px;background:#111}
.fab.whatsapp{bottom:152px;background:#25D366}
.fab.fav{bottom:218px;background:#ff2e63}

.fab-social{position:fixed;right:86px;bottom:152px;display:none;gap:8px;z-index:998}
.fab-social a{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;box-shadow:0 6px 16px rgba(0,0,0,.2)}
.fab-social .fb{background:#1877F2}
.fab-social .ig{background:#E1306C}
.fab-social .x {background:#000}

/* Modal público */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;align-items:center;justify-content:center;z-index:1000}
.modal.open{display:flex}
.modal-box{background:#fff;border-radius:14px;max-width:92vw;max-height:92vh;overflow:auto;padding:14px 16px;position:relative;box-shadow:0 14px 40px rgba(0,0,0,.25)}
.modal-close{position:absolute;right:10px;top:10px;border:0;background:#000;color:#fff;border-radius:50%;width:30px;height:30px;cursor:pointer;font-weight:700}

/* Checkout */
.checkout-form .row{display:flex;gap:8px;flex-wrap:wrap}
.checkout-form .row > *{flex:1}

/* Carrito abierto: ajusta FABs */
body.cart-open .fab{ right: calc(360px + 24px); }
body.cart-open .fab-social{ right: calc(360px + 92px); }
@media (max-width: 480px){
  body.cart-open .fab{ right: 55vw; }
  body.cart-open .fab-social{ right: calc(55vw + 68px); }
}

/* ===== Chips de categorías (color por variables) ===== */
.cat-chip.active{
  background: var(--store-button, var(--global-button, #0d6efd));
  border-color: var(--store-button, var(--global-button, #0d6efd));
  color:#fff;
}

/* ===== Chips de ETIQUETAS ===== */
.prod-tags{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}
.prod-tags .chip{
  display:inline-flex;align-items:center;gap:6px;
  background:#fff;border:1px solid #e5e7eb;color:#111;
  padding:6px 10px;border-radius:999px;font-size:14px;line-height:1;white-space:nowrap;
  box-shadow:0 2px 6px rgba(0,0,0,.05)
}
.prod-tags .chip::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background: var(--store-button, var(--global-button, #16a34a));opacity:.9
}
@media (max-width: 480px){ .prod-tags .chip{font-size:13px;padding:5px 9px} }

/* FIX: logos en listado de Tiendas (home) */
.card .store-logo { flex: 0 0 auto; }
.card .store-logo .logo-img{ width:72px;height:72px;border-radius:50%;object-fit:cover;display:block; }
@media (min-width: 992px){ .card .store-logo .logo-img{ width:80px; height:80px; } }

/* Logos en hero/tienda sin distorsión */
.hero .avatar img,
.store-header .avatar img{
  width:auto;height:auto;max-height:96px;max-width:220px;object-fit:contain;border-radius:8px;border:0;box-shadow:none;
}
.logo-img{ max-width:100%; height:auto; }

/* Redes sociales oficiales */
.fab-social{ position:fixed; right:86px; bottom:152px; display:none; gap:10px; z-index:997; }
.fab-social .brand{ width:44px; height:44px; border-radius:50%; background:#fff; display:flex; align-items:center; justify-content:center; text-decoration:none; box-shadow:0 6px 16px rgba(0,0,0,.20); }
.fab-social .brand i{ font-size:22px; line-height:1; }
.fab-social .brand.fb{ color:#1877F2; }
.fab-social .brand.ig{ color:#E4405F; }
.fab-social .brand.x { color:#111111; }
.fab-social .fb, .fab-social .ig, .fab-social .x { background:#fff !important; }

/* THEME FIX */
:root{
  --global-header: #0d6efd;
  --global-footer: #0d6efd;
  --global-button: #0d6efd;
  --global-bg:     #f8f9fa;
}
body{ background: var(--store-bg, var(--global-bg, #f8f9fa)) !important; }
.topbar{ background: var(--store-header, var(--global-header, #0d6efd)) !important; color:#fff; }
.btn{ background: var(--store-button, var(--global-button, #0d6efd)) !important; border-color: var(--store-button, var(--global-button, #0d6efd)) !important; color:#fff; }
.btn.ghost{ background:#fff !important; color: var(--store-button, var(--global-button, #0d6efd)) !important; border:1px solid var(--store-button, var(--global-button, #0d6efd)) !important; }
.site-footer{ background: var(--store-footer, var(--global-footer, #111)) !important; color:#eee; }

/* Iconos sociales */
.fab-social a{ width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;border:3px solid #fff;box-shadow:0 8px 20px rgba(0,0,0,.2); }
.fab-social a .fa-brands{ font-size:22px; line-height:1; }
.fab-social .fb{ background:#1877F2; box-shadow:0 8px 20px rgba(24,119,242,.35); }
.fab-social .ig{ background: radial-gradient(45% 45% at 30% 107%, #fdf497 0%, #fdf497 10%, #fd5949 40%, #d6249f 60%, #285AEB 90%); box-shadow:0 8px 20px rgba(214,36,159,.35); }
.fab-social > a.tt{ background:#000 !important; }
.fab-social > a.tt svg path{ fill:#fff; }
