/* selem-ui.css — Sistema de diseño SELEM (compartido por motoselem.com y catalogo.motoselem.com)
   Tokens + componentes: header, buscador, tarjeta de producto, filtros, pastillas, botones,
   modal, carrito, toast, responsive. Editar AQUÍ afina las 4 superficies a la vez. */

:root{
        --red:#DC2626;--red-d:#b91c1c;
        --ink:#0b0d10;--ink-2:#3a4149;--muted:#727a84;
        --line:rgba(15,20,30,.08);--line-2:rgba(15,20,30,.14);
        --page:#f4f5f7;--surface:#fff;--surface2:#f1f3f5;--photo:#f6f7f9;
        --ok:#0f9d58;--ok-bg:#e7f6ee;--warn:#b7791f;--warn-bg:#fdf3e3;--err:#b42318;
        --shadow:0 1px 2px rgba(16,24,40,.04),0 1px 3px rgba(16,24,40,.06);
        --shadow-h:0 6px 16px rgba(16,24,40,.10),0 2px 6px rgba(16,24,40,.06);
        --r:16px;
        --font:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",Roboto,Helvetica,Arial,sans-serif;
      }
      *{box-sizing:border-box;}html,body{margin:0;overflow-x:clip;}
      body{background:var(--page);color:var(--ink);font-family:var(--font);-webkit-font-smoothing:antialiased;}
      a{color:inherit;text-decoration:none;}button{font-family:inherit;cursor:pointer;}input,select{font-family:inherit;}
      .muted{color:var(--muted);}

      /* ---------- Header + buscador Spotlight ---------- */
      .topbar{position:sticky;top:0;z-index:30;background:#0a0b0d;border-bottom:2.5px solid var(--red);}
      .topbar-in{max-width:1480px;margin:0 auto;display:flex;align-items:center;gap:16px;padding:11px 20px;}
      .brand{flex:none;display:flex;align-items:center;}.brand img{height:34px;width:auto;display:block;}
      /* Buscador protagonista — barra elevada sobre el fondo claro (debajo del header) */
      .searchbar{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line-2);border-radius:16px;padding:14px 18px;box-shadow:var(--shadow);margin:2px 0 16px;transition:border-color .15s,box-shadow .15s;}
      .searchbar:focus-within{border-color:var(--red);box-shadow:0 0 0 4px rgba(220,38,38,.08),var(--shadow);}
      .searchbar .s-ic{flex:none;color:var(--muted);}
      .searchbar input{flex:1;min-width:0;border:none;outline:none;background:transparent;font-size:1.08rem;color:var(--ink);}
      .searchbar input::placeholder{color:var(--muted);}
      .searchbar .ic{background:transparent;border:none;color:var(--muted);display:flex;align-items:center;padding:3px;border-radius:8px;}
      .searchbar .ic:hover{color:var(--ink);background:var(--surface2);}
      #buscar{display:none;}
      .top-r{margin-left:auto;display:flex;align-items:center;gap:12px;}
      .acceso{color:#cbd2da;font-size:.9rem;font-weight:500;}
      .cart-btn{position:relative;display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;background:#17191d;border:1px solid #2a2e34;color:#fff;font-size:1.15rem;}
      .cart-btn .cb-count{position:absolute;top:-6px;right:-6px;min-width:19px;height:19px;border-radius:99px;background:var(--red);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px;}

      .wrap{max-width:1480px;margin:0 auto;padding:18px 20px 80px;}
      /* contexto: crumbs + filtros(móvil) + orden */
      .ctx-bar{display:flex;align-items:center;gap:12px;margin:2px 0 16px;flex-wrap:wrap;}
      .crumbs{font-size:1rem;color:var(--muted);font-weight:500;}.crumbs b{color:var(--ink);font-weight:600;}
      .ctx-right{margin-left:auto;display:flex;align-items:center;gap:10px;}
      .ctx-right label{font-size:.85rem;color:var(--muted);display:flex;align-items:center;gap:6px;}
      .selsort{-webkit-appearance:none;appearance:none;border:1px solid var(--line-2);border-radius:11px;padding:9px 30px 9px 13px;background:#fff url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" fill="none" stroke="%23727a84" stroke-width="2"><path d="M2 4l4 4 4-4"/></svg>') no-repeat right 11px center;font-size:.86rem;color:var(--ink-2);cursor:pointer;}
      #filtros-btn{display:none;align-items:center;gap:7px;border:1px solid var(--line-2);background:#fff;border-radius:99px;padding:9px 15px;font-size:.88rem;font-weight:600;color:var(--ink);}
      #filtros-btn .fb-n{background:var(--red);color:#fff;border-radius:99px;font-size:.68rem;padding:1px 6px;}
      .btn{border:none;border-radius:10px;padding:10px 15px;background:var(--red);color:#fff;font-size:.88rem;font-weight:600;}

      /* ---------- Layout ---------- */
      .cat-layout{display:grid;grid-template-columns:248px minmax(0,1fr);gap:26px;align-items:start;}
      .cat-main{min-width:0;}

      /* ---------- Filtros (sidebar) ---------- */
      .filters{position:sticky;top:84px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);max-height:calc(100vh - 104px);overflow:auto;}
      .fil-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 6px;}
      .fil-head b{font-size:.98rem;}.fil-head button{border:none;background:var(--surface2);width:30px;height:30px;border-radius:50%;font-size:1.05rem;display:none;}
      .facet{padding:13px 16px;border-top:1px solid var(--line);}
      .facet:first-of-type{border-top:none;}
      .facet h4{margin:0 0 10px;font-size:.7rem;font-weight:700;letter-spacing:1.1px;text-transform:uppercase;color:var(--muted);}
      .facet-list{display:flex;flex-direction:column;gap:1px;max-height:188px;overflow:auto;}
      .frow{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--ink-2);padding:6px 8px;border-radius:8px;cursor:pointer;}
      .frow:hover{background:var(--surface2);color:var(--ink);}
      .frow input{accent-color:var(--red);width:15px;height:15px;flex-shrink:0;}
      .frow .fr-n{margin-left:auto;color:var(--muted);font-size:.74rem;}
      .frow.cat-link{justify-content:space-between;}
      .frow.cat-link.active{background:var(--ink);color:#fff;font-weight:600;}
      .frow.cat-link.active .fr-n{color:#c7ccd2;}
      .marca-search,select#f-tienda{width:100%;border:1px solid var(--line-2);border-radius:10px;padding:9px 11px;font-size:.86rem;color:var(--ink);background:#fff;outline:none;margin-bottom:8px;}
      .marca-search:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(220,38,38,.1);}
      select#f-tienda{margin-bottom:0;cursor:pointer;}
      .price-row{display:flex;align-items:center;gap:8px;}
      .price-row input{width:100%;border:1px solid var(--line-2);border-radius:10px;padding:8px 10px;font-size:.86rem;}
      .price-apply{margin-top:9px;width:100%;background:var(--surface2);border:1px solid var(--line-2);color:var(--ink-2);border-radius:10px;padding:9px;font-size:.82rem;font-weight:600;cursor:pointer;}
      .price-apply:hover{border-color:var(--red);color:var(--red);}
      .switch{display:flex;align-items:center;gap:9px;font-size:.875rem;color:var(--ink-2);cursor:pointer;}
      .switch input{accent-color:var(--ok);width:34px;height:20px;}
      .fil-aplicar{display:none;}

      /* ---------- Chips activos ---------- */
      .chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;}
      .chips:empty{display:none;}
      .chip-f{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line-2);border-radius:99px;padding:6px 9px 6px 13px;font-size:.83rem;color:var(--ink-2);}
      .chip-f b{font-weight:600;color:var(--ink);}
      .chip-f button{border:none;background:var(--surface2);color:#6b7280;width:18px;height:18px;border-radius:50%;line-height:1;font-size:.8rem;}
      .chip-clear{background:none;border:none;color:var(--red);font-size:.83rem;cursor:pointer;font-weight:600;padding:6px 4px;}
      .lead{color:var(--muted);margin:0 0 14px;font-size:1rem;}.lead strong,.lead b{color:var(--ink);font-weight:600;}

      /* ---------- Grid + tarjetas ---------- */
      .grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;}
      @media(min-width:1680px){.grid{grid-template-columns:repeat(6,minmax(0,1fr));}}
      .prod{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:transform .16s cubic-bezier(.2,.7,.3,1),box-shadow .16s,border-color .16s;}
      .prod:hover{transform:translateY(-3px);box-shadow:var(--shadow-h);border-color:var(--line-2);}
      .ph-box{position:relative;aspect-ratio:1/1;background:var(--photo);display:flex;align-items:center;justify-content:center;cursor:pointer;}
      .ph{width:100%;height:100%;object-fit:contain;padding:12px;display:block;}
      .ph-box.noimg{flex-direction:column;gap:5px;color:#aab1ba;cursor:pointer;}
      .ph-box.noimg::before{content:attr(data-mk);font-size:.82rem;font-weight:700;letter-spacing:.5px;color:#8b929b;}
      .ph-box.noimg::after{content:"Sin foto";font-size:.7rem;}
      .add{position:absolute;top:10px;right:10px;z-index:2;height:34px;min-width:34px;border-radius:99px;border:none;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;line-height:1;box-shadow:0 2px 8px rgba(220,38,38,.35);overflow:hidden;transition:padding .18s,gap .18s;padding:0;}
      .add .t{max-width:0;overflow:hidden;white-space:nowrap;font-size:.8rem;font-weight:600;transition:max-width .2s;}
      .prod:hover .add{padding:0 13px;gap:6px;}.prod:hover .add .t{max-width:90px;}
      .add:hover{background:var(--red-d);}
      .pbody{padding:12px 13px 14px;}
      .pmarca{font-size:.68rem;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);margin-bottom:3px;}
      .pdesc{font-size:.86rem;line-height:1.32;color:var(--ink);font-weight:500;min-height:2.3em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;overflow-wrap:anywhere;margin-bottom:9px;cursor:pointer;}
      .pprice{display:flex;align-items:baseline;gap:6px;margin-bottom:9px;}
      .pprice b{font-size:1.3rem;font-weight:700;letter-spacing:-.4px;color:var(--ink);}
      .pprice small{font-size:.68rem;color:var(--muted);font-weight:500;}
      .avail{display:flex;align-items:center;gap:7px;font-size:.76rem;flex-wrap:wrap;}
      .pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:99px;font-weight:600;}
      .pill.ok{background:var(--ok-bg);color:var(--ok);}.pill.warn{background:var(--warn-bg);color:var(--warn);}.pill.off{background:#fdecec;color:var(--err);}
      .pill .dot{width:6px;height:6px;border-radius:99px;background:currentColor;}
      .suc-line{color:var(--muted);}

      .pager{display:flex;gap:12px;align-items:center;justify-content:center;margin:28px 0 0;}
      .pager button{border:1px solid var(--line-2);background:var(--surface);color:var(--ink);border-radius:10px;padding:8px 14px;cursor:pointer;min-width:44px;font-size:1.05rem;}
      .pager button:disabled{opacity:.4;cursor:default;}

      /* ---------- Modal detalle ---------- */
      .modal-back{position:fixed;inset:0;z-index:60;background:rgba(8,9,12,.6);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px;}
      .modal{position:relative;background:var(--surface);border-radius:20px;max-width:880px;width:100%;max-height:90vh;overflow:auto;display:grid;grid-template-columns:1.1fr .9fr;box-shadow:0 30px 80px -30px rgba(0,0,0,.55);}
      .m-close{position:absolute;top:12px;right:14px;z-index:2;width:36px;height:36px;border-radius:50%;border:none;background:rgba(0,0,0,.5);color:#fff;font-size:1.4rem;line-height:1;cursor:pointer;}
      .m-gallery{background:var(--photo);padding:18px;display:flex;flex-direction:column;gap:10px;}
      .m-main-box{width:100%;height:340px;display:flex;align-items:center;justify-content:center;}
      .m-main-box.noimg{color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-size:.8rem;}
      .m-main{max-width:100%;max-height:100%;object-fit:contain;}
      .m-thumbs{display:flex;gap:8px;flex-wrap:wrap;}
      .m-thumb{width:56px;height:56px;object-fit:contain;background:#fff;border:2px solid transparent;border-radius:9px;cursor:pointer;}
      .m-thumb.sel{border-color:var(--red);}
      .m-info{padding:26px 24px;display:flex;flex-direction:column;gap:8px;}
      .m-info .pmarca{font-size:.72rem;}
      .m-desc{font-size:1.2rem;line-height:1.35;font-weight:600;margin:2px 0 4px;overflow-wrap:anywhere;}
      .m-price{font-size:1.7rem;font-weight:700;letter-spacing:-.5px;}.m-price small{font-size:.7rem;color:var(--muted);font-weight:500;margin-left:6px;}
      .m-add{display:flex;gap:8px;margin-top:14px;}
      .m-add input{width:64px;padding:11px;border:1px solid var(--line-2);border-radius:10px;}
      .m-add button{flex:1;background:var(--red);color:#fff;border:none;border-radius:11px;padding:12px;font-size:.95rem;font-weight:600;}
      .m-fullpage{display:inline-block;margin-top:14px;color:var(--red);font-weight:600;font-size:.88rem;}
      .m-sucs{margin-top:16px;}
      .m-sucs-t{font-size:.82rem;font-weight:700;color:var(--ok);margin-bottom:8px;}
      .m-sucs-t.off{color:var(--err);font-weight:500;line-height:1.4;}
      .suc-pills{display:flex;flex-wrap:wrap;gap:6px;}
      .suc-pill{font-size:.8rem;background:var(--ok-bg);color:var(--ok);border-radius:99px;padding:4px 11px;}
      .suc-pill .suc-city{opacity:.75;}

      /* ---------- Carrito (cajón) ---------- */
      .overlay{position:fixed;inset:0;background:rgba(8,9,12,.45);z-index:48;opacity:0;pointer-events:none;transition:opacity .2s;}
      .overlay.show{opacity:1;pointer-events:auto;}
      .drawer{position:fixed;top:0;right:0;height:100%;width:390px;max-width:92vw;background:var(--surface);z-index:50;box-shadow:-12px 0 40px -16px rgba(0,0,0,.4);transform:translateX(100%);transition:transform .24s ease;display:flex;flex-direction:column;}
      .drawer.open{transform:translateX(0);}
      .drawer-top{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line);}
      .drawer-top h3{margin:0;font-size:1.05rem;font-weight:700;}
      .drawer-top button{border:none;background:var(--surface2);width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:1.2rem;}
      .drawer-body{padding:16px 18px;overflow:auto;flex:1;}
      .chip{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.6px;padding:3px 9px;border-radius:99px;border:1px solid var(--line);color:var(--muted);}
      .cart-empty{text-align:center;color:var(--muted);padding:34px 6px;}.cart-emoji{font-size:2.4rem;margin-bottom:8px;}
      .cart-items{display:flex;flex-direction:column;gap:10px;margin-bottom:12px;}
      .ci{display:grid;grid-template-columns:1fr auto auto;gap:6px 8px;align-items:center;border-bottom:1px solid var(--line);padding-bottom:8px;}
      .ci-desc{font-size:.84rem;line-height:1.25;overflow-wrap:anywhere;}
      .ci-q{display:flex;align-items:center;gap:6px;}
      .ci-q .qbtn{background:var(--surface2);border:1px solid var(--line-2);color:var(--ink);width:26px;height:26px;border-radius:7px;padding:0;font-size:1rem;cursor:pointer;}
      .ci-q .qbtn:hover{border-color:var(--red);}
      .ci-q span{min-width:22px;text-align:center;font-size:.9rem;}
      .ci-sub{font-weight:700;font-size:.88rem;}
      .ci-del{grid-column:3;background:transparent;border:none;color:var(--muted);padding:0 4px;font-size:.85rem;cursor:pointer;}
      .ci-del:hover{color:var(--red);}
      .cart-cov{font-size:.82rem;margin:4px 0 10px;line-height:1.4;}
      .cov-ok{color:var(--ok);font-weight:500;}.cov-mix{color:var(--warn);}.cov-no{color:var(--err);}
      .cart-total{display:flex;justify-content:space-between;align-items:baseline;padding:10px 0;border-top:2px solid var(--ink);}
      .cart-total b{font-size:1.4rem;font-weight:700;color:var(--ink);}
      .cart-cta{background:var(--surface2);border-radius:12px;padding:12px;margin:8px 0 12px;text-align:center;}
      .cta-title{font-weight:700;color:var(--ink);font-size:1rem;}.cta-sub{color:var(--muted);font-size:.82rem;margin-top:3px;}
      .cart-tel{width:100%;background:var(--surface);color:var(--ink);border:1px solid var(--line-2);border-radius:10px;padding:11px 12px;font-size:.95rem;margin-bottom:10px;}
      .cart-tel:focus{border-color:var(--red);outline:none;}
      .cart-btn-big{width:100%;padding:14px;background:var(--red);color:#fff;border:none;border-radius:11px;cursor:pointer;font-size:.98rem;font-weight:600;}
      .cart-ok{text-align:center;padding:14px 4px;}.cart-ok h3{margin:6px 0;font-weight:700;}
      .notice{padding:11px 13px;border-radius:10px;margin-bottom:12px;font-size:.9rem;border:1px solid var(--line);}
      .notice.err{background:#fdecec;color:var(--err);border-color:#f1b0aa;}
      .ghost{background:transparent;border:1px solid var(--line-2);color:var(--ink);border-radius:10px;padding:11px;cursor:pointer;}

      #toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);background:#0a0b0d;color:#fff;padding:12px 20px;border-radius:12px;font-size:.9rem;z-index:70;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;box-shadow:0 10px 30px -10px rgba(0,0,0,.5);}
      #toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

      /* ---------- Responsive ---------- */
      @media(max-width:980px){
        .cat-layout{grid-template-columns:1fr;}
        .acceso{display:none;}
        #filtros-btn{display:inline-flex;}
        /* Ordenar en móvil: botón-pastilla chiquito. Ocultamos solo el texto "Orden:" (font-size:0
           sobre la etiqueta) y dejamos el <select> visible, estilizado igual que el de filtros. */
        .ctx-right label{display:inline-flex;align-items:center;font-size:0;gap:0;margin:0;}
        #orden{font-size:.84rem;-webkit-appearance:none;appearance:none;border:1px solid var(--line-2);border-radius:99px;padding:9px 30px 9px 14px;color:var(--ink);cursor:pointer;background:#fff url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" fill="none" stroke="%23727a84" stroke-width="2"><path d="M2 4l4 4 4-4"/></svg>') no-repeat right 11px center;}
        /* buscador + filtro flotantes: banda pegajosa bajo el header */
        .topsticky{position:sticky;top:58px;z-index:26;background:var(--page);padding-top:14px;}
        .searchbar{margin:0 0 10px;}
        .ctx-bar{margin:0 0 12px;}
        /* filtros como hoja inferior (bottom sheet) */
        .filters{position:fixed;left:0;right:0;bottom:0;top:auto;width:auto;max-width:none;max-height:86vh;border-radius:20px 20px 0 0;border:none;z-index:55;transform:translateY(100%);transition:transform .26s cubic-bezier(.2,.8,.2,1);box-shadow:0 -8px 30px rgba(0,0,0,.18);display:flex;flex-direction:column;}
        .filters.open{transform:translateY(0);}
        .fil-head{position:sticky;top:0;z-index:2;background:var(--surface);padding:16px 18px 8px;border-bottom:1px solid var(--line);}
        .fil-head button{display:flex;align-items:center;justify-content:center;}
        .filters .facet{padding-left:18px;padding-right:18px;}
        /* footer fijo real: sticky en el contenedor con scroll (antes absolute → caía a media lista) */
        .fil-aplicar{display:block;position:sticky;bottom:0;left:0;right:0;margin-top:auto;width:100%;background:var(--red);color:#fff;border:none;padding:16px;font-size:1rem;font-weight:600;cursor:pointer;z-index:2;box-shadow:0 -6px 16px rgba(0,0,0,.10);}
      }
      @media(max-width:760px){
        .topbar-in{padding:9px 13px;gap:9px;}
        .brand img{height:30px;}
        .topsticky{top:50px;}
        .wrap{padding:14px 12px 90px;}
        .grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:11px;}
        .prod:hover{transform:none;}
        /* móvil: solo "+" (sin "Agregar") para no tapar la foto */
        .add .t{display:none;}
        .pprice b{font-size:1.2rem;}
        .modal{grid-template-columns:1fr;}.m-main-box{height:260px;}
      }

/* ===================================================================
   COMPONENTES POR SUPERFICIE (bodega/vendedores + portal/clientes)
   Mismo lenguaje visual que el público — extras propios de cada una.
   =================================================================== */
/* Header de bodega: etiqueta + nombre del vendedor + cotizador + salir */
.vtag{flex:none;color:#cbd2da;font-size:.66rem;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;border:1px solid #2a2e34;border-radius:99px;padding:5px 11px;}
.vname{color:#cbd2da;font-size:.82rem;font-weight:500;}
.logout{color:#8b939d;background:none;border:none;cursor:pointer;font-size:.8rem;}
.logout:hover{color:#cfd6df;}
/* Toggle "Lo nuestro / Todo el universo" */
.modo{display:inline-flex;background:var(--surface2);border:1px solid var(--line-2);border-radius:11px;padding:3px;gap:2px;}
.modo button{border:none;background:transparent;color:var(--muted);font-size:.8rem;font-weight:600;padding:7px 13px;border-radius:8px;cursor:pointer;transition:.12s;}
.modo button.on{background:#fff;color:var(--ink);box-shadow:var(--shadow);}
/* Filtro de talla (pastillas) */
.talla-pill{border:1px solid var(--line-2);background:#fff;border-radius:9px;padding:5px 11px;font-size:.83rem;font-weight:600;cursor:pointer;color:var(--ink-2);}
.talla-pill:hover{border-color:var(--red);}
.talla-pill.on{background:var(--ink);color:#fff;border-color:var(--ink);}
/* Tarjeta bodega: código, talla, "en tu sucursal", badge tenemos/nuevo */
.pcodigo{font-size:.72rem;color:var(--muted);font-variant-numeric:tabular-nums;margin-bottom:5px;}
.pfolio{color:var(--red);font-weight:600;}
.ptalla{font-size:.74rem;font-weight:700;color:var(--red);margin:0 0 7px;}
.mia{display:inline-flex;align-items:center;gap:5px;font-size:.74rem;font-weight:600;color:var(--ok);margin-bottom:7px;}
.prod.nuevo{border-style:dashed;}
.badge{align-self:flex-start;font-size:.66rem;font-weight:700;letter-spacing:.4px;padding:4px 9px;border-radius:99px;margin-bottom:9px;}
.badge.tenemos{color:var(--ok);background:var(--ok-bg);}
.badge.nuevo{color:var(--warn);background:var(--warn-bg);}
/* Variante clara del botón flotante + (bodega: "Lo necesito" en productos del universo) */
.add.need{background:#fff;color:var(--ink-2);border:1px solid var(--line-2);box-shadow:0 2px 8px rgba(16,24,40,.2);}
.add.need:hover{background:#fff;border-color:var(--red);color:var(--red);}
/* Botón de acción inferior (Cotizar / Lo necesito / Agregar en bodega+portal) */
.padd{margin-top:auto;}
.padd button{width:100%;background:var(--red);color:#fff;border:none;border-radius:11px;padding:11px;font-size:.86rem;font-weight:600;cursor:pointer;}
.padd button:hover{background:var(--red-d);}
.padd button.need{background:var(--surface2);color:var(--ink-2);border:1px solid var(--line-2);}
.padd button.need:hover{border-color:var(--red);color:var(--red);background:#fff;}
/* Moto: chip actual + chips de aplicación */
.moto-current{display:inline-flex;align-items:center;gap:7px;background:var(--ink);color:#fff;border-radius:99px;padding:5px 12px;font-size:.82rem;font-weight:600;margin-bottom:8px;}
.moto-current button{border:none;background:rgba(255,255,255,.2);color:#fff;width:18px;height:18px;border-radius:50%;cursor:pointer;line-height:1;}
.apchip{display:inline-block;font-size:.78rem;background:var(--surface2);border:1px solid var(--line-2);border-radius:99px;padding:4px 11px;margin:0 5px 5px 0;cursor:pointer;color:var(--ink-2);}
.apchip.sug{border-style:dashed;color:var(--muted);}
/* Portal clientes: bloque de precios por rol */
.precios{display:flex;flex-direction:column;gap:3px;margin:2px 0 9px;}
.prow{display:flex;align-items:baseline;justify-content:space-between;font-size:.82rem;color:var(--ink-2);}
.prow.pub b,.prow.tuyo b{font-weight:700;color:var(--ink);}
.prow.tuyo{color:var(--ok);}.prow.tuyo b{color:var(--ok);}
.ubic,.m-ubic{font-size:.78rem;color:var(--ink-2);background:var(--surface2);border-radius:8px;padding:6px 9px;margin:4px 0;}
.ubic-lg{font-size:.9rem;}

/* ---- Alias para el PORTAL (clientes) — arma su UI en JS con clases con guion ---- */
.prod-body{padding:12px 13px 14px;display:flex;flex-direction:column;flex:1;}
.prod-marca{font-size:.68rem;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);margin-bottom:3px;}
.prod-desc{font-size:.86rem;line-height:1.32;color:var(--ink);font-weight:500;min-height:2.3em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;overflow-wrap:anywhere;margin-bottom:9px;cursor:pointer;}
.prod-sim{font-size:.72rem;font-weight:600;color:var(--red);margin-bottom:4px;}
/* Toolbar del portal → buscador protagonista */
.cat-toolbar{display:flex;align-items:center;gap:12px;margin:2px 0 16px;}
.tb-search{flex:1;display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line-2);border-radius:16px;padding:14px 18px;box-shadow:var(--shadow);}
.tb-search:focus-within{border-color:var(--red);box-shadow:0 0 0 4px rgba(220,38,38,.08),var(--shadow);}
.tb-search .q{flex:1;min-width:0;border:none;outline:none;background:transparent;font-size:1.08rem;color:var(--ink);}
.tb-search button{background:transparent;border:none;color:var(--muted);font-size:1.1rem;cursor:pointer;padding:3px;border-radius:8px;}
.tb-search button:hover{color:var(--ink);background:var(--surface2);}
.cart-toggle{flex:none;position:relative;display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:13px;background:var(--ink);border:none;color:#fff;font-size:1.2rem;}
.cart-toggle .ct-count{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;border-radius:99px;background:var(--red);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px;}

/* ---- Header (chrome) del portal — alinear al topbar negro + línea roja ---- */
.bar{background:#0a0b0d;border-bottom:2.5px solid var(--red);display:flex;align-items:center;gap:14px;padding:11px 20px;position:sticky;top:0;z-index:30;}
.bar-logo{height:32px;width:auto;display:block;}
.bar-title{color:#cbd2da;font-size:.9rem;font-weight:500;}
.bar-user{margin-left:auto;display:flex;align-items:center;gap:12px;}
.bar-nombre{color:#cbd2da;font-size:.85rem;}
.bar .chip{color:#cbd2da;border-color:#2a2e34;}
.bar .ghost.small{color:#cbd2da;background:transparent;border:1px solid #2a2e34;border-radius:9px;padding:7px 12px;font-size:.82rem;cursor:pointer;}
.bar .ghost.small:hover{border-color:#4b5158;}

/* ---- Infinite scroll (centinela + spinner + "Ver más") ---- */
.io-sentinel{display:flex;align-items:center;justify-content:center;gap:9px;color:var(--muted);font-size:.88rem;padding:26px 0;}
.spinner{width:16px;height:16px;border:2px solid var(--line-2);border-top-color:var(--red);border-radius:50%;animation:spin .7s linear infinite;flex:none;}
@keyframes spin{to{transform:rotate(360deg);}}
.vermas{display:block;margin:26px auto 0;border:1px solid var(--line-2);background:#fff;color:var(--ink);border-radius:12px;padding:12px 30px;font-size:.92rem;font-weight:600;cursor:pointer;box-shadow:var(--shadow);}
.vermas:hover{border-color:var(--red);color:var(--red);}
.end-msg{text-align:center;color:var(--muted);font-size:.88rem;padding:26px 0;}
