/* =========================================================
   Woorcoop UI — Minimal Pro (mobile-first)
   ========================================================= */

/* ----- Variables de tema ----- */
:root{
  --bg:#f7f7f8; --surface:#fff; --border:#e9e9ec; --text:#111827; --muted:#6b7280;
  --brand:#0ea5e9; --brand-600:#0284c7; --focus:0 0 0 3px rgba(14,165,233,.35);
  --success:#16a34a; --danger:#b00020; --warning:#f59e0b;
  --shadow:0 6px 18px rgba(16,24,40,.06);
  --radius:14px; --radius-sm:10px;
}
[data-theme="dark"]{
  --bg:#0b0d10; --surface:#111318; --border:#1f232a; --text:#e5e7eb; --muted:#9aa3af;
  --brand:#22d3ee; --brand-600:#06b6d4; --success:#22c55e; --danger:#ef4444; --warning:#fbbf24;
  --shadow:0 8px 22px rgba(0,0,0,.45);
}

/* ----- Reset básico ----- */
*,*::before,*::after{ box-sizing:border-box }
html,body{ height:100% }
body{
  margin:0; background:var(--bg); color:var(--text);
  font:500 15px/1.6 ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, "Helvetica Neue", Arial;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block }

/* ----- Layout ----- */
.container{ width:min(1100px,92%); margin:18px auto }

/* ----- Header / Nav ----- */
.header{ position:sticky; top:0; z-index:1000; backdrop-filter:saturate(180%) blur(8px);
  background: color-mix(in oklab, var(--surface), transparent 10%); border-bottom:1px solid var(--border); }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:10px 0 }
.nav-brand{ display:flex; align-items:center; gap:8px; font-weight:800; }
.nav-brand .badge{ font-size:12px; color:var(--muted); font-weight:700 }
.nav-menu{ display:flex; gap:8px; align-items:center; flex-wrap:wrap }
.nav-menu a{ padding:8px 12px; border-radius:10px; text-decoration:none; color:var(--text); border:1px solid transparent }
.nav-menu a:hover{ background:var(--surface); border-color:var(--border); box-shadow:var(--shadow) }
.nav-menu a.is-active{ background:var(--brand); color:#001019 }
.nav-actions{ display:flex; gap:8px; align-items:center }
#menuToggle{ display:none }

@media (max-width:760px){
  #menuToggle{
    display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px;
    border-radius:10px; border:1px solid var(--border); background:var(--surface); cursor:pointer;
  }
  .nav-menu{
    display:none; width:100%; margin-top:10px; padding:10px;
    border:1px solid var(--border); border-radius:12px; background:var(--surface);
  }
  .nav-menu.is-open{ display:flex; flex-direction:column; align-items:flex-start }
}

/* ----- Botones ----- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:10px 14px; border-radius:12px; border:1px solid var(--border);
  background:var(--surface); color:var(--text); text-decoration:none; cursor:pointer;
  transition:transform .08s, box-shadow .2s, background .2s;
}
.btn:hover{ box-shadow:var(--shadow) } .btn:active{ transform:translateY(1px) }
.btn:focus-visible{ outline:none; box-shadow:var(--focus) }
.btn-primary{ background:var(--brand); color:#001019; border-color: color-mix(in oklab, var(--brand), #000 20%) }
.btn-primary:hover{ background:var(--brand-600) }
.btn-ghost{ background:transparent; border-color:transparent; color:var(--muted) }
.btn-danger{ background:var(--danger); color:#fff; border-color:transparent }
.btn-success{ background:var(--success); color:#fff; border-color:transparent }

/* ----- Cards & Grid ----- */
.card{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:16px; box-shadow:var(--shadow) }
.grid{ display:grid; gap:14px; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)) }
.card-img{ width:100%; aspect-ratio:16/10; object-fit:cover; border-radius:12px }

/* ----- Secciones ----- */
.section.destacada h2{ margin:0 0 6px } .section.destacada p{ color:var(--muted); margin:0 }
.center{ text-align:center } .muted{ color:var(--muted) } .price{ font-weight:800 }
.pos{ color:var(--success) } .neg{ color:var(--danger) }

/* === Variantes extra === */
.btn-teal{
  background:#14b8a6; color:#001015; border:1px solid #0d9488;
}
.btn-teal:hover{ background:#0fb5a2; border-color:#0b8f86; }

/* (Opcional) Lima si algún día quieres otro color más
.btn-lime{ background:#84cc16; color:#101800; border:1px solid #65a30d; }
.btn-lime:hover{ background:#86d11f; border-color:#6faa10; }
*/


/* ----- Formularios ----- */
input, select, textarea{
  width:100%; padding:10px 12px; border-radius:10px; border:1px solid var(--border);
  background:var(--surface); color:var(--text)
}
label{ font-weight:600; color:var(--muted) }
form .row{ display:grid; gap:10px; grid-template-columns:1fr }
@media (min-width:680px){ form .row-2{ grid-template-columns:1fr 1fr } }

/* ----- Tablas ----- */
table{ width:100%; border-collapse:collapse }
th,td{ padding:10px 12px; border-bottom:1px solid var(--border) }
th{ text-align:left; color:var(--muted); font-weight:700; background: color-mix(in oklab, var(--surface), #000 3%) }
tbody tr:hover{ background: color-mix(in oklab, var(--surface), #000 2%) }

/* ----- Tabs Admin ----- */
.tab-btn{ padding:8px 12px; border:1px solid var(--border); border-radius:10px; background:var(--surface); cursor:pointer; margin-right:6px }
.tab-btn.active{ box-shadow:var(--focus); border-color: color-mix(in oklab, var(--brand), #000 20%) }
.tab-content.hidden{ display:none }

/* ----- Modales unificados ----- */
#modalCompra, #recargaModal, #consumeModal, #modalBienvenida{
  position:fixed; inset:0; display:none; align-items:center; justify-content:center; padding:20px;
  background:rgba(0,0,0,.55); z-index:9999;
}
.modal-compra-content, .modal-content, .modal-content-consume, .modal-bienvenida-contenido{
  background:var(--surface); color:var(--text); border:1px solid var(--border);
  border-radius:16px; box-shadow:var(--shadow); width:min(520px,94%); padding:18px 16px; position:relative;
}
.close, .close-modal, .close-bienvenida{
  position:absolute; right:12px; top:10px; font-size:22px; line-height:1; cursor:pointer; color:var(--muted)
}
.close:hover, .close-modal:hover, .close-bienvenida:hover{ color:var(--text) }

/* ----- Toasts (avisos) ----- */
.toast-wrap{ position:fixed; left:50%; transform:translateX(-50%); bottom:16px; z-index:10000; display:flex; flex-direction:column; gap:10px; width:min(96vw,520px) }
.toast{
  background:var(--surface); color:var(--text); border:1px solid var(--border); box-shadow:var(--shadow);
  padding:12px 14px; border-radius:12px; display:flex; align-items:center; justify-content:space-between; gap:10px;
}
.toast.ok{ border-color: color-mix(in oklab, var(--success), #000 20%) }
.toast.err{ border-color: color-mix(in oklab, var(--danger), #000 20%) }
.toast .x{ border:0; background:transparent; font-size:18px; cursor:pointer; color:var(--muted) }

/* ----- Footer ----- */
.footer{ margin:18px auto; padding:14px; color:var(--muted); text-align:center }

/* ====== WhatsApp floating button ====== */
.whatsapp-float{
  position: fixed;
  right: 14px;
  bottom: 14px;
  z-index: 9980;                /* Debajo de toasts (10000) y modales (9999) */
  width: 56px;
  height: 56px;
  border-radius: 9999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-size: 26px;              /* el emoji o ícono */
  background: var(--brand);
  color: #001019;
  border: 1px solid color-mix(in oklab, var(--brand), #000 20%);
  box-shadow: var(--shadow);
  transition: transform .12s ease, box-shadow .2s ease, background .2s ease;
}
.whatsapp-float:hover{ 
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
  background: var(--brand-600);
}
.whatsapp-float:focus-visible{
  outline: none;
  box-shadow: var(--focus);
}

/* separarlo un poco más en pantallas grandes */
@media (min-width: 768px){
  .whatsapp-float{ right: 22px; bottom: 22px; }
}

/* ===== NAV: overrides mobile-first ===== */
.header{
  position: sticky; top:0; z-index:1000;
  background: var(--surface);
  border-bottom:1px solid var(--border);
}
.nav{
  display:flex; align-items:center; gap:10px; padding:10px 0;
}
.nav-brand{ display:flex; align-items:center; text-decoration:none; color:var(--text); }
.nav-actions{ margin-left:auto; display:flex; align-items:center; gap:8px; }

/* Botón hamburguesa */
.nav-toggle{
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px; border-radius:10px;
  border:1px solid var(--border); background:var(--surface); cursor:pointer;
}

/* Menú: móvil por defecto (oculto) */
.nav-menu{
  display:none; flex-direction:column; gap:6px;
  position:absolute; left:12px; right:12px; top:58px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:12px; padding:10px; box-shadow:var(--shadow);
}
.nav-menu.is-open{ display:flex; }
.nav-menu a{
  display:block; padding:10px 12px; border-radius:10px; text-decoration:none;
  color:var(--text); border:1px solid transparent;
}
.nav-menu a:hover{ background:rgba(0,0,0,.04); border-color:var(--border); }
[data-theme="dark"] .nav-menu a:hover{ background:rgba(255,255,255,.05); }

/* Desktop */
@media (min-width: 761px){
  .nav{ gap:14px; }
  .nav-toggle{ display:none; }
  .nav-menu{
    position:static; display:flex !important; flex-direction:row; align-items:center;
    gap:8px; padding:0; border:none; box-shadow:none; background:transparent;
  }
  .nav-menu a{ padding:8px 10px; }
}

/* Enlace activo (marcado por ui.js) */
.nav-menu a.is-active{
  background: var(--brand);
  color:#001019;
  border-color: transparent;
}

/* ===== NAV 3-column layout (Menú izquierda · Toggle centro · Marca derecha) ===== */
.header{
  position: sticky; top:0; z-index:1000;
  background: var(--surface);
  border-bottom:1px solid var(--border);
}
.nav.nav-3{
  display:grid;
  grid-template-columns: auto 1fr auto; /* IZQ (toggle/menú), CENTRO (tema), DER (marca) */
  align-items:center;
  gap:10px;
  padding:10px 0;
  position:relative;
}
.nav-brand{
  text-decoration:none; color:var(--text); justify-self:end;
  font-weight:800; font-size:18px;
}
.nav-center{ display:flex; justify-content:center; }

/* Botón hamburguesa (móvil) */
.nav-toggle{
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px; border-radius:10px;
  border:1px solid var(--border); background:var(--surface); cursor:pointer;
}

/* Menú: móvil oculto por defecto, aparece bajo el header a la IZQUIERDA */
.nav-menu{
  display:none; flex-direction:column; gap:6px;
  position:absolute; left:12px; top:58px;
  min-width: 220px; width:max-content;
  background:var(--surface); border:1px solid var(--border);
  border-radius:12px; padding:10px; box-shadow:var(--shadow);
}
.nav-menu.is-open{ display:flex; }

.nav-menu a{
  display:block; padding:10px 12px; border-radius:10px; text-decoration:none;
  color:var(--text); border:1px solid transparent;
}
.nav-menu a:hover{ background:rgba(0,0,0,.04); border-color:var(--border); }
[data-theme="dark"] .nav-menu a:hover{ background:rgba(255,255,255,.05); }

/* Enlace activo (lo marca ui.js) */
.nav-menu a.is-active{
  background: var(--brand); color:#001019; border-color: transparent;
}

/* Desktop: menú siempre visible a la IZQUIERDA, botón noche al CENTRO, marca a la DERECHA */
@media (min-width: 761px){
  .nav-toggle{ display:none; }
  .nav-menu{
    position:static; display:flex !important; flex-direction:row; align-items:center;
    gap:8px; padding:0; border:none; box-shadow:none; background:transparent; min-width:0;
  }
  .nav-brand{ justify-self:end; }
  .nav-center{ justify-self:center; }
}

/* Espacio bajo header si algún contenido queda pegado */
.header + .container{ margin-top:8px; }

/* ==== NAV - Mejor contraste en modo noche ==== */
.nav-toggle{
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--border);
  font-size: 20px;
  transition: background .15s ease, border-color .15s ease, transform .1s ease;
}
.nav-toggle:hover{ 
  background: rgba(0,0,0,.05);
  transform: translateY(-1px);
}
.nav-toggle:focus-visible{ box-shadow: var(--focus); outline: none; }

[data-theme="dark"] .nav-toggle{
  background: #0f172a;            /* fondo más oscuro */
  border-color: #233047;          /* borde definido */
  color: #e6eef5;                 /* icono claro */
}
[data-theme="dark"] .nav-menu{
  background: #0b1220;
  border-color: #233047;
}
[data-theme="dark"] .nav-menu a:hover{ background: rgba(255,255,255,.06); }

/* ==== Botón naranja (Consume Points) ==== */
.btn-orange{
  display: inline-flex; align-items:center; justify-content:center;
  padding: 10px 14px; border-radius: 10px;
  border: 1px solid #e06e18;
  background: #ff7a1a;           /* naranja principal */
  color: #111;                    /* texto oscuro para contraste */
  font-weight: 700; cursor: pointer;
  box-shadow: var(--shadow);
  transition: transform .1s ease, box-shadow .2s ease, background .15s ease, border-color .15s ease;
}
.btn-orange:hover{ 
  background: #ff8a39; 
  border-color: #f08a2a;
  transform: translateY(-1px);
}
.btn-orange:active{ transform: translateY(0); }
.btn-orange:focus-visible{ outline:none; box-shadow: var(--focus); }

/* Variante grande (por si la quieres usar) */
.btn-lg{ padding: 12px 18px; font-size: 16px; }

/* ==== Lectura: resaltar botón Reclamar (fallback si no puedes tocar el HTML) ==== */
/* Si tu botón ya tiene alguno de estos selectores, tomará el estilo naranja automáticamente */
#btnReclamar, button#btnReclamar, button[name="reclamar"], .reclamar-btn{
  border: 1px solid #e06e18 !important;
  background: #ff7a1a !important;
  color: #111 !important;
  font-weight: 700 !important;
  border-radius: 10px !important;
  padding: 10px 14px !important;
  box-shadow: var(--shadow) !important;
}
#btnReclamar:hover, button#btnReclamar:hover, button[name="reclamar"]:hover, .reclamar-btn:hover{
  background: #ff8a39 !important;
  border-color: #f08a2a !important;
}
/* ===== Modal Bienvenida ===== */
#modalBienvenida{
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,.5);
  z-index: 9999;
}
.modal-bienvenida-contenido{
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 12px;
  width: 90%; max-width: 560px;
  padding: 20px 16px;
  box-shadow: var(--shadow);
  position: relative;
}
.close-bienvenida{
  position: absolute; top:10px; right:12px;
  font-size: 20px; cursor: pointer;
  background: transparent; border: 0; color: var(--text);
}
#cerrarBienvenida.btn{
  margin-top: 10px;
}

.btn-purple { 
  background:#6d28d9; border:1px solid #6d28d9; color:#fff;
}
.btn-purple:hover { background:#7c3aed; border-color:#7c3aed; }
@media (prefers-color-scheme: dark) {
  .btn-purple { background:#5b21b6; border-color:#5b21b6; color:#fff; }
  .btn-purple:hover { background:#6d28d9; border-color:#6d28d9; }
}

  /* Overlay del modal */
  #participaModal{
    position:fixed; inset:0; background:rgba(0,0,0,.5);
    display:none; align-items:center; justify-content:center; z-index:9999;
    padding:14px;
  }

  /* === Radios bonitos y alineados === */
  #participaModal .part-levels{
    display:grid; gap:10px; margin-top:8px;
  }
  #participaModal label.level{
    display:flex; align-items:center; gap:12px;
    padding:10px 12px; border:1px solid var(--border, #e5e7eb);
    border-radius:10px; cursor:pointer;
  }
  #participaModal label.level:hover{ background:rgba(2,132,199,0.04); }

  /* Radio custom */
  #participaModal .level input[type="radio"]{
    appearance:none; -webkit-appearance:none; -moz-appearance:none;
    width:18px; height:18px; border:2px solid var(--primary, #0ea5e9);
    border-radius:50%; position:relative; display:inline-block;
  }
  #participaModal .level input[type="radio"]:checked::after{
    content:""; position:absolute; left:50%; top:50%;
    width:8px; height:8px; background:var(--primary, #0ea5e9);
    border-radius:50%; transform:translate(-50%,-50%);
  }
  #participaModal .level span{ font-weight:600; }
  #participaModal .level.selected{ border-color: var(--primary, #0ea5e9); }

  /* Botón copiar deshabilitado si no hay número */
  #waCopy:disabled{ opacity:.6; cursor:not-allowed; }

.part-levels{ display:flex; gap:8px; }
.part-levels .level{
  display:flex; align-items:center; gap:8px;
  padding:10px 12px; border:1px solid var(--border,#e5e7eb);
  border-radius:10px; cursor:pointer; user-select:none;
}
.part-levels .level input{ margin:0; }
.part-levels .level.level--disabled{
  opacity:.45; filter:grayscale(0.6); pointer-events:none;
}

.brand{display:flex;align-items:center;gap:8px}
.brand-logo{width:28px;height:28px;object-fit:contain}
.brand-name{font-weight:700;letter-spacing:.2px}

/* Si el logo es oscuro y no se ve en modo noche, puedes invertirlo: */
/* @media (prefers-color-scheme: dark){ .brand-logo{ filter: invert(1); } } */


/* === Mejora visual para tarjetas de productos === */
.card.product-card { 
  overflow: hidden; 
  transition: transform .12s ease, box-shadow .2s ease;
}
.card.product-card:hover { 
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(0,0,0,.08);
}

/* Imagen de producto con fondo amable por si la imagen tiene transparencia */
.card-img{
  border: 1px solid var(--border);
  background:
    radial-gradient(120% 120% at 20% 15%, color-mix(in oklab, var(--brand), #fff 85%) 0%, transparent 45%),
    radial-gradient(140% 140% at 80% 85%, color-mix(in oklab, var(--brand), #fff 90%) 0%, transparent 50%),
    var(--surface);
  transition: transform .25s ease;
}
.card.product-card:hover .card-img { transform: scale(1.02); }

/* Títulos y precio con un poco más de presencia */
.card.product-card h3{ margin:10px 0 4px; font-weight:800; letter-spacing:.2px }
.card.product-card .price{ font-weight:900; font-variation-settings:"wght" 800 }

/* Modo oscuro: subir contraste suave del fondo de imagen */
[data-theme="dark"] .card-img{
  background:
    radial-gradient(120% 120% at 20% 15%, color-mix(in oklab, var(--brand), #0b1220 85%) 0%, transparent 45%),
    radial-gradient(140% 140% at 80% 85%, color-mix(in oklab, var(--brand), #0b1220 90%) 0%, transparent 50%),
    #0b1220;
  border-color:#1f2937;
}

/* Etiqueta “Nuevo” opcional */
.badge-new{
  position:absolute; top:10px; left:10px;
  padding:6px 10px; border-radius:999px; font-size:12px; font-weight:800;
  background:var(--brand); color:#001019; border:1px solid color-mix(in oklab, var(--brand), #000 20%);
  box-shadow: var(--shadow);
}

/* Si quieres un contenedor de imagen alternativo (object-fit contain) */
.product-media{
  width:100%; aspect-ratio: 16/10; border-radius:12px; 
  display:grid; place-items:center; overflow:hidden;
  background:
    radial-gradient(120% 120% at 20% 15%, color-mix(in oklab, var(--brand), #fff 85%) 0%, transparent 45%),
    radial-gradient(140% 140% at 80% 85%, color-mix(in oklab, var(--brand), #fff 90%) 0%, transparent 50%),
    var(--surface);
  border: 1px solid var(--border);
}
.product-media img{ width:100%; height:100%; object-fit:contain; }

/* Marco recortador para imágenes con sello (ej. Temu) */
.img-frame{
  position: relative;
  overflow: hidden;
  border-radius: 12px;
}

/* Forzamos formato cuadrado y encuadre alto para alejar el sello del borde */
.card-img.temu-hide{
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  object-position: 50% 35%; /* sube el encuadre (ajústalo si hace falta) */
  display: block;
  border-radius: 12px;
}

/* Tapamos la esquina inferior-derecha donde suele ir el logo */
.img-frame.temu::after{
  content:"";
  position:absolute;
  right:0; bottom:0;
  width: 38%;
  height: 18%;
  /* tapa con el color del fondo de la card; cambia si tu tema varía */
  background: var(--surface, #fff);
  border-top-left-radius: 10px;
  /* leve sombra para que no se note el corte */
  box-shadow: 0 0 0 1px rgba(0,0,0,.04) inset;
}

/* En modo oscuro, usa el color de surface oscuro */
@media (prefers-color-scheme: dark){
  .img-frame.temu::after{
    background: var(--surface, #111318);
  }
}
