﻿/* ══════════════════════════════════════════════════════════
   DARK MODE
   ══════════════════════════════════════════════════════════ */
[data-theme="dark"] {
  --ink:      #f0ede8;
  --soft:     #9ca3af;
  --cream:    #1e1c18;
  --paper:    #111111;
  --card-bg:  #1a1a1a;
  --shadow:    0 4px 24px rgba(0,0,0,.32);
  --shadow-lg: 0 12px 48px rgba(0,0,0,.48);
  color-scheme: dark;
}
[data-theme="dark"] body,
[data-theme="dark"] #dashboard,
[data-theme="dark"] .dashboard-wrap {
  background: #111;
  color: #f0ede8;
}
[data-theme="dark"] .modal-box,
[data-theme="dark"] .modal,
[data-theme="dark"] .cart-drawer,
[data-theme="dark"] .cust-account-drawer {
  background: #1a1a1a;
  color: #f0ede8;
}
[data-theme="dark"] .form-input,
[data-theme="dark"] .form-control {
  background: #2a2a2a;
  color: #f0ede8;
  border-color: rgba(255,255,255,.12);
}
[data-theme="dark"] .pl-row {
  border-color: rgba(255,255,255,.07);
}
[data-theme="dark"] .orders-section,
[data-theme="dark"] .sv-section,
[data-theme="dark"] .wizard-card {
  background: #1a1a1a;
  border-color: rgba(255,255,255,.07);
}
[data-theme="dark"] .orders-section-header:hover { background: #222; }
[data-theme="dark"] .ofilter-btn { background: #2a2a2a; color: #9ca3af; border-color: rgba(255,255,255,.1); }
[data-theme="dark"] .order-card  { background: #222; border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .cat-top-nav { background: transparent !important; }
[data-theme="dark"] .cat-bottom-tabs {
  background: #1a1a1a !important;
  border-color: rgba(255,255,255,.1) !important;
}
[data-theme="dark"] .cat-btab { color: rgba(255,255,255,.75); }
[data-theme="dark"] .cat-btab--active { color: var(--accent); }

[data-theme="dark"] #catalog-view { background: #111; }
[data-theme="dark"] .catalog-body,
[data-theme="dark"] .catalog-products-grid { background: #1a1a1a; }
/* Transición suave hero → catálogo en dark mode */
[data-theme="dark"] .catalog-body { border-radius: 16px 16px 0 0; border-top: none; }
[data-theme="dark"] .cat-product-card { background: #1a1a1a; border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .cat-product-code,
[data-theme="dark"] .cat-meta-text { color: #6b7280; }
[data-theme="dark"] .cat-search-wrap { background: #1e1c18; border-color: rgba(255,255,255,.1); }
[data-theme="dark"] .cat-search-input { background: transparent; color: #f0ede8; }
[data-theme="dark"] .chip { background: #1e1c18; border-color: rgba(255,255,255,.12); color: #9ca3af; }
[data-theme="dark"] .chip--active { background: var(--accent); color: #fff; border-color: var(--accent); }
[data-theme="dark"] .cat-sort-select { background: #1e1c18; color: #f0ede8; border-color: rgba(255,255,255,.12); }
[data-theme="dark"] .cat-count { color: #6b7280; }
[data-theme="dark"] .cat-product-card { background: #1a1a1a; border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .cat-more-menu,
[data-theme="dark"] .cat-view-menu.open { background: #1a1a1a; }
[data-theme="dark"] .cat-more-menu button:hover { background: #2a2a2a; }
[data-theme="dark"] .cart-drawer { background: #1a1a1a; }
[data-theme="dark"] .modal-overlay { background: rgba(0,0,0,.7); }
[data-theme="dark"] .plan-chip--gratis { background: #2a2a2a; }
/* Plan chip DENTRO del nav siempre sobre fondo accent → conserva look blanco */
[data-theme="dark"] .dash-nav .plan-chip--gratis,
[data-theme="dark"] .dash-nav .plan-chip--basico,
[data-theme="dark"] .dash-nav .plan-chip--estandar,
[data-theme="dark"] .dash-nav .plan-chip--pro,
[data-theme="dark"] .dash-nav .plan-chip--max,
[data-theme="dark"] #dash-top-bar .plan-chip--gratis,
[data-theme="dark"] #dash-top-bar .plan-chip--basico,
[data-theme="dark"] #dash-top-bar .plan-chip--estandar,
[data-theme="dark"] #dash-top-bar .plan-chip--pro,
[data-theme="dark"] #dash-top-bar .plan-chip--max { background: rgba(255,255,255,.2) !important; color: white !important; }
[data-theme="dark"] .sv-card { background: transparent; }
[data-theme="dark"] .sv-bar-fill--zero { background: rgba(255,255,255,.08); }
[data-theme="dark"] .bulk-bar { background: #1e1c18; border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .wizard-step--pending { opacity:.45; }
[data-theme="dark"] input, [data-theme="dark"] textarea, [data-theme="dark"] select {
  background: #2a2a2a; color: #f0ede8; border-color: rgba(255,255,255,.12);
}

/* ── Dark mode — Landing page ── */
[data-theme="dark"] .nav,
[data-theme="dark"] .nav--white { background: #111; border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .btn-ghost { background: transparent; color: #f0ede8; border-color: rgba(255,255,255,.18); }
[data-theme="dark"] .btn-ghost:hover { background: #1e1c18; border-color: rgba(255,255,255,.35); }
[data-theme="dark"] .btn-secondary { background: #f0ede8; color: #111; }
[data-theme="dark"] .btn-secondary:hover { background: #fff; }
[data-theme="dark"] .badge { background: #1e1c18; border-color: rgba(255,255,255,.12); color: #f0ede8; }
[data-theme="dark"] .hero-proof-text { color: #9ca3af; }
[data-theme="dark"] .hero-proof-text strong { color: #f0ede8; }
[data-theme="dark"] .features-strip { background: #1a1a1a; border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .feature-item { border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .mock-header,
[data-theme="dark"] .mock-card { background: #2a2a2a; }
[data-theme="dark"] .mock-chip { background: #2a2a2a; border-color: rgba(255,255,255,.1); color: #f0ede8; }
[data-theme="dark"] .mock-bar { background: #1a1a1a; border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .how-step { background: #1a1a1a; border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .store-spotlight { background: transparent; }
[data-theme="dark"] .spotlight-card { background: #1a1a1a; border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .spotlight-prod { background: #222; border-color: rgba(255,255,255,.06); }
[data-theme="dark"] .spotlight-prod-name { color: #d1cdc8; }
[data-theme="dark"] .spotlight-prod-price { color: #9ca3af; }

/* ── Dark mode — Login/Register tabs ── */
[data-theme="dark"] .tab.active { background: #2a2a2a; color: #f0ede8; box-shadow: 0 2px 8px rgba(0,0,0,.3); }

/* ── Dark mode — Dashboard menú ⋮ ── */
/* Dark mode — Navs del dashboard mantienen color accent */
[data-theme="dark"] .dash-nav,
[data-theme="dark"] #dash-top-bar { background: color-mix(in srgb, var(--accent), black 18%) !important; }

[data-theme="dark"] .dash-more-menu { background: #1a1a1a; border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .dash-more-menu button:hover { background: #222; }
[data-theme="dark"] .dash-more-sep { background: rgba(255,255,255,.08); }
[data-theme="dark"] .dash-more-verify-row input { background: #222; color: #f0ede8; border-color: rgba(255,255,255,.12); }
[data-theme="dark"] .dash-more-verify-row input:focus { background: #2a2a2a; border-color: var(--accent); }

/* ── Dark mode — Panel de notificaciones ── */
[data-theme="dark"] .notif-panel { background: #1a1a1a; border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .notif-panel-head { background: #1a1a1a; border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .notif-item { border-color: rgba(255,255,255,.06); }
[data-theme="dark"] .notif-item-icon { background: #2a2a2a; }
[data-theme="dark"] .notif-item--orange .notif-item-icon { background: rgba(245,158,11,.15); }
[data-theme="dark"] .notif-item--red    .notif-item-icon { background: rgba(239,68,68,.15); }
[data-theme="dark"] .notif-item--yellow .notif-item-icon { background: rgba(234,179,8,.15); }
[data-theme="dark"] .notif-item--violet .notif-item-icon { background: rgba(124,58,237,.15); }
[data-theme="dark"] .notif-item--blue   .notif-item-icon { background: rgba(37,99,235,.15); }

/* ── Dark mode — Marketing panel ── */
[data-theme="dark"] .mkt-item { background: #1e1c18; border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .mkt-item:active { background: #2a2a2a; }

/* ── Dark mode — Lista de productos (contenedor) ── */
[data-theme="dark"] .products-grid { background: #1a1a1a; border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .pl-row { border-color: rgba(255,255,255,.06); }
[data-theme="dark"] .pl-row:hover .pl-main { background: rgba(255,255,255,.03); }
[data-theme="dark"] .pl-sub-dot { color: rgba(255,255,255,.2); }
[data-theme="dark"] .pl-sub-cat { color: rgba(255,255,255,.42); }
[data-theme="dark"] .pl-btn { color: rgba(255,255,255,.25); }
[data-theme="dark"] .pl-btn:hover { background: rgba(255,255,255,.07); color: rgba(255,255,255,.75); }
[data-theme="dark"] .pl-btn--vis-on { color: #4ade80; }
[data-theme="dark"] .pl-btn--vis-on:hover { background: rgba(74,222,128,.1); color: #4ade80; }
[data-theme="dark"] .pl-btn--may-on { color: #2dd4bf; }
[data-theme="dark"] .pl-btn--del:hover { background: rgba(220,38,38,.12); color: #f87171; }
[data-theme="dark"] .pl-edit-btn { color: rgba(255,255,255,.22); }
[data-theme="dark"] .pl-edit-btn:hover { background: rgba(37,99,235,.12); color: #93c5fd; }
[data-theme="dark"] .pl-name-text { color: #e8e4df; }
[data-theme="dark"] .pl-stock--ok  { background: rgba(22,163,74,.18); color: #4ade80; border-color: rgba(22,163,74,.25); }
[data-theme="dark"] .pl-stock--low { background: rgba(217,119,6,.18); color: #fbbf24; border-color: rgba(217,119,6,.25); }
[data-theme="dark"] .pl-stock--out { background: rgba(225,29,72,.18); color: #fb7185; border-color: rgba(225,29,72,.25); }

/* ── Dark mode — Tarjeta de producto (pc-*) ── */
[data-theme="dark"] .product-card { background: #1a1a1a; border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .pc-state-col { background: rgba(255,255,255,.025); }
[data-theme="dark"] .pc-sep { background: rgba(255,255,255,.07); }
[data-theme="dark"] .pc-accordion { border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .pc-toggle-row:hover { background: rgba(255,255,255,.06); }
[data-theme="dark"] .pc-t-icon--blue   { background: rgba(37,99,235,.2); color: #93c5fd; }
[data-theme="dark"] .pc-t-icon--amber  { background: rgba(245,158,11,.2); color: #fcd34d; }
[data-theme="dark"] .pc-t-icon--yellow { background: rgba(234,179,8,.2);  color: #fde047; }
[data-theme="dark"] .pc-active-pill--blue   { background: rgba(37,99,235,.2);  color: #93c5fd; }
[data-theme="dark"] .pc-active-pill--amber  { background: rgba(245,158,11,.2); color: #fcd34d; }
[data-theme="dark"] .pc-active-pill--violet { background: rgba(124,58,237,.2); color: #c4b5fd; }
[data-theme="dark"] .pc-active-pill--teal   { background: rgba(13,148,136,.2); color: #5eead4; }
[data-theme="dark"] .pc-active-pill--rose   { background: rgba(225,29,72,.2);  color: #fb7185; }
[data-theme="dark"] .pc-tag-icon--violet { background: rgba(124,58,237,.2); color: #c4b5fd; }
[data-theme="dark"] .pc-tag-icon--teal   { background: rgba(13,148,136,.2); color: #5eead4; }
[data-theme="dark"] .pc-tag-icon--rose   { background: rgba(225,29,72,.2);  color: #fb7185; }
[data-theme="dark"] .pc-tag-icon--amber  { background: rgba(245,158,11,.2); color: #fcd34d; }
[data-theme="dark"] .pc-act-btn { background: #1e1c18; border-color: rgba(255,255,255,.1); color: #d1cdc8; }
[data-theme="dark"] .pc-act-btn:hover { background: #2a2a2a; }
[data-theme="dark"] .pc-act-btn--edit:hover { background: rgba(37,99,235,.2); border-color: rgba(37,99,235,.4); }
[data-theme="dark"] .pc-act-btn--del:hover  { background: rgba(239,68,68,.2); border-color: rgba(239,68,68,.4); }

/* ── Dark mode — Onboarding wizard ── */
[data-theme="dark"] .wizard-step--active { background: color-mix(in srgb, var(--accent) 10%, #1a1a1a); }
[data-theme="dark"] .wizard-step-circle { background: rgba(255,255,255,.08); }
[data-theme="dark"] .wizard-progress-track { background: rgba(255,255,255,.08); }
[data-theme="dark"] .wizard-step-done-tag { background: rgba(22,163,74,.2); color: #4ade80; }

/* ── Dark mode — Settings ── */
[data-theme="dark"] .settings-select { background: #2a2a2a; color: #f0ede8; border-color: rgba(255,255,255,.12); }
[data-theme="dark"] .settings-select-wrap { background: #2a2a2a; border-color: rgba(255,255,255,.12); }
[data-theme="dark"] .settings-select-wrap:focus-within { border-color: var(--accent); background: #2a2a2a; }
[data-theme="dark"] .config-section { border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .config-sep { background: rgba(255,255,255,.07); }

/* ── Dark mode — Plan chips ── */
[data-theme="dark"] .plan-chip--basico   { background: rgba(37,99,235,.2);   color: #93c5fd; }
[data-theme="dark"] .plan-chip--estandar { background: rgba(245,158,11,.2);  color: #fcd34d; }
[data-theme="dark"] .plan-chip--pro      { background: rgba(124,58,237,.2);  color: #c4b5fd; }
[data-theme="dark"] .plan-chip--max      { background: rgba(201,168,76,.2);  color: #fde68a; }

/* ── Dark mode — Bulk upload screen ── */
[data-theme="dark"] .bulk-cat-select { background: #2a2a2a; color: #f0ede8; border-color: rgba(255,255,255,.12); }
[data-theme="dark"] .bulk-delete-btn { border-color: rgba(239,68,68,.3) !important; color: #fb7185 !important; }
[data-theme="dark"] .bulk-delete-btn:hover { background: rgba(239,68,68,.18) !important; }

/* ── Dark mode — Inventario / sub-pantallas ── */
[data-theme="dark"] .pl-settings-dropdown { background: #1c1a17; border-color: rgba(255,255,255,.1); }
[data-theme="dark"] .pl-settings-dropdown::before { background: rgba(255,255,255,.16); }
[data-theme="dark"] .plsd-may-title { color: #e5e1d8; }
[data-theme="dark"] .pl-wholesale-label { color: #9ca3af; }
[data-theme="dark"] .plsd-nav-item { color: #9ca3af; }
[data-theme="dark"] .plsd-nav-item:hover { background: #1e1c18; color: #f0ede8; }
[data-theme="dark"] .plsd-nav-item--active { background: rgba(124,58,237,.2); color: #c4b5fd; }

/* ── Dark mode — Catálogo público: producto detalle ── */
[data-theme="dark"] .pd-carousel-nav:hover { background: #2a2a2a; }
[data-theme="dark"] .prod-page-nav { border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .prod-page-nav--solid { background: rgba(17,17,17,.92); }
[data-theme="dark"] #pd-more-menu { background: #1a1a1a; border-color: rgba(255,255,255,.08); }
[data-theme="dark"] #pd-more-menu button:hover { background: #222; }

/* ── Dark mode — Botón "Agregar al carrito" en catálogo ── */
[data-theme="dark"] .add-cart-btn { background: var(--accent); color: #fff; }
[data-theme="dark"] .cat-card-btn { background: #1e1c18; border-color: rgba(255,255,255,.1); color: #f0ede8; }
[data-theme="dark"] .cat-card-btn:hover { background: #2a2a2a; }

/* ── Dark mode — Carrito ── */
[data-theme="dark"] .cart-item { border-color: rgba(255,255,255,.06); }
[data-theme="dark"] .cart-name-modal { background: #1a1a1a; }
[data-theme="dark"] #cart-name-modal { background: #1a1a1a; }

/* ── Dark mode — Shared cart banner ── */
[data-theme="dark"] #cart-shared-banner { background: #1e1c18; border-color: rgba(255,255,255,.1); }

/* ── Dark mode — Drawer "Mis guardados" ── */
[data-theme="dark"] #saved-drawer { background: #1a1a1a; }
[data-theme="dark"] .saved-drawer-header { border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .saved-drawer-close { background: rgba(255,255,255,.08); color: rgba(255,255,255,.5); }
[data-theme="dark"] .saved-drawer-close:hover { background: rgba(255,255,255,.15); color: #fff; }
[data-theme="dark"] .saved-card { background: #222; border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .saved-card-img { background: #2a2a2a; }
[data-theme="dark"] .saved-card-name { color: rgba(255,255,255,.9); }
[data-theme="dark"] .saved-empty-title { color: rgba(255,255,255,.85); }

/* ── Dark mode — Soporte técnico ── */
[data-theme="dark"] .support-msg--me .support-bubble { background: color-mix(in srgb, var(--accent) 85%, #000); }
[data-theme="dark"] .support-msg--them .support-bubble { background: #2a2a2a; }

/* ── Dark mode — Galería ── */
[data-theme="dark"] .gallery-lightbox { background: rgba(0,0,0,.95); }
[data-theme="dark"] .gallery-item { background: #1e1c18; border-color: rgba(255,255,255,.07); }

/* ── Dark mode — Input con prefijo (precio, etc.) ── */
[data-theme="dark"] .price-input-prefix,
[data-theme="dark"] .input-prefix { background: #1e1c18; border-color: rgba(255,255,255,.12); color: #9ca3af; }
[data-theme="dark"] .price-input-wrap { border-color: rgba(255,255,255,.12); }
[data-theme="dark"] .price-input-wrap input { border: none; }

/* ── Dark mode — Variant matrix inputs ── */
[data-theme="dark"] .variant-matrix-input { background: #2a2a2a; border-color: rgba(255,255,255,.12); color: #f0ede8; }
[data-theme="dark"] .variant-matrix-row-hdr { color: #d1cdc8; }

/* ── Dark mode — QR modal ── */
[data-theme="dark"] .qr-image { background: #fff; border-color: rgba(255,255,255,.1); }

/* ── Dark mode — Página de producto ── */
[data-theme="dark"] #product-page { background: #111; }
[data-theme="dark"] .prod-page-nav { background: #111; border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .prod-page-back-btn:hover { background: rgba(255,255,255,.08); }
[data-theme="dark"] .pd-info-col { background: #111; color: #f0ede8; }
[data-theme="dark"] .pd-footer-bar { background: rgba(17,17,17,.94); border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .pd-share { color: #9ca3af; }
[data-theme="dark"] .pd-share:hover { color: #f0ede8; background: rgba(255,255,255,.07); }
[data-theme="dark"] .pd-color-chip { border-color: rgba(255,255,255,.15); }
[data-theme="dark"] .pd-color-chip--selected { border-color: var(--accent); }

/* ── Dark mode — Tab switcher (Lista/Inventario/Masiva) ── */
[data-theme="dark"] .prod-sub-toggle { background: #1e1c18; }
[data-theme="dark"] .prod-sub-btn { color: #6b7280; }
[data-theme="dark"] .prod-sub-btn svg { stroke: #6b7280; }
[data-theme="dark"] .prod-sub-btn--active {
  background: color-mix(in srgb, var(--accent) 18%, #1a1a1a);
  color: var(--accent);
  box-shadow: 0 1px 4px color-mix(in srgb, var(--accent) 25%, transparent);
}
[data-theme="dark"] .prod-sub-btn--teal.prod-sub-btn--active   { background: rgba(13,148,136,.2);  color: #5eead4; }
[data-theme="dark"] .prod-sub-btn--teal.prod-sub-btn--active svg   { stroke: #5eead4; }
[data-theme="dark"] .prod-sub-btn--violet.prod-sub-btn--active { background: rgba(124,58,237,.2); color: #c4b5fd; }
[data-theme="dark"] .prod-sub-btn--violet.prod-sub-btn--active svg { stroke: #c4b5fd; }
[data-theme="dark"] .prod-sub-btn--amber.prod-sub-btn--active  { background: rgba(245,158,11,.2); color: #fcd34d; }
[data-theme="dark"] .prod-sub-btn--amber.prod-sub-btn--active svg  { stroke: #fcd34d; }
[data-theme="dark"] .prod-sub-btn--rose.prod-sub-btn--active   { background: rgba(225,29,72,.2);  color: #fb7185; }
[data-theme="dark"] .prod-sub-btn--rose.prod-sub-btn--active svg   { stroke: #fb7185; }

/* ── Dark mode — Botones de ratio (Vertical/Cuadrada) ── */
[data-theme="dark"] .ratio-btn { background: #1e1c18; border-color: rgba(255,255,255,.12); color: #9ca3af; }
[data-theme="dark"] .ratio-btn:hover { background: #2a2a2a; border-color: rgba(255,255,255,.2); }
[data-theme="dark"] .ratio-btn--active { background: color-mix(in srgb, var(--accent) 15%, #1a1a1a); border-color: var(--accent); color: var(--accent); }
[data-theme="dark"] .ratio-preview { background: rgba(255,255,255,.2); }

/* ── Dark mode — Sub-headers de pantallas internas ── */
[data-theme="dark"] .page-screen-header,
[data-theme="dark"] .product-screen-header {
  background: #1a1a1a;
  border-color: rgba(255,255,255,.08);
}
[data-theme="dark"] .page-screen-title { color: #f0ede8; }
[data-theme="dark"] .page-back-btn { color: #f0ede8; }
[data-theme="dark"] .page-back-btn:hover { background: rgba(255,255,255,.08); }

/* ── Dark mode — Marketing tabs (mkt-nav-btn) ── */
[data-theme="dark"] .mkt-nav-btn {
  background: #1e1c18;
  border-color: rgba(255,255,255,.1);
  color: #6b7280;
}
[data-theme="dark"] .mkt-nav-btn svg { stroke: #6b7280; }
[data-theme="dark"] .mkt-nav-btn.mkt-nav-btn--active {
  background: color-mix(in srgb, var(--accent) 15%, #1a1a1a);
  border-color: color-mix(in srgb, var(--accent) 45%, transparent);
  color: var(--accent);
}
[data-theme="dark"] .mkt-nav-btn.mkt-nav-btn--active svg { stroke: var(--accent); }

/* ── Dark mode — Colecciones en catálogo público ── */
[data-theme="dark"] #cat-collections-section { background: #1a1a1a; }
[data-theme="dark"] .col-card { background: #222; box-shadow: 0 2px 8px rgba(0,0,0,.3); }
[data-theme="dark"] .col-card-name { color: #d1cdc8; }

/* ── Dark mode — Collection items (admin/dashboard) ── */
[data-theme="dark"] .collection-item { background: #1e1c18; border-color: rgba(255,255,255,.07); }

/* ── Dark mode — Promo / Cupones ── */
[data-theme="dark"] .promo-card,
[data-theme="dark"] .coupon-card { background: #1e1c18; border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .coupon-code-badge { background: #2a2a2a; color: #f0ede8; border-color: rgba(255,255,255,.1); }

/* ── Dark mode — Checkout / carrito nombre ── */
[data-theme="dark"] .cart-name-input-wrap input { background: #2a2a2a; border-color: rgba(255,255,255,.12); color: #f0ede8; }

/* ── Dark mode — Categorías tags ── */
[data-theme="dark"] .cat-tag-chip { background: #1e1c18; border-color: rgba(255,255,255,.1); color: #d1cdc8; }

/* ══════════════════════════════════════════════════════════
   DRAG & DROP — ordenar productos
   ══════════════════════════════════════════════════════════ */
.pl-row { cursor: grab; user-select: none; transition: opacity .15s, box-shadow .15s; }
.pl-row:active { cursor: grabbing; }
.pl-row--dragging { opacity: .45; }
.pl-row--drag-over {
  box-shadow: 0 0 0 2px var(--accent);
  background: color-mix(in srgb, var(--accent) 5%, #fff);
}
/* Ocultar handle cuando está en modo bulk */
.products-grid--bulk .pl-row { cursor: default; }

/* ══════════════════════════════════════════════════════════
   BULK ACTIONS BAR
   ══════════════════════════════════════════════════════════ */
.bulk-bar {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 10px 14px;
  background: #fffbf5;
  border: 1.5px solid rgba(15,14,12,.1);
  border-radius: 12px;
  margin-bottom: 10px;
}
.bulk-bar-left { display: flex; align-items: center; gap: 8px; }
.bulk-count { font-size: .82rem; font-weight: 600; color: var(--soft); }
.bulk-bar-actions { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; flex: 1; }
.bulk-cat-select {
  font-size: .78rem; padding: 5px 8px; border-radius: 8px;
  border: 1px solid rgba(15,14,12,.15); background: #fff; cursor: pointer;
}
.bulk-delete-btn { color: #b91c1c !important; border-color: rgba(185,28,28,.25) !important; }
.bulk-delete-btn:hover { background: #fee2e2 !important; }
.bulk-action-btn:disabled { opacity: .35; cursor: not-allowed; }
.bulk-exit-btn {
  margin-left: auto; background: none; border: none;
  font-size: 1rem; color: var(--soft); cursor: pointer; padding: 4px 8px;
}
/* Checkboxes en modo selección */
.bulk-check-wrap {
  display: none; width: 20px; flex-shrink: 0; cursor: pointer;
}
.products-grid--bulk .bulk-check-wrap { display: flex; align-items: center; justify-content: center; }
.bulk-check { width: 16px; height: 16px; cursor: pointer; accent-color: var(--accent); }

/* ══════════════════════════════════════════════════════════
   QR MODAL
   ══════════════════════════════════════════════════════════ */
.qr-modal-body {
  padding: 20px 24px 28px;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
}
.qr-image {
  width: 220px; height: 220px;
  border: 1px solid rgba(15,14,12,.1);
  border-radius: 12px; padding: 8px;
  background: #fff;
}
.qr-store-name { font-weight: 700; font-size: .95rem; }
.qr-hint { font-size: .78rem; color: var(--soft); text-align: center; margin: 0; }
.qr-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }

/* ══════════════════════════════════════════════════════════
   ONBOARDING WIZARD
   ══════════════════════════════════════════════════════════ */
.wizard-card {
  background: #fff;
  border: 1px solid rgba(15,14,12,.08);
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 16px;
}
.wizard-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 8px;
}
.wizard-header-left { display: flex; flex-direction: column; gap: 2px; }
.wizard-title { font-weight: 700; font-size: .95rem; }
.wizard-sub { font-size: .75rem; color: var(--soft); }
.wizard-dismiss {
  background: none; border: none; font-size: 1.1rem;
  color: var(--soft); cursor: pointer; padding: 4px 6px;
}
.wizard-progress-track {
  height: 3px; background: rgba(15,14,12,.08); margin: 0 16px;
}
.wizard-progress-fill {
  height: 100%; background: var(--accent);
  border-radius: 2px; transition: width .4s ease;
}
.wizard-steps { padding: 10px 16px 16px; display: flex; flex-direction: column; gap: 8px; }
.wizard-step {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 10px;
  transition: background .12s;
}
.wizard-step--active { background: color-mix(in srgb, var(--accent) 6%, #fff); }
.wizard-step--pending { opacity: .55; }
.wizard-step--done { opacity: 1; }
.wizard-step-circle {
  width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  background: rgba(15,14,12,.06);
  transition: background .2s;
}
.wizard-step--done   .wizard-step-circle { background: var(--accent); color: #fff; }
.wizard-step--active .wizard-step-circle { background: color-mix(in srgb, var(--accent) 15%, #fff); font-size: 1.1rem; }
.wizard-step-body { flex: 1; }
.wizard-step-label { font-weight: 600; font-size: .88rem; }
.wizard-step-sub { font-size: .75rem; color: var(--soft); margin-top: 1px; }
.wizard-step-cta {
  flex-shrink: 0; font-size: .78rem; font-weight: 700;
  color: var(--accent); background: none; border: 1.5px solid var(--accent);
  border-radius: 20px; padding: 4px 12px; cursor: pointer;
  transition: background .12s, color .12s;
}
.wizard-step-cta:hover { background: var(--accent); color: #fff; }
.wizard-step-done-tag {
  flex-shrink: 0; font-size: .72rem; font-weight: 600;
  color: #15803d; background: #dcfce7; border-radius: 20px; padding: 3px 9px;
}

/* ══════════════════════════════════════════════════════════
   VARIANTES COMBINADAS — editor (products.js)
   ══════════════════════════════════════════════════════════ */
.variant-dim-btn {
  font-size: .78rem; color: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 30%, transparent);
}
.variant-dim2-header {
  display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
}
.variant-dim2-name-input { flex: 1; font-size: .85rem; }
.variant-dim2-hint { font-size: .78rem; color: var(--soft); flex-shrink: 0; }
.variant-matrix-wrap { margin-top: 10px; }
.variant-matrix-label {
  font-size: .78rem; font-weight: 600; color: var(--soft); margin-bottom: 8px;
}
.variant-matrix-grid {
  display: grid; gap: 4px;
}
.variant-matrix-hdr {
  font-size: .72rem; font-weight: 700; color: var(--soft); text-align: center;
  padding: 4px 2px;
}
.variant-matrix-row-hdr {
  font-size: .78rem; font-weight: 600; color: var(--ink);
  display: flex; align-items: center; padding-right: 6px;
}
.variant-matrix-input {
  width: 100%; min-width: 44px; max-width: 80px;
  padding: 5px 6px; border: 1px solid rgba(15,14,12,.15);
  border-radius: 6px; font-size: .78rem; text-align: center;
  background: #fafaf9;
}
.variant-matrix-hint { font-size: .78rem; color: var(--soft); padding: 6px 0; }

/* Catálogo — selectores de variante */
.variant-selectors { display: flex; flex-direction: column; gap: 12px; }
.variant-sel-group { display: flex; flex-direction: column; gap: 6px; }
.variant-sel-label { font-size: .78rem; font-weight: 700; color: var(--soft); }
.variant-chips { display: flex; flex-wrap: wrap; gap: 6px; }

/* ══════════════════════════════════════════════════════════
   SKELETON LOADERS (genérico)
   ══════════════════════════════════════════════════════════ */
@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.skel {
  border-radius: 8px;
  background: linear-gradient(90deg, #f0ede8 25%, #e8e4dd 50%, #f0ede8 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
}
[data-theme="dark"] .skel {
  background: linear-gradient(90deg, #2a2a2a 25%, #333 50%, #2a2a2a 75%);
  background-size: 200% 100%;
}

/* ══════════════════════════════════════════════════════════
   TOAST DE ACTUALIZACIÓN
   ══════════════════════════════════════════════════════════ */
.update-toast {
  position: fixed;
  bottom: 16px; right: 16px; left: auto; transform: none;
  z-index: 9999;
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px 7px 12px;
  background: rgba(26,26,26,.92); color: #fff;
  border-radius: 999px;
  box-shadow: 0 2px 12px rgba(0,0,0,.22);
  font-size: .78rem; font-weight: 500;
  max-width: calc(100vw - 28px);
  backdrop-filter: blur(8px);
  animation: ut-in .25s ease;
}
@keyframes ut-in {
  from { opacity:0; transform: translateY(8px); }
  to   { opacity:1; transform: translateY(0); }
}
.update-toast-btn {
  background: var(--accent); color: #fff;
  border: none; border-radius: 20px;
  padding: 4px 10px; font-size: .73rem; font-weight: 700;
  cursor: pointer; white-space: nowrap;
  transition: opacity .12s;
}
.update-toast-btn:hover { opacity: .88; }
.update-toast-close {
  background: none; border: none; color: rgba(255,255,255,.5);
  font-size: 1rem; cursor: pointer; padding: 0 2px; line-height: 1;
}
.update-toast-close:hover { color: #fff; }

/* ── GRABADOR DE REELS ── */
.reel-record-overlay {
  display: none;
  position: fixed; inset: 0; z-index: 1200;
  background: #000;
  flex-direction: column;
}
.reel-record-overlay > div {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
}
.reel-record-video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
/* Capa de UI sobre el video */
.reel-record-ui {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  pointer-events: none;
}
.reel-record-ui > * { pointer-events: auto; }
.reel-record-close {
  position: absolute; top: max(16px, env(safe-area-inset-top, 16px)); left: 16px;
  background: rgba(0,0,0,.45); border: none; border-radius: 50%;
  width: 42px; height: 42px; display: flex; align-items: center; justify-content: center;
  color: #fff; cursor: pointer;
}
.reel-record-bottom {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 32px 24px max(28px, env(safe-area-inset-bottom, 28px));
  background: linear-gradient(to top, rgba(0,0,0,.75), transparent);
  display: flex; flex-direction: column; align-items: center; gap: 20px;
}
.reel-record-hint {
  color: rgba(255,255,255,.8); font-size: .9rem; font-weight: 600;
  letter-spacing: .03em; text-shadow: 0 1px 6px rgba(0,0,0,.5);
}
.reel-duration-btns { display: flex; gap: 20px; }
.reel-dur-btn {
  width: 80px; height: 80px; border-radius: 50%;
  background: rgba(255,255,255,.18); backdrop-filter: blur(8px);
  border: 2px solid rgba(255,255,255,.5); color: #fff; cursor: pointer;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2px; transition: background .15s, transform .12s;
}
.reel-dur-btn:active { transform: scale(.92); background: rgba(255,255,255,.3); }
.reel-dur-num  { font-size: 1.8rem; font-weight: 800; line-height: 1; }
.reel-dur-label { font-size: .72rem; font-weight: 600; opacity: .8; }

/* Indicador REC */
.reel-rec-indicator {
  position: absolute; top: max(18px, env(safe-area-inset-top, 18px)); left: 50%; transform: translateX(-50%);
  display: flex; align-items: center; gap: 6px;
  background: rgba(0,0,0,.5); border-radius: 20px; padding: 5px 14px;
  color: #fff; font-size: .78rem; font-weight: 700; letter-spacing: .1em;
}
.reel-rec-dot {
  width: 9px; height: 9px; border-radius: 50%; background: #ef4444;
  animation: reel-rec-pulse 1s ease-in-out infinite;
}
@keyframes reel-rec-pulse { 0%,100%{ opacity:1 } 50%{ opacity:.3 } }

/* Círculo de progreso */
.reel-countdown-ring-wrap {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
}
.reel-countdown-ring { width: 140px; height: 140px; transform: rotate(-90deg); }
.reel-ring-track {
  fill: none; stroke: rgba(255,255,255,.2); stroke-width: 8;
}
.reel-ring-fill {
  fill: none; stroke: #fff; stroke-width: 8;
  stroke-linecap: round;
  stroke-dasharray: 314.16;
  stroke-dashoffset: 0;
}
.reel-countdown-num {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  font-size: 3rem; font-weight: 900; color: #fff;
  text-shadow: 0 2px 16px rgba(0,0,0,.6);
  font-variant-numeric: tabular-nums;
}

/* Fase de revisión */
.reel-rotate-btn {
  width: 100%; padding: 13px; border: 1.5px solid rgba(255,255,255,.45);
  border-radius: 14px; background: rgba(255,255,255,.12); backdrop-filter: blur(8px);
  color: #fff; font-size: 1rem; font-weight: 700; cursor: pointer; margin-bottom: 10px;
  transition: background .15s, transform .12s;
}
.reel-rotate-btn:active { transform: scale(.97); }
.reel-rotate-btn--on { background: rgba(255,255,255,.3); border-color: #fff; }
#reel-recorded-video.reel-preview-rotated {
  position: absolute; top: 50%; left: 50%;
  width: 100dvh; height: 100vw;
  transform: translate(-50%, -50%) rotate(-90deg);
  object-fit: cover;
}
.reel-review-btns { display: flex; gap: 14px; width: 100%; margin-top: 4px; }
.reel-review-btn {
  flex: 1; padding: 14px; border: none; border-radius: 14px;
  font-size: 1rem; font-weight: 700; cursor: pointer;
  background: #fff; color: #111;
  transition: opacity .15s, transform .12s;
}
.reel-review-btn:active { transform: scale(.97); }
.reel-review-btn--ghost {
  background: rgba(255,255,255,.18); backdrop-filter: blur(8px);
  border: 1.5px solid rgba(255,255,255,.4); color: #fff;
}

/* ── Ocultar vistas del catálogo según ajustes del vendedor ── */
body.view-no-gallery #view-gallery-btn                        { display: none !important; }
body.view-no-gallery #cat-menu-view-gallery-btn               { display: none !important; }
body.view-no-gallery #cat-view-menu [data-view="gallery"]     { display: none !important; }
body.view-no-stories #view-story-btn                          { display: none !important; }
body.view-no-stories #cat-view-menu [data-view="story"]       { display: none !important; }
body.view-no-reels   #view-reel-btn                           { display: none !important; }
body.view-no-reels   #cat-view-menu [data-view="reel"]        { display: none !important; }

/* ── Picker fuente de imagen ── */
.img-picker-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.5); display: flex;
  align-items: flex-end; justify-content: center;
  animation: fadeIn .15s ease;
}
.img-picker-sheet {
  width: 100%; max-width: 480px;
  background: #fff; border-radius: 20px 20px 0 0;
  padding: 20px 16px 32px; display: flex; flex-direction: column; gap: 10px;
}
.img-picker-title {
  font-size: 1rem; font-weight: 700; color: #111;
  text-align: center; padding-bottom: 6px;
}
.img-picker-btn {
  display: flex; align-items: center; gap: 14px;
  width: 100%; padding: 14px 16px; border: 1.5px solid rgba(15,14,12,.10);
  border-radius: 14px; background: var(--paper); cursor: pointer;
  text-align: left; transition: background .12s;
}
.img-picker-btn:active { background: #f0f0f0; }
.img-picker-icon { font-size: 1.6rem; flex-shrink: 0; }
.img-picker-label { font-size: .97rem; font-weight: 700; color: #111; }
.img-picker-sub   { font-size: .8rem; color: #888; margin-top: 1px; }
.img-picker-cancel {
  margin-top: 4px; width: 100%; padding: 14px;
  border: none; border-radius: 14px; background: #f2f2f2;
  font-size: 1rem; font-weight: 600; color: #555; cursor: pointer;
}
.img-picker-cancel:active { background: #e5e5e5; }

/* Dos botones de acción en la lista */
.reels-actions-row {
  display: flex; gap: 10px; margin: 12px 16px;
}
.reels-actions-row .reels-upload-area {
  flex: 1; margin: 0;
}

/* ── GESTIÓN DE REELS (dashboard Marketing) ── */
.reels-upload-area {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 4px; padding: 20px; margin: 12px 16px;
  border: 2px dashed #e0dbd3; border-radius: 14px;
  cursor: pointer; transition: border-color .15s, background .15s;
  background: var(--paper);
}
.reels-upload-area:hover { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 5%, #fff); }
.reels-upload-icon  { font-size: 1.8rem; }
.reels-upload-label { font-weight: 700; font-size: .95rem; color: var(--ink); }
.reels-upload-hint  { font-size: .76rem; color: #a8a49e; }
.reels-empty { text-align: center; color: #a8a49e; font-size: .88rem; padding: 16px 24px 24px; line-height: 1.6; }

.reel-mgmt-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 16px; border-bottom: 1px solid #f0ede8;
}
.reel-mgmt-row:last-child { border-bottom: none; }
.reel-mgmt-thumb {
  width: 64px; height: 80px; object-fit: cover;
  border-radius: 8px; background: #111; flex-shrink: 0;
  cursor: pointer;
}
.reel-mgmt-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 6px; }
.reel-mgmt-title {
  width: 100%; border: 1px solid #e8e5e0; border-radius: 8px;
  padding: 6px 10px; font-size: .88rem; font-family: inherit;
  color: var(--ink); background: #fff;
}
.reel-mgmt-title:focus { outline: none; border-color: var(--accent); }
.reel-mgmt-tag { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.reel-tag-chip {
  background: color-mix(in srgb, var(--accent) 10%, #fff);
  color: var(--accent); border: 1px solid color-mix(in srgb, var(--accent) 25%, transparent);
  border-radius: 20px; padding: 3px 10px; font-size: .78rem; font-weight: 600;
}
.reel-tag-btn {
  background: var(--cream); border: 1px solid rgba(15,14,12,.10); border-radius: 20px;
  padding: 4px 12px; font-size: .78rem; cursor: pointer; color: var(--ink);
  transition: background .12s;
}
.reel-tag-btn:hover { background: #edeae5; }
.reel-tag-btn--remove { background: #fef2f2; border-color: #fecaca; color: #dc2626; }
.reel-tag-btn--remove:hover { background: #fee2e2; }
.reel-mgmt-delete {
  flex-shrink: 0; background: none; border: none; cursor: pointer;
  color: #d1cdc8; padding: 6px; border-radius: 8px; transition: color .12s, background .12s;
}
.reel-mgmt-delete:hover { color: #dc2626; background: #fef2f2; }
.mkt-loading { padding: 32px; text-align: center; color: #a8a49e; font-size: .9rem; }

/* Modal etiquetar producto */
.reel-tag-product-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px; border: 1px solid #f0ede8; border-radius: 10px;
  background: #fff; cursor: pointer; text-align: left;
  transition: background .12s, border-color .12s;
}
.reel-tag-product-item:hover { background: var(--paper); border-color: var(--accent); }
.reel-tag-prod-img  { width: 44px; height: 44px; object-fit: cover; border-radius: 6px; flex-shrink: 0; }
.reel-tag-prod-emoji { width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; font-size: 1.4rem; background: var(--cream); border-radius: 6px; flex-shrink: 0; }
.reel-tag-prod-name  { flex: 1; font-size: .9rem; font-weight: 600; color: var(--ink); }
.reel-tag-prod-price { font-size: .82rem; color: var(--accent); font-weight: 700; flex-shrink: 0; }

/* Chip de producto etiquetado en el reel del catálogo público */
.reel-tagged-product {
  display: flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,.15); backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.25); border-radius: 20px;
  padding: 4px 12px; width: fit-content;
}
.reel-tagged-label { font-size: .65rem; color: rgba(255,255,255,.7); text-transform: uppercase; letter-spacing: .06em; }
.reel-tagged-name  { font-size: .82rem; font-weight: 700; color: #fff; }

/* ── Pantalla Soporte ── */
#support-screen.active { display: flex; flex-direction: column; height: 100dvh; overflow: hidden; }
#support-screen .support-messages { flex: 1; overflow-y: auto; }
#support-screen .support-input-row { flex-shrink: 0; border-top: 1px solid #f0ede8; padding: 10px 12px; }

/* ── Pantalla Configuración ── */
#config-screen.active { display: flex; flex-direction: column; }
#config-screen.active .settings-body { flex: 1; overflow-y: auto; padding: 0 0 16px; }

/* ── Pantallas Share y Plan ── */
#share-screen.active, #plan-screen.active { display: flex; flex-direction: column; }

/* ── Menú ⋯ página pública de producto ── */
.prod-page-more-wrap { position: relative; width: 40px; }
.prod-more-btn {
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  background: none; border: none; cursor: pointer;
  border-radius: 8px; color: var(--ink);
  transition: background .13s;
}
.prod-more-btn:hover { background: rgba(0,0,0,.06); }
.prod-more-menu {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  background: #fff;
  border: 1px solid #e8e5e0;
  border-radius: 12px;
  box-shadow: 0 4px 24px rgba(0,0,0,.13);
  padding: 6px;
  min-width: 170px;
  z-index: 200;
}
.prod-more-menu.prod-more-menu--open { display: flex; flex-direction: column; }
.prod-more-item {
  padding: 10px 14px;
  text-align: left;
  background: none;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  font-size: .9rem;
  color: var(--ink);
  transition: background .1s;
  white-space: nowrap;
}
.prod-more-item:hover { background: var(--cream); }
.prod-more-item--danger { color: #dc2626; }
.prod-more-item--danger:hover { background: #fef2f2; }
.prod-more-item--saved { color: var(--accent); font-weight: 600; }

/* ── Medida de talla en página pública ── */
.pd-size-measure {
  display: none;
  font-size: .8rem;
  color: #78716c;
  padding: 5px 11px;
  background: var(--cream);
  border-radius: 8px;
  margin-top: 2px;
}
.pd-size-measure.active { display: block; }

/* ── Presets de tipo de medida (dashboard — formulario de producto) ── */
.size-measure-presets {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 6px;
  margin-bottom: 6px;
}
.measure-preset-btn {
  padding: 4px 11px;
  border: 1.5px solid rgba(15,14,12,.14);
  border-radius: 20px;
  background: #fff;
  font-size: .77rem;
  cursor: pointer;
  color: #57534e;
  transition: all .13s;
}
.measure-preset-btn:hover { border-color: var(--accent); color: var(--accent); }
.measure-preset-btn--active {
  border-color: var(--accent);
  background: var(--accent);
  color: #fff;
}

/* ── Input de medida por talla ── */
.sizes-measure-input {
  flex: 1;
  min-width: 70px;
  max-width: 110px;
  padding: 5px 8px;
  font-size: .82rem;
  border: 1.5px solid rgba(15,14,12,.12);
  border-radius: 7px;
  background: #fff;
  color: var(--ink);
}

/* ── Preset colores producto ── */
.color-presets {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}
.color-preset-chip {
  width: 32px; height: 32px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  flex-shrink: 0;
  transition: transform .12s, box-shadow .12s;
  position: relative;
}
.color-preset-chip:hover { transform: scale(1.15); box-shadow: 0 2px 8px rgba(0,0,0,.22); }
.color-preset-chip--custom {
  background: var(--cream);
  border: 1.5px solid rgba(15,14,12,.12);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; color: var(--soft);
  overflow: hidden;
}
.color-preset-chip--custom input[type=color] {
  position: absolute; inset: 0; width: 100%; height: 100%;
  opacity: 0; cursor: pointer; border: none; padding: 0; margin: 0;
}
.color-preset-chip--custom span { pointer-events: none; }
.color-add-row { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }

/* ── Fila envío en carrito ── */
.cart-shipping-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
  margin-bottom: 4px;
  border-top: 1px solid #f0ede8;
  font-size: .88rem;
}
.cart-shipping-label { color: var(--soft); }
.cart-shipping-price { font-weight: 600; color: var(--ink); }

/* ── Drawer Mis Guardados ── */
.saved-drawer .saved-drawer-handle {
  width: 38px; height: 4px;
  background: rgba(15,14,12,.13);
  border-radius: 2px;
  margin: 12px auto 0;
  flex-shrink: 0;
}
.saved-drawer-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px 14px;
  border-bottom: 1.5px solid rgba(15,14,12,.07);
  flex-shrink: 0;
}
.saved-drawer-title-row {
  display: flex; align-items: center; gap: 8px;
  color: var(--ink);
}
.saved-drawer-title-row svg { color: var(--accent); flex-shrink: 0; }
.saved-drawer-title { font-size: 1rem; font-weight: 700; }
.saved-drawer-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 20px; height: 20px; padding: 0 6px;
  background: var(--accent); color: #fff;
  border-radius: 10px; font-size: .7rem; font-weight: 700;
}
.saved-drawer-close {
  background: rgba(15,14,12,.06); border: none; cursor: pointer;
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--soft); transition: background .13s, color .13s;
}
.saved-drawer-close:hover { background: rgba(15,14,12,.12); color: var(--ink); }
.saved-drawer-body {
  flex: 1; overflow-y: auto; overscroll-behavior: contain;
  padding: 14px 14px 24px;
}
.saved-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.saved-card {
  background: var(--paper); border-radius: 12px;
  overflow: hidden; cursor: pointer;
  border: 1.5px solid rgba(15,14,12,.08);
  transition: transform .13s, box-shadow .13s;
}
.saved-card:active { transform: scale(.97); }
.saved-card-img {
  position: relative; aspect-ratio: 1/1;
  background: var(--cream);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.saved-card-img img { width: 100%; height: 100%; object-fit: cover; }
.saved-card-emoji { font-size: 2.2rem; }
.saved-card-remove {
  position: absolute; top: 6px; right: 6px;
  width: 24px; height: 24px; border-radius: 50%;
  background: rgba(0,0,0,.45); backdrop-filter: blur(4px);
  border: none; cursor: pointer; color: #fff;
  display: flex; align-items: center; justify-content: center;
  transition: background .13s;
}
.saved-card-remove:hover { background: rgba(220,38,38,.85); }
.saved-card-disc-badge {
  position: absolute; bottom: 6px; left: 6px;
  background: #ef4444; color: #fff;
  font-size: .65rem; font-weight: 700;
  padding: 2px 6px; border-radius: 6px;
}
.saved-card-info { padding: 8px 10px 10px; }
.saved-card-name {
  font-size: .82rem; font-weight: 600; color: var(--ink);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-bottom: 4px;
}
.saved-card-price { display: flex; align-items: center; gap: 5px; flex-wrap: wrap; }
.saved-card-cur { font-size: .85rem; font-weight: 700; color: var(--accent); }
.saved-card-old { font-size: .72rem; color: var(--soft); text-decoration: line-through; }
.saved-empty {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; padding: 48px 24px; text-align: center;
  color: var(--soft);
}
.saved-empty-title { font-size: 1rem; font-weight: 600; margin: 14px 0 6px; color: var(--ink); }
.saved-empty-sub { font-size: .82rem; line-height: 1.5; }

/* ── Subida Masiva ── */
.bulk-wrap {
  max-width: 860px; margin: 16px auto 80px; padding: 0 16px;
}
.bulk-dropzone {
  border: 2px dashed #d6d1ca; border-radius: 14px;
  padding: 32px 20px; text-align: center; cursor: pointer;
  transition: border-color .18s, background .18s;
  background: var(--paper);
}
.bulk-dropzone:hover,
.bulk-dropzone--over {
  border-color: var(--accent); background: color-mix(in srgb, var(--accent) 5%, #fff);
}
.bulk-drop-icon { color: #b8b4ae; margin-bottom: 10px; }
.bulk-drop-label { font-weight: 600; color: #44403c; font-size: .95rem; }
.bulk-drop-sub   { font-size: .8rem; color: #9a948c; margin-top: 4px; }

/* Barra de progreso */
.bulk-upload-progress { margin: 12px 0; }
.bulk-progress-bar  { height: 6px; background: #e8e5e0; border-radius: 99px; overflow: hidden; }
.bulk-progress-fill { height: 100%; background: var(--accent); border-radius: 99px; transition: width .2s; width: 0%; }
.bulk-progress-label { font-size: .8rem; color: #9a948c; margin-top: 4px; }

/* Resumen */
.bulk-summary {
  display: flex; gap: 10px; flex-wrap: wrap;
  margin: 10px 0; font-size: .83rem; font-weight: 500;
}
.bulk-sum-ok  { color: #15803d; background: #f0fdf4; border: 1px solid #bbf7d0; padding: 3px 10px; border-radius: 99px; }
.bulk-sum-dup { color: #9a3412; background: #fff7ed; border: 1px solid #fed7aa; padding: 3px 10px; border-radius: 99px; }

/* Acciones globales */
.bulk-global-actions {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  margin: 14px 0;
}
.bulk-clear-btn { color: #ef4444 !important; }

/* Título de sección */
.bulk-section-title {
  display: flex; align-items: center; gap: 6px;
  font-family: 'Syne', sans-serif; font-weight: 700; font-size: .92rem; letter-spacing: -.01em;
  color: #1c1917; margin: 20px 0 10px;
}
.bulk-section-title svg { stroke: #9a948c; flex-shrink: 0; }
.bulk-section-count {
  background: #e8e5e0; color: #57534e; font-size: .75rem; font-weight: 600;
  border-radius: 99px; padding: 1px 7px; margin-left: 2px;
}

/* Filas de producto (lista) */
.bulk-product-list { display: flex; flex-direction: column; gap: 8px; }

.bulk-product-row {
  display: flex; align-items: center; gap: 12px;
  background: #fff; border: 1.5px solid #e8e5e0; border-radius: 10px;
  padding: 10px 12px; transition: border-color .15s, box-shadow .15s;
}
.bulk-product-row--over {
  border-color: var(--accent); box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent);
}
.bulk-product-row--ready { border-color: #86efac; background: #f0fdf4; }

/* Imagen principal */
.bpr-img {
  position: relative; flex-shrink: 0;
  width: 72px; height: 72px; border-radius: 9px;
  overflow: hidden; background: var(--cream); border: 1.5px solid #e8e5e0;
}
.bpr-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bpr-img-empty {
  width: 100%; height: 100%; display: flex; align-items: center;
  justify-content: center; font-size: 1.6rem;
}
.bpr-img-count {
  position: absolute; bottom: 4px; right: 4px;
  background: rgba(0,0,0,.58); color: #fff;
  font-size: .62rem; font-weight: 700; border-radius: 99px;
  padding: 1px 5px; line-height: 1.4; pointer-events: none;
}

/* Campos */
.bpr-fields { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 7px; }
.bpr-row2 { display: flex; gap: 8px; }
.bpr-row2 .bulk-price-wrap { flex: 0 0 120px; }
.bpr-row2 > .bulk-input { flex: 1; min-width: 0; }

/* Inputs */
.bulk-input {
  width: 100%; padding: 7px 10px; border: 1px solid #e0dcd7;
  border-radius: 8px; font-size: .88rem; font-family: inherit;
  background: var(--paper); color: var(--ink); outline: none;
  transition: border-color .15s;
}
.bulk-input:focus { border-color: var(--accent); background: #fff; }
.bulk-input--name { font-weight: 600; }
.bulk-price-wrap {
  display: flex; align-items: center;
  border: 1px solid #e0dcd7; border-radius: 8px; overflow: hidden;
  background: var(--paper);
}
.bulk-currency-label {
  padding: 0 8px; font-size: .85rem; color: #9a948c;
  border-right: 1px solid #e0dcd7; white-space: nowrap; font-weight: 600;
}
.bulk-price-wrap .bulk-input--price {
  border: none; border-radius: 0; background: transparent; padding: 7px 8px; flex: 1; min-width: 0;
}
.bulk-price-wrap .bulk-input--price:focus { border: none; box-shadow: none; }

/* Acciones */
.bpr-actions { display: flex; flex-direction: column; align-items: stretch; gap: 6px; flex-shrink: 0; }
.bpr-publish-btn { white-space: nowrap; }
.bulk-del-prod-btn { color: #ef4444 !important; justify-content: center; }

/* Imágenes sin asignar */
.bulk-unassigned-grid {
  display: flex; flex-wrap: wrap; gap: 10px;
  background: var(--paper); border: 1.5px dashed #d6d1ca; border-radius: 12px;
  padding: 12px; min-height: 80px;
}
.bulk-ua-thumb {
  position: relative; width: 76px; cursor: grab;
  border-radius: 8px; overflow: hidden; border: 1px solid #e8e5e0;
  background: var(--cream);
}
.bulk-ua-thumb img { width: 76px; height: 76px; object-fit: cover; display: block; }
.bulk-ua-name {
  font-size: .62rem; color: #9a948c; padding: 3px 4px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  background: #fff;
}
.bulk-ua-thumb .bulk-thumb-remove { top: 3px; right: 3px; }
.bulk-ua-thumb:hover .bulk-thumb-remove { display: flex; }

/* Responsive — móvil */
@media (max-width: 600px) {
  .bulk-wrap { padding: 0 10px; margin-top: 10px; }
  .bulk-product-list { gap: 8px; }

  .bulk-product-row { padding: 10px; gap: 9px; border-radius: 10px; }
  .bpr-img { width: 64px; height: 64px; border-radius: 8px; }
  .bpr-row2 { gap: 6px; }
  .bpr-row2 .bulk-price-wrap { flex: 0 0 95px; }
  .bulk-input { padding: 8px 9px; font-size: .86rem; }

  /* Botón Publicar compacto, 🗑 solo ícono sin padding extra */
  .bpr-actions { gap: 5px; }
  .bpr-publish-btn { padding: 7px 10px; font-size: .82rem; }
  .bulk-del-prod-btn { padding: 7px 8px !important; font-size: .85rem; min-width: 0; }

  .bulk-global-actions { flex-direction: column; gap: 8px; }
  .bulk-global-actions .btn-primary { width: 100%; justify-content: center; }
  .bulk-ua-thumb { width: 70px; }
  .bulk-ua-thumb img { width: 70px; height: 70px; }
  .bulk-ua-name { font-size: .6rem; }
}

/* prod-sub-toggle con 4 botones */
.prod-sub-toggle--4 {
  max-width: 430px;
}
@media (max-width: 480px) {
  .prod-sub-toggle--4 {
    max-width: 100%;
  }
  .prod-sub-toggle--4 .prod-sub-btn {
    padding: 6px 3px;
    font-size: 0.7rem;
    gap: 0;
  }
  .prod-sub-toggle--4 .prod-sub-btn svg {
    display: none;
  }
}

/* ── Pantalla Acciones rápidas ── */
.actions-list {
  padding: 4px 16px 80px;
  max-width: 680px;
  margin: 0 auto;
}
.actions-empty {
  text-align: center;
  padding: 40px 16px;
  color: #9a948c;
  font-size: .9rem;
}
.act-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 0;
  border-bottom: 1px solid rgba(15,14,12,.07);
}
.act-thumb { flex-shrink: 0; width: 44px; height: 44px; position: relative; }
.act-img { width: 44px; height: 44px; border-radius: 8px; object-fit: cover; display: block; }
.act-img-ph {
  width: 44px; height: 44px; border-radius: 8px;
  background: var(--cream);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem;
}
.act-info { flex: 1; min-width: 0; }
.act-name { font-size: .85rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Selector de estado segmentado */
.act-seg {
  display: flex;
  background: rgba(15,14,12,.06);
  border-radius: 8px;
  padding: 2px;
  gap: 1px;
  margin-top: 5px;
}
.act-seg-opt {
  flex: 1;
  padding: 4px 2px;
  border: none; background: transparent; border-radius: 6px;
  font-size: .6rem; font-weight: 500;
  cursor: pointer; color: rgba(15,14,12,.42);
  transition: background .15s, color .15s, box-shadow .15s;
  font-family: inherit; white-space: nowrap;
  line-height: 1.3; text-align: center;
}
.act-seg-opt:hover:not(.act-seg-opt--on) { background: rgba(15,14,12,.05); color: rgba(15,14,12,.65); }
.act-seg-opt--on { background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.12); font-weight: 600; }
.act-seg-opt--green.act-seg-opt--on  { color: #16a34a; }
.act-seg-opt--red.act-seg-opt--on    { color: #dc2626; }
.act-seg-opt--purple.act-seg-opt--on { color: #7c3aed; }
.act-seg-opt--amber.act-seg-opt--on  { color: #ca8a04; }

/* Sub-fila extras */
.act-extras { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 5px; }
.act-extra {
  font-size: .58rem; padding: 1px 5px; border-radius: 20px;
  border: 1.5px solid rgba(15,14,12,.09); background: transparent;
  cursor: pointer; color: rgba(15,14,12,.38); font-family: inherit;
  line-height: 1.5; transition: all .14s; white-space: nowrap;
}
.act-extra:hover:not(.act-extra--on) { border-color: rgba(15,14,12,.2); color: rgba(15,14,12,.65); }
.act-extra-lbl { display: none; }
.act-extra--on { border-color: transparent; color: #fff; }
.act-extra--on .act-extra-lbl { display: inline; }
.act-extra--on.act-extra--blue   { background: #2563eb; }
.act-extra--on.act-extra--yellow { background: #b45309; }
.act-extra--on.act-extra--teal   { background: #0d9488; }
.act-extra--on.act-extra--rose   { background: #e11d48; }

/* Botón editar */
.act-edit-btn {
  flex-shrink: 0; width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  border: none; background: transparent; cursor: pointer;
  color: rgba(15,14,12,.3); border-radius: 8px;
  transition: background .14s, color .14s;
}
.act-edit-btn:hover { background: var(--cream); color: rgba(15,14,12,.7); }

/* 2×2 en móvil para mostrar texto completo */
@media (max-width: 520px) {
  .act-seg { flex-wrap: wrap; gap: 2px; }
  .act-seg-opt { flex: 0 0 calc(50% - 2px); font-size: .65rem; padding: 5px 4px; }
}

/* dark mode Acciones */
[data-theme="dark"] .act-row         { border-bottom-color: rgba(255,255,255,.06); }
[data-theme="dark"] .act-img-ph      { background: #252320; }
[data-theme="dark"] .act-seg         { background: rgba(255,255,255,.08); }
[data-theme="dark"] .act-seg-opt     { color: rgba(255,255,255,.35); }
[data-theme="dark"] .act-seg-opt--on { background: rgba(255,255,255,.13); }
[data-theme="dark"] .act-extra       { border-color: rgba(255,255,255,.1); color: rgba(255,255,255,.3); }
[data-theme="dark"] .act-extra--on   { color: #fff; }
[data-theme="dark"] .act-edit-btn    { color: rgba(255,255,255,.25); }
[data-theme="dark"] .act-edit-btn:hover { background: #252320; color: rgba(255,255,255,.7); }


/* ── Inventario: compacto en móvil estrecho ── */
@media (max-width: 400px) {
  .inv-status-btn { font-size: .62rem; padding: 3px 7px; }
  .inv-qty-input  { width: 42px; }
  .inv-qty-btn    { width: 24px; height: 24px; }
}

/* ── Wizard registro: URL wrap ── */
.reg-url-wrap {
  display: flex;
  align-items: center;
  border: 1.5px solid rgba(15,14,12,.12);
  border-radius: 12px;
  overflow: hidden;
  background: var(--paper);
  transition: border-color .15s, box-shadow .15s;
}
.reg-url-wrap:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 12%, transparent);
}
.reg-url-prefix {
  padding: 11px 6px 11px 12px;
  font-size: .75rem;
  color: var(--soft);
  white-space: nowrap;
  user-select: none;
  border-right: 1px solid rgba(15,14,12,.08);
  background: rgba(15,14,12,.03);
}
.reg-url-wrap input {
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  flex: 1;
  min-width: 0;
  padding: 11px 12px 11px 8px;
  font-size: .9rem;
}
#form-register select {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid rgba(15,14,12,.12);
  border-radius: 12px;
  font-size: .95rem;
  background: var(--paper);
  color: var(--ink);
  transition: border-color .15s, box-shadow .15s;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}
#form-register select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 12%, transparent);
}

/* ── Banner bienvenida nuevos vendedores ── */
.welcome-banner {
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--accent) 10%, transparent),
    color-mix(in srgb, var(--accent) 4%, transparent));
  border: 1px solid color-mix(in srgb, var(--accent) 25%, transparent);
  border-radius: 14px;
  margin: 12px 16px 0;
  overflow: hidden;
  animation: wb-slide-in .35s ease;
}
@keyframes wb-slide-in {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: none; }
}
.welcome-banner-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
}
.welcome-banner-left {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.welcome-banner-emoji { font-size: 1.6rem; flex-shrink: 0; }
.welcome-banner-title {
  font-weight: 700;
  font-size: .92rem;
  color: var(--ink);
  margin-bottom: 4px;
}
.welcome-banner-steps {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px 6px;
  font-size: .78rem;
  color: var(--soft);
}
.wb-step {
  cursor: pointer;
  color: var(--soft);
  transition: color .15s;
}
.wb-step:hover { color: var(--accent); }
.wb-sep { color: rgba(15,14,12,.2); }
.welcome-banner-close {
  background: none;
  border: none;
  font-size: 1.3rem;
  color: var(--soft);
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 6px;
  flex-shrink: 0;
  line-height: 1;
  transition: background .15s;
}
.welcome-banner-close:hover { background: rgba(15,14,12,.06); }
[data-theme="dark"] .welcome-banner {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.1);
}

/* ── Banner crop modal ────────────────────────────────── */
.bc-modal {
  position: fixed; inset: 0; z-index: 1600;
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
}
.bc-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.8);
}
.bc-dialog {
  position: relative; z-index: 1;
  background: var(--paper);
  border-radius: 18px;
  width: min(440px, 100%);
  padding: 20px;
  box-shadow: 0 24px 60px rgba(0,0,0,.35);
}
.bc-dialog-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 4px;
}
.bc-dialog-title { font-family: 'Syne',sans-serif; font-size: 1rem; font-weight: 700; }
.bc-close-btn {
  width: 30px; height: 30px;
  border: none; background: rgba(15,14,12,.07);
  border-radius: 50%; cursor: pointer; font-size: 1rem; color: var(--ink);
  display: flex; align-items: center; justify-content: center;
}
.bc-hint {
  font-size: .72rem; color: var(--soft); margin: 0 0 12px;
}
/* Zona de recorte — proporción 4:1 igual que el header del catálogo */
.bc-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 1;
  overflow: hidden;
  border-radius: 10px;
  background: #111;
  cursor: grab;
  touch-action: none;
  user-select: none;
}
.bc-wrap:active { cursor: grabbing; }
.bc-img {
  position: absolute;
  top: 0; left: 0;
  transform-origin: 0 0;
  will-change: transform;
  pointer-events: none;
  user-select: none;
  -webkit-user-drag: none;
}
/* Overlay semitransparente con ghost del layout del header */
.bc-overlay {
  position: absolute; inset: 0;
  pointer-events: none;
}
.bc-overlay-dim {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.3);
}
.bc-overlay-content {
  position: absolute; inset: 0;
  display: flex; align-items: center;
  padding: 0 14px; gap: 10px;
}
.bc-ghost-avatar {
  width: 32px; height: 32px; flex-shrink: 0;
  border-radius: 50%;
  background: rgba(255,255,255,.25);
  border: 1.5px solid rgba(255,255,255,.4);
}
.bc-ghost-info { display: flex; flex-direction: column; gap: 4px; }
.bc-ghost-name {
  width: 88px; height: 9px;
  background: rgba(255,255,255,.55);
  border-radius: 3px;
}
.bc-ghost-badge {
  width: 60px; height: 7px;
  background: rgba(255,255,255,.28);
  border-radius: 10px;
}
.bc-ghost-desc {
  width: 110px; height: 6px;
  background: rgba(255,255,255,.2);
  border-radius: 3px;
}
.bc-ratio-label {
  font-size: .7rem; color: var(--soft);
  margin: 8px 0 0; text-align: center;
}
.bc-actions {
  display: flex; gap: 10px; justify-content: flex-end;
  margin-top: 16px;
}
[data-theme="dark"] .bc-dialog { background: #1a1a1a; }
[data-theme="dark"] .bc-close-btn { background: rgba(255,255,255,.1); color: #f0ede8; }

/* ── MODAL REPORTE PRODUCTO ── */
.rpt-overlay {
  position: fixed; inset: 0; background: rgba(15,14,12,.55);
  z-index: 3100; opacity: 0; pointer-events: none; transition: opacity .22s;
}
.rpt-overlay.rpt-open { opacity: 1; pointer-events: all; }
.rpt-modal {
  position: fixed; bottom: 0; left: 50%; transform: translateX(-50%) translateY(100%);
  width: min(100%, 440px); background: var(--paper); border-radius: 20px 20px 0 0;
  z-index: 3101; transition: transform .28s cubic-bezier(.32,1,.56,1);
  box-shadow: 0 -4px 32px rgba(15,14,12,.18);
}
.rpt-modal.rpt-open { transform: translateX(-50%) translateY(0); }
.rpt-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px 12px; border-bottom: 1px solid rgba(15,14,12,.08);
}
.rpt-title { font-weight: 700; font-size: .95rem; }
.rpt-close {
  background: none; border: none; cursor: pointer; font-size: 1rem;
  color: var(--soft); padding: 4px 6px; border-radius: 6px; line-height: 1;
}
.rpt-close:hover { background: rgba(15,14,12,.07); }
.rpt-body { padding: 16px 20px 28px; display: flex; flex-direction: column; gap: 14px; }
.rpt-prod-name {
  font-size: .82rem; color: var(--soft); font-style: italic;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rpt-field { display: flex; flex-direction: column; gap: 5px; }
.rpt-label { font-size: .8rem; font-weight: 600; color: rgba(15,14,12,.7); }
.rpt-select, .rpt-input, .rpt-textarea {
  font-family: inherit; font-size: .88rem; padding: 9px 12px;
  border: 1.5px solid rgba(15,14,12,.15); border-radius: 10px;
  background: var(--paper); color: var(--ink); outline: none;
  transition: border-color .15s;
}
.rpt-select:focus, .rpt-input:focus, .rpt-textarea:focus {
  border-color: var(--accent);
}
.rpt-textarea { resize: none; line-height: 1.5; }
.rpt-error {
  font-size: .8rem; color: #ef4444; background: #fef2f2;
  border-radius: 8px; padding: 8px 12px;
}
.rpt-actions { display: flex; gap: 10px; margin-top: 4px; }
.rpt-btn-cancel {
  flex: 1; padding: 11px; border-radius: 10px; font-size: .88rem;
  font-weight: 600; border: 1.5px solid rgba(15,14,12,.15); background: none;
  cursor: pointer; color: var(--ink);
}
.rpt-btn-cancel:hover { background: rgba(15,14,12,.05); }
.rpt-btn-submit {
  flex: 2; padding: 11px; border-radius: 10px; font-size: .88rem;
  font-weight: 700; border: none; background: #ef4444; color: #fff; cursor: pointer;
  transition: opacity .15s;
}
.rpt-btn-submit:disabled { opacity: .55; cursor: default; }
.rpt-btn-submit:not(:disabled):hover { opacity: .88; }
[data-theme="dark"] .rpt-modal { background: #1a1a1a; }
[data-theme="dark"] .rpt-select, [data-theme="dark"] .rpt-input, [data-theme="dark"] .rpt-textarea {
  background: #232323; color: #f0ede8; border-color: rgba(255,255,255,.13);
}
[data-theme="dark"] .rpt-error { background: rgba(239,68,68,.15); }
[data-theme="dark"] .rpt-label { color: rgba(240,237,232,.65); }

/* ── CHAT WIDGET VISITANTES ── */
.gc-widget {
  position: fixed; bottom: 24px; right: 24px; z-index: 3200;
  display: flex; flex-direction: column; align-items: flex-end; gap: 12px;
}

/* Botón toggle */
.gc-toggle {
  background: var(--ink); color: #fff;
  border: none; padding: 14px 22px; border-radius: 60px;
  font-weight: 600; font-size: .92rem; cursor: pointer;
  box-shadow: 0 8px 24px rgba(15,14,12,.28);
  display: flex; align-items: center; gap: 10px; position: relative;
  transition: transform .18s, box-shadow .18s;
}
.gc-toggle:hover { transform: scale(1.04); box-shadow: 0 12px 32px rgba(15,14,12,.36); }
.gc-toggle--open { background: #374151; }
.gc-toggle-label { white-space: nowrap; }
.gc-badge {
  position: absolute; top: -6px; right: -6px;
  background: #ef4444; color: #fff; font-size: .65rem; font-weight: 700;
  padding: 3px 7px; border-radius: 40px; min-width: 20px; text-align: center;
  display: inline-flex; align-items: center; justify-content: center;
}

/* Ventana del chat */
.gc-window {
  width: 360px; max-width: calc(100vw - 48px);
  height: 460px; max-height: calc(100vh - 180px);
  background: var(--paper); border-radius: 20px;
  box-shadow: 0 20px 60px rgba(15,14,12,.22);
  display: none; flex-direction: column; overflow: hidden;
}
.gc-window.gc-open {
  display: flex;
  animation: gcSlideUp .28s cubic-bezier(.32,1,.56,1);
}
@keyframes gcSlideUp {
  from { opacity:0; transform: translateY(16px) scale(.97); }
  to   { opacity:1; transform: translateY(0) scale(1); }
}

/* Header */
.gc-header {
  background: var(--ink); color: #fff;
  padding: 14px 18px; display: flex; align-items: center;
  justify-content: space-between; flex-shrink: 0;
}
.gc-header-info { display: flex; align-items: center; gap: 10px; }
.gc-avatar {
  width: 34px; height: 34px; border-radius: 50%;
  background: rgba(255,255,255,.15); display: flex;
  align-items: center; justify-content: center; font-size: .95rem; overflow: hidden;
}
.gc-avatar img { width: 100%; height: 100%; object-fit: cover; }
.gc-header-name { font-weight: 700; font-size: .9rem; }
.gc-header-sub { font-size: .68rem; opacity: .75; display: flex; align-items: center; gap: 5px; margin-top: 1px; }
.gc-online-dot {
  width: 7px; height: 7px; border-radius: 50%; background: #4ade80; flex-shrink: 0;
  animation: gcPulse 2s infinite;
}
@keyframes gcPulse { 0%,100% { opacity:1; } 50% { opacity:.4; } }
.gc-close-btn {
  background: none; border: none; cursor: pointer; color: rgba(255,255,255,.7);
  padding: 5px; border-radius: 7px; display: flex; align-items: center; transition: color .15s;
}
.gc-close-btn:hover { color: #fff; background: rgba(255,255,255,.1); }

/* Mensajes */
.gc-messages {
  flex: 1; padding: 14px 16px; overflow-y: auto;
  display: flex; flex-direction: column; gap: 2px; background: #f8faff;
}
.gc-messages::-webkit-scrollbar { width: 4px; }
.gc-messages::-webkit-scrollbar-thumb { background: var(--cream); border-radius: 10px; }
.gc-sys-bubble {
  align-self: center; background: #fff6e5; color: #b8731a;
  font-size: .78rem; padding: 5px 14px; border-radius: 40px; margin-bottom: 6px;
}

/* Burbujas de mensaje (reutiliza support-bubble-wrap de dashboard) */
.gc-messages .support-bubble-wrap { display: flex; flex-direction: column; }
.gc-messages .support-bubble-wrap--seller { align-items: flex-start; }
.gc-messages .support-bubble-wrap--admin  { align-items: flex-end; }
.gc-messages .support-bubble {
  max-width: 80%; padding: 9px 14px; border-radius: 16px;
  font-size: .88rem; line-height: 1.45; word-break: break-word;
}
.gc-messages .support-bubble--seller {
  background: var(--cream); color: var(--ink); border-bottom-left-radius: 4px;
}
.gc-messages .support-bubble--admin {
  background: var(--accent); color: #fff; border-bottom-right-radius: 4px;
}
.gc-messages .support-bubble-meta {
  font-size: .62rem; color: #9ca3af; margin: 2px 4px 8px;
}

/* Input */
.gc-input-row {
  display: flex; gap: 8px; padding: 10px 14px 14px;
  background: var(--paper); border-top: 1px solid rgba(15,14,12,.07);
  flex-shrink: 0;
}
.gc-input {
  flex: 1; padding: 9px 14px; border: 1.5px solid rgba(15,14,12,.13);
  border-radius: 40px; font-size: .88rem; font-family: inherit;
  outline: none; background: var(--paper); color: var(--ink);
  transition: border-color .15s;
}
.gc-input:focus { border-color: var(--accent); }
.gc-send-btn {
  background: var(--ink); color: #fff; border: none;
  width: 38px; height: 38px; border-radius: 50%; cursor: pointer;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  transition: opacity .15s;
}
.gc-send-btn:disabled { opacity: .5; cursor: default; }
.gc-send-btn:not(:disabled):hover { opacity: .82; }

/* Intro form */
.gc-welcome-block { display: flex; flex-direction: column; align-items: center; gap: 8px; text-align: center; }
.gc-welcome-icon { font-size: 2rem; }
.gc-welcome-text { font-size: .88rem; color: var(--ink); line-height: 1.5; }
.gc-welcome-text span { font-size: .8rem; color: var(--soft); }
.gc-form-label { font-size: .78rem; font-weight: 600; color: rgba(15,14,12,.65); }
.gc-form-input {
  padding: 10px 14px; border: 1.5px solid rgba(15,14,12,.14);
  border-radius: 10px; font-size: .9rem; font-family: inherit;
  outline: none; background: var(--paper); color: var(--ink);
  transition: border-color .15s; width: 100%;
}
.gc-form-input:focus { border-color: var(--accent); }
.gc-start-btn {
  padding: 12px; border-radius: 12px; border: none;
  background: var(--accent); color: #fff; font-size: .92rem;
  font-weight: 700; cursor: pointer; transition: opacity .15s;
}
.gc-start-btn:hover { opacity: .88; }

/* Chip contexto del producto */
.gc-context {
  background: rgba(255,255,255,.94); border: 1px solid rgba(15,14,12,.1);
  border-radius: 40px; font-size: .75rem; color: var(--soft);
  padding: 5px 14px; display: flex; align-items: center; gap: 5px;
  backdrop-filter: blur(8px); max-width: calc(100vw - 48px);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* ── Ajustes rápidos de pedidos (dashboard) ── */
.quick-order-settings {
  margin: 0 0 14px; padding: 10px 12px 12px;
  background: var(--paper); border: 1.5px solid rgba(15,14,12,.08);
  border-radius: 12px;
}
.qos-header { margin-bottom: 10px; }
.qos-title {
  font-size: .68rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: var(--soft);
}
.qos-status {
  font-size: .78rem; font-weight: 500; margin-top: 2px;
}
.qos-status--ok   { color: #16a34a; }
.qos-status--warn { color: #d97706; }
.qos-toggles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.qos-toggle-row {
  display: flex; flex-direction: column; align-items: center;
  gap: 6px; padding: 10px 6px; cursor: pointer; border-radius: 10px;
  border: 1.5px solid rgba(15,14,12,.08); transition: background .15s;
}
.qos-toggle-row:hover { background: var(--cream); }
.qos-icon { line-height: 1; color: var(--soft); display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; }
.qos-label { font-size: .72rem; font-weight: 500; color: var(--ink); }
.qos-toggle-wrap { position: relative; }
.qos-toggle-wrap input { position: absolute; opacity: 0; width: 0; height: 0; }
.qos-toggle-track {
  display: block; width: 36px; height: 20px; border-radius: 10px;
  background: rgba(15,14,12,.15); transition: background .2s; position: relative;
}
.qos-toggle-track::after {
  content: ''; position: absolute; top: 3px; left: 3px;
  width: 14px; height: 14px; border-radius: 50%;
  background: #fff; transition: transform .2s;
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.qos-toggle-wrap input:checked + .qos-toggle-track { background: var(--accent); }
.qos-toggle-wrap input:checked + .qos-toggle-track::after { transform: translateX(16px); }

[data-theme="dark"] .quick-order-settings { background: #1a1a1a; border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .qos-toggle-row { border-color: rgba(255,255,255,.06); }
[data-theme="dark"] .qos-toggle-row:hover { background: #232323; }
[data-theme="dark"] .qos-toggle-track { background: rgba(255,255,255,.15); }
[data-theme="dark"] .qos-label { color: #f0ede8; }

/* Footer acciones: precio + botón agregar + ícono consulta */
.cat-footer-actions {
  display: flex; align-items: center; gap: 6px; flex-shrink: 0;
}

/* Íconos pequeños de consulta en tarjeta */
.cat-ask-icon-btn {
  width: 34px; height: 34px; flex-shrink: 0;
  border: 1.5px solid rgba(15,14,12,.13); background: var(--paper);
  border-radius: 50%; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--soft); transition: background .15s, border-color .15s, color .15s;
}
.cat-ask-icon-btn:hover { background: var(--cream); border-color: rgba(15,14,12,.22); color: var(--ink); }
.cat-ask-icon-btn--cart { border-color: rgba(15,14,12,.18); color: var(--ink); background: var(--accent); color: #fff; border-color: var(--accent); }
.cat-ask-icon-btn--cart:hover { opacity: .88; }
.cat-ask-icon-btn--incart { background: var(--accent); border-color: var(--accent); color: #fff; gap: 3px; }
.cat-ask-icon-btn--incart:hover { opacity: .88; }
.cat-cart-qty { font-size: .72rem; font-weight: 700; line-height: 1; }
.cat-ask-icon-btn--added { background: #d1fae5; border-color: #6ee7b7; color: #065f46; }
.cat-ask-icon-btn--oos { opacity: .4; cursor: not-allowed; }
.cat-ask-icon-btn--wa { border-color: rgba(37,211,102,.35); color: #25d366; }
.cat-ask-icon-btn--wa:hover { background: rgba(37,211,102,.08); border-color: #25d366; color: #128c4e; }

/* Responsive móvil */
@media (max-width: 700px) {
  .gc-widget { bottom: 90px; right: 14px; }
  .gc-window { width: calc(100vw - 28px); height: 68vh; max-height: 68vh; }
  .gc-toggle-label { display: none; }
  .gc-toggle { padding: 14px; border-radius: 50%; width: 54px; height: 54px; justify-content: center; }
}

/* Dark mode */
[data-theme="dark"] .gc-window { background: #1a1a1a; }
[data-theme="dark"] .gc-messages { background: #111; }
[data-theme="dark"] .gc-messages .support-bubble--seller { background: #2a2a2a; color: #f0ede8; }
[data-theme="dark"] .gc-sys-bubble { background: rgba(185,115,26,.15); }
[data-theme="dark"] .gc-input-row { background: #1a1a1a; border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .gc-input { background: #232323; color: #f0ede8; border-color: rgba(255,255,255,.12); }
[data-theme="dark"] .gc-form-input { background: #232323; color: #f0ede8; border-color: rgba(255,255,255,.12); }
[data-theme="dark"] .gc-context { background: rgba(26,26,26,.9); border-color: rgba(255,255,255,.1); }
[data-theme="dark"] .cat-ask-icon-btn { background: #1a1a1a; border-color: rgba(255,255,255,.12); color: rgba(240,237,232,.5); }
[data-theme="dark"] .cat-ask-icon-btn:hover { background: #232323; color: #f0ede8; }
[data-theme="dark"] .cat-ask-icon-btn--wa { border-color: rgba(37,211,102,.3); color: #25d366; }
[data-theme="dark"] .cat-ask-icon-btn--wa:hover { background: rgba(37,211,102,.1); }

/* ════════════════════════════════════════════════
   PANTALLA CONSULTAS — estilo WhatsApp
   Desktop: dos paneles lado a lado
   Móvil:   cada panel ocupa pantalla completa,
            el chat desliza desde la derecha
   ════════════════════════════════════════════════ */

/* Contenedor raíz — flex row en desktop */
#inquiries-screen.active {
  display: flex;
  height: 100dvh;
  overflow: hidden;
  background: var(--paper);
}

/* ── Panel genérico ── */
.inq-panel {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--paper);
}

/* ── Panel lista (izquierda) ── */
.inq-panel--list {
  width: 340px;
  flex-shrink: 0;
  border-right: 1px solid rgba(15,14,12,.08);
}

/* Cabecera del panel lista */
.inq-panel-hdr {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(15,14,12,.07);
  flex-shrink: 0;
  background: var(--paper);
}
.inq-panel-back {
  width: 32px; height: 32px; border-radius: 8px;
  border: none; background: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--ink); transition: background .13s; flex-shrink: 0;
}
.inq-panel-back:hover { background: var(--cream); }
.inq-panel-title {
  font-family: 'Syne', sans-serif; font-weight: 700;
  font-size: 1rem; color: var(--ink); letter-spacing: -.02em;
}

/* Lista de conversaciones (scrollable) */
.inq-thread-list { flex: 1; overflow-y: auto; }
.inq-thread-item {
  padding: 13px 16px; cursor: pointer;
  border-bottom: 1px solid rgba(15,14,12,.055);
  transition: background .12s;
}
.inq-thread-item:hover { background: var(--cream); }
.inq-thread-item--active { background: rgba(232,93,38,.07); }
.inq-thread-top { display: flex; justify-content: space-between; align-items: center; gap: 6px; }
.inq-thread-name {
  font-weight: 600; font-size: .87rem;
  display: flex; align-items: center; gap: 5px;
}
.inq-thread-time { font-size: .7rem; color: var(--soft); flex-shrink: 0; }
.inq-thread-prod { font-size: .73rem; color: var(--soft); margin-top: 2px; }
.inq-thread-last {
  font-size: .78rem; color: var(--soft); margin-top: 3px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.inq-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent); display: inline-block; flex-shrink: 0;
}

/* ── Panel chat (derecha) ── */
.inq-panel--chat { flex: 1; min-width: 0; }

/* Estado vacío (desktop sin conversación activa) */
.inq-chat-empty {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 10px; color: var(--soft); font-size: .88rem;
}
.inq-empty-icon { font-size: 2.5rem; }

/* Hilo activo: flex column que ocupa todo el panel */
.inq-chat-wrap {
  display: flex; flex-direction: column;
  height: 100%; overflow: hidden;
}

/* Cabecera del chat */
.inq-chat-hdr {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; flex-shrink: 0;
  background: var(--ink); color: #fff;
}
.inq-chat-back {
  display: none;
  background: none; border: none; cursor: pointer;
  color: #fff; padding: 4px; flex-shrink: 0;
  align-items: center; justify-content: center;
}
.inq-chat-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  background: rgba(255,255,255,.2); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: .95rem; font-weight: 700; color: #fff;
}
.inq-chat-hdr-info { flex: 1; min-width: 0; }
.inq-chat-hdr-name { font-weight: 700; font-size: .9rem; }
.inq-chat-hdr-sub  { font-size: .7rem; opacity: .7; margin-top: 1px; }

/* Mensajes */
.inq-messages {
  flex: 1; overflow-y: auto; padding: 14px 16px;
  display: flex; flex-direction: column; gap: 4px;
  background: #eef0f5; min-height: 0;
  -webkit-overflow-scrolling: touch;
}
.inq-bubble-wrap { display: flex; flex-direction: column; }
.inq-bubble-wrap--me   { align-items: flex-end; }
.inq-bubble-wrap--them { align-items: flex-start; }
.inq-bubble {
  max-width: 78%; padding: 8px 13px; border-radius: 18px;
  font-size: .88rem; line-height: 1.45; word-break: break-word;
}
.inq-bubble--me {
  background: var(--accent); color: #fff;
  border-bottom-right-radius: 4px;
}
.inq-bubble--them {
  background: #fff; color: var(--ink);
  border-bottom-left-radius: 4px;
  box-shadow: 0 1px 2px rgba(0,0,0,.08);
}
.inq-bubble-meta { font-size: .62rem; color: #9ca3af; margin: 2px 4px 8px; }

/* Input de respuesta */
.inq-input-row {
  display: flex; gap: 8px; padding: 10px 12px 12px;
  background: var(--paper); border-top: 1px solid rgba(15,14,12,.07);
  flex-shrink: 0; align-items: center;
}
.inq-input {
  flex: 1; padding: 10px 15px;
  border: 1.5px solid rgba(15,14,12,.12);
  border-radius: 24px; font-size: .9rem; font-family: inherit;
  outline: none; background: var(--paper); color: var(--ink);
  transition: border-color .15s;
}
.inq-input:focus { border-color: var(--accent); }
.inq-send-btn {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--accent); color: #fff; border: none;
  cursor: pointer; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: opacity .15s;
}
.inq-send-btn:hover { opacity: .85; }

/* Badge nav */
.inq-nav-badge {
  position: absolute; top: -4px; right: -6px;
  background: var(--accent); color: #fff; font-size: .58rem; font-weight: 700;
  padding: 2px 5px; border-radius: 40px; min-width: 16px; text-align: center;
  display: inline-flex; align-items: center; justify-content: center;
}

.inq-loading, .inq-empty {
  padding: 20px; text-align: center;
  color: var(--soft); font-size: .85rem;
}

.inq-verified-badge {
  display: inline-flex; align-items: center;
  font-size: .62rem; font-weight: 600; color: #16a34a;
  background: #dcfce7; border-radius: 20px;
  padding: 1px 6px; margin-left: 4px; flex-shrink: 0;
}

/* ── Dark mode ── */
[data-theme="dark"] #inquiries-screen       { background: #111; }
[data-theme="dark"] .inq-panel              { background: #1a1a1a; }
[data-theme="dark"] .inq-panel-hdr         { background: #1a1a1a; border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .inq-panel-back:hover  { background: #232323; }
[data-theme="dark"] .inq-panel-title       { color: #f0ede8; }
[data-theme="dark"] .inq-panel--list       { border-color: rgba(255,255,255,.07); }
[data-theme="dark"] .inq-thread-item:hover      { background: #232323; }
[data-theme="dark"] .inq-thread-item--active    { background: rgba(232,93,38,.12); }
[data-theme="dark"] .inq-messages          { background: #111; }
[data-theme="dark"] .inq-bubble--them      { background: #2a2a2a; color: #f0ede8; box-shadow: none; }
[data-theme="dark"] .inq-input-row         { background: #1a1a1a; border-color: rgba(255,255,255,.08); }
[data-theme="dark"] .inq-input             { background: #232323; color: #f0ede8; border-color: rgba(255,255,255,.12); }
[data-theme="dark"] .inq-verified-badge    { background: rgba(22,163,74,.18); color: #4ade80; }
