*{box-sizing:border-box}
body.uni-mobile-cart-page{
  margin:0;
  min-height:100vh;
  background:
    radial-gradient(circle at 10% 5%,rgba(124,58,237,.16),transparent 28%),
    radial-gradient(circle at 90% 0%,rgba(14,165,233,.18),transparent 24%),
    linear-gradient(180deg,#f8fbff,#fdf7ff);
  color:#172033;
  padding-bottom:28px;
}
.umc-top{
  position:sticky;
  top:0;
  z-index:20;
  display:grid;
  grid-template-columns:44px 1fr 44px;
  gap:10px;
  align-items:center;
  padding:10px 12px;
  background:rgba(255,255,255,.94);
  border-bottom:1px solid #e5e7eb;
  backdrop-filter:blur(14px);
}
.umc-top strong{display:block;font-weight:950;font-size:1rem}
.umc-top span{display:block;font-size:.76rem;color:#64748b;font-weight:800}
.umc-back,.umc-mini{
  width:44px;height:44px;
  display:grid;place-items:center;
  text-decoration:none;
  border-radius:16px;
  background:#f5f3ff;
  color:#5b21b6;
  font-weight:950;
}
.umc-wrap{width:100%;max-width:560px;margin:0 auto;padding:14px 12px 120px}
.umc-title{margin:8px 0 14px}
.umc-title h1{margin:0;font-size:1.55rem;line-height:1.05;font-weight:950}
.umc-title p{margin:6px 0 0;color:#64748b;font-weight:750;line-height:1.35}
.umc-list{display:grid;gap:12px}
.umc-card{
  display:grid;
  grid-template-columns:104px 1fr;
  gap:12px;
  position:relative;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:24px;
  padding:12px;
  box-shadow:0 14px 34px rgba(15,23,42,.09);
  overflow:hidden;
}
.umc-card.is-school{border-color:#c4b5fd;background:linear-gradient(180deg,#fff,#fbf7ff)}
.umc-img{
  width:104px;
  min-height:104px;
  border-radius:18px;
  background:#f8fafc;
  border:1px dashed #c4b5fd;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.umc-img img{max-width:94%;max-height:94%;object-fit:contain;display:block}
.umc-noimg{font-size:2rem}
.umc-info{min-width:0}
.umc-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.umc-badges span,.umc-badges em{
  font-style:normal;
  border-radius:999px;
  padding:4px 7px;
  font-size:.66rem;
  font-weight:950;
  background:#eef2ff;
  color:#5b21b6;
  border:1px solid #ddd6fe;
}
.umc-badges em{background:#f8fafc;color:#475569;border-color:#e2e8f0}
.umc-info h2{font-size:.98rem;line-height:1.14;margin:0 0 7px;font-weight:950;color:#172033}
.umc-meta{display:grid;gap:2px;font-size:.76rem;color:#64748b;font-weight:850}
.umc-note{margin-top:6px;font-size:.74rem;color:#475569;font-weight:800;background:#f8fafc;border-radius:12px;padding:6px 8px}
.umc-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:9px}
.umc-actions form{margin:0}
.umc-small-btn{
  border:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:7px 10px;
  border-radius:12px;
  background:#f1f5f9;
  color:#334155;
  text-decoration:none;
  font-weight:950;
  font-size:.78rem;
}
.umc-small-btn.danger{background:#fff1f2;color:#be123c}
.umc-price{
  grid-column:1 / -1;
  justify-self:end;
  color:#16a34a;
  font-size:1.05rem;
  font-weight:950;
}
.umc-total{
  position:fixed;
  left:10px;
  right:10px;
  bottom:10px;
  z-index:30;
  max-width:560px;
  margin:0 auto;
  background:rgba(255,255,255,.96);
  border:1px solid #ddd6fe;
  border-radius:24px;
  padding:12px;
  box-shadow:0 20px 50px rgba(15,23,42,.18);
  backdrop-filter:blur(14px);
}
.umc-total > div:first-child{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
  font-weight:900;
  color:#64748b;
}
.umc-total strong{color:#16a34a;font-size:1.25rem}
.umc-btn{
  width:100%;
  min-height:46px;
  border:0;
  border-radius:16px;
  padding:12px 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-weight:950;
  font-size:.94rem;
  cursor:pointer;
}
.umc-btn.primary{background:linear-gradient(135deg,#7c3aed,#0ea5e9);color:#fff}
.umc-btn.soft{background:#f5f3ff;color:#5b21b6}
.umc-btn.ghost{background:#f8fafc;color:#64748b}
.umc-total-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.umc-total-actions form{margin:0}
.umc-empty{
  min-height:70vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:10px;
}
.umc-empty-icon{font-size:3rem}
.umc-empty h1{margin:0;font-weight:950}
.umc-empty p{margin:0;color:#64748b;font-weight:800;line-height:1.35}
@media(min-width:761px){
  body.uni-mobile-cart-page:before{
    content:"Vista móvil";
    position:fixed;
    top:10px;
    right:10px;
    z-index:50;
    padding:6px 10px;
    border-radius:999px;
    background:#111827;
    color:#fff;
    font-size:.72rem;
    font-weight:950;
  }
}

/* UNI_MOBILE_CART_REAL_DB_V4 */
.umc-svg-inline{
  width:100%;
  height:100%;
  min-height:100px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.umc-svg-inline svg{
  width:100% !important;
  height:100% !important;
  max-width:100% !important;
  max-height:122px !important;
  display:block !important;
}

.umc-svg-inline image{
  image-rendering:auto;
}

.umc-meta span:nth-child(3){
  color:#5b21b6 !important;
  font-weight:950 !important;
}
