 :root {
  --blue: #0f4fa8;
  --blue-dark: #0a3774;
  --orange: #f28b20;
  --orange-dark: #da7410;
  --white: #ffffff;
  --bg: #f3f6fb;
  --text: #1f2a37;
  --muted: #64748b;
  --border: #dce4ef;
  --shadow: 0 10px 30px rgba(15, 79, 168, 0.10);
  --radius: 18px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  background: var(--bg);
  color: var(--text);
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.container {
  width: min(1140px, calc(100% - 32px));
  margin: 0 auto;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 30;
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}

.header-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 84px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
}

.brand-logo {
  height: 54px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.12));
}

.brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}

.brand-text strong {
  font-size: 1.35rem;
  color: var(--blue);
}

.brand-text span {
  font-size: 0.95rem;
  color: var(--muted);
}

.main-nav {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.main-nav a {
  font-weight: 700;
  color: var(--blue-dark);
}

.header-actions {
  display: flex;
  gap: 10px;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 12px;
  border: 0;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.18s ease, opacity 0.18s ease, background 0.18s ease;
}

.btn:hover { transform: translateY(-1px); }

.btn-primary { background: var(--blue); color: var(--white); }
.btn-primary:hover { background: var(--blue-dark); }
.btn-accent { background: var(--orange); color: var(--white); }
.btn-accent:hover { background: var(--orange-dark); }
.btn-outline {
  background: var(--white);
  color: var(--blue);
  border: 1px solid var(--border);
}

.hero {
  background:
    linear-gradient(135deg, rgba(15,79,168,0.98), rgba(10,55,116,0.95)),
    radial-gradient(circle at top right, rgba(242,139,32,0.28), transparent 30%);
  color: var(--white);
  padding: 72px 0;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.3fr 0.9fr;
  gap: 28px;
  align-items: center;
}

.eyebrow {
  display: inline-block;
  margin-bottom: 12px;
  padding: 8px 12px;
  background: rgba(255,255,255,0.14);
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.92rem;
}

.hero h1 {
  margin: 0 0 12px;
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: 1.05;
}

.hero p {
  margin: 0;
  max-width: 650px;
  font-size: 1.08rem;
  line-height: 1.6;
  color: rgba(255,255,255,0.92);
}

.hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 24px;
}

.hero-card,
.info-card,
.about-box,
.contact-box,
.product-card,
.mini-card {
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.hero-card {
  color: var(--text);
  padding: 26px;
  border: 1px solid rgba(255,255,255,0.15);
}

.hero-card h3 { margin-top: 0; color: var(--blue); }
.hero-card ul {
  margin: 0;
  padding-left: 18px;
  line-height: 1.8;
  color: var(--text);
}

.section { padding: 64px 0; }
.section.alt { background: #edf3fb; }

.section-head { margin-bottom: 24px; }
.section-head h2 {
  margin: 0 0 10px;
  font-size: 2rem;
  color: var(--blue-dark);
}
.section-head p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.category-grid,
.product-grid,
.service-grid {
  display: grid;
  gap: 18px;
}

.category-grid { grid-template-columns: repeat(6, 1fr); }
.product-grid { grid-template-columns: repeat(4, 1fr); }
.service-grid { grid-template-columns: repeat(4, 1fr); }

.mini-card {
  padding: 18px;
  text-align: center;
  font-weight: 700;
  color: var(--blue-dark);
  border: 1px solid var(--border);
}

.product-card {
  overflow: hidden;
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
}

.product-image {
  height: 180px;
  background: linear-gradient(135deg, #dfeafb, #fef3e7);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue);
  font-weight: 700;
  font-size: 1.08rem;
  padding: 16px;
  text-align: center;
}

.product-body { padding: 18px; display:flex; flex-direction:column; flex:1; }
.product-body h3 {
  margin: 0 0 10px;
  font-size: 1.05rem;
}
.product-body p {
  margin: 0 0 14px;
  color: var(--muted);
  min-height: 66px;
}

.price-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: auto;
}

.price {
  color: var(--orange-dark);
  font-weight: 800;
  font-size: 1.2rem;
}

.product-link {
  display: inline-block;
  margin-top: 10px;
  color: var(--blue);
  font-weight: 700;
}

.info-card,
.about-box,
.contact-box {
  padding: 24px;
  border: 1px solid var(--border);
}

.info-card h3,
.contact-box h3 {
  margin-top: 0;
  color: var(--blue);
}

.info-card p,
.about-box p,
.contact-box p {
  margin-bottom: 0;
  color: var(--muted);
  line-height: 1.7;
}

.contact-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 20px;
  align-items: start;
}

.contact-list p {
  margin: 0 0 12px;
  color: var(--text);
}


.contact-hours {
  margin: 0 0 12px;
  color: var(--text);
}

.hours-row {
  display: grid;
  grid-template-columns: 92px 56px 1fr;
  align-items: baseline;
  column-gap: 10px;
  margin-bottom: 4px;
}

.hours-row:last-child {
  margin-bottom: 0;
}

.hours-label {
  font-weight: 800;
}

.hours-day,
.hours-time {
  display: inline-block;
}

.hours-second {
  padding-left: 102px;
  grid-template-columns: 56px 1fr;
}

.map-box {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.map-embed {
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: #e7eef8;
}

.map-embed iframe {
  display: block;
  width: 100%;
  height: 290px;
  border: 0;
}

.cart-subtitle{
  margin:6px 0 0;
  color: var(--muted);
  font-size: .95rem;
}

.cart-panel {
  position: fixed;
  top: 0;
  right: -460px;
  width: 440px;
  max-width: 95vw;
  height: 100vh;
  background: #ffffff;
  box-shadow: -10px 0 35px rgba(0,0,0,0.16);
  z-index: 100;
  display: flex;
  flex-direction: column;
  transition: right 0.28s ease;
}

.cart-panel.open { right: 0; }

.cart-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--border);
}

.cart-header h3 {
  margin: 0;
  color: var(--blue-dark);
  font-size: 1.45rem;
  line-height: 1.1;
}

.cart-close {
  border: 0;
  background: transparent;
  font-size: 28px;
  cursor: pointer;
  color: var(--blue-dark);
  line-height: 1;
}

.cart-items {
  flex: 1 1 auto;
  overflow: auto;
  padding: 8px 16px 4px;
}

.cart-item {
  border-bottom: 1px solid var(--border);
  padding: 10px 0;
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 10px;
  align-items: start;
}

.cart-item:last-child { border-bottom: 0; }

.cart-item-media{
  width: 64px;
  height: 64px;
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  background: #f8fafc;
  display:flex;
  align-items:center;
  justify-content:center;
}

.cart-item-media img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.cart-item-media-fallback{
  color: var(--blue-dark);
  font-weight: 800;
  font-size: .95rem;
}

.cart-item-body{
  min-width: 0;
}

.cart-item h4 {
  margin: 0 0 4px;
  font-size: .92rem;
  line-height: 1.2;
  color: #111827;
}

.cart-item-meta {
  margin: 0 0 7px;
  color: var(--muted);
  font-size: .82rem;
}

.cart-item-price-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom: 8px;
}

.cart-unit-price{
  font-size: .82rem;
  color: var(--blue-dark);
  font-weight: 700;
}

.cart-line-total{
  font-weight: 800;
  color: var(--blue-dark);
  font-size: .95rem;
}

.cart-actions {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}

.cart-actions button {
  border: 0;
  border-radius: 10px;
  padding: 6px 10px;
  cursor: pointer;
  font-weight: 700;
  font-size: .88rem;
}

.qty-btn { background: #eef3fb; color: var(--blue-dark); min-width: 34px; }
.qty-value{ background:#ffffff; border:1px solid var(--border); }
.remove-btn { background: #ffe2e2; color: #b42318; }

.cart-shipping{
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 10px 16px;
}

.cart-shipping-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-weight:800;
  color: var(--blue-dark);
  font-size: .95rem;
}

.shipping-toggle{
  border:0;
  background: transparent;
  font-size: 1.45rem;
  line-height: 1;
  cursor:pointer;
  color: var(--blue-dark);
}

.shipping-box{
  display:none;
  color: var(--muted);
  padding-top: 8px;
  line-height: 1.45;
  font-size: .9rem;
}

.shipping-box.open{ display:block; }
.shipping-options{
  display:grid;
  gap:8px;
}

.shipping-option{
  display:flex;
  align-items:center;
  gap:8px;
  padding: 8px 10px;
  border:1px solid var(--border);
  border-radius: 12px;
  background:#f8fafc;
  color: var(--blue-dark);
  font-weight: 700;
}

.shipping-option input{
  accent-color: #1d57b7;
}

.cart-note{ padding: 10px 16px 6px; }
.cart-note label{
  display:block;
  margin-bottom: 6px;
  font-weight: 800;
  color: var(--blue-dark);
  font-size: .95rem;
}
.cart-note textarea{
  width:100%;
  min-height: 72px;
  resize: vertical;
  border:1px solid var(--border);
  border-radius: 12px;
  padding: 12px 14px;
  font-family: Arial, Helvetica, sans-serif;
  font-size: .92rem;
}

.cart-footer {
  border-top: 1px solid var(--border);
  padding: 10px 16px 14px;
}

.cart-summary-row,
.cart-total-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom: 10px;
}

.cart-summary-row{
  color: var(--blue-dark);
  font-size: .94rem;
}

.cart-summary-row.light{ color: var(--muted); }

.cart-total-row{
  margin: 12px 0 10px;
  font-size: 1rem;
  font-weight: 800;
  color: #111827;
}

.cart-main-btn{
  width:100%;
  min-height:48px;
  font-size:.95rem;
}

.cart-secondary-btn{
  width:100%;
  min-height:42px;
  margin-bottom: 8px;
  border:1px solid var(--border);
  border-radius: 14px;
  background:#ffffff;
  color: var(--blue-dark);
  font-size:.95rem;
  font-weight:800;
  cursor:pointer;
}

.cart-link-btn{
  width:100%;
  border:0;
  background:transparent;
  padding:10px 8px 2px;
  font-size:.95rem;
  cursor:pointer;
  color: var(--blue-dark);
}

.empty-cart {
  color: var(--muted);
  line-height: 1.45;
  padding: 12px;
  border: 1px dashed var(--border);
  border-radius: 14px;
  background: #f8fafc;
}

.login-modal {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.55);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 200;
  padding: 20px;
}

.login-modal.open,
.login-modal.show { display: flex; }

.login-box {
  width: 100%;
  max-width: 420px;
  background: #ffffff;
  border-radius: 18px;
  box-shadow: 0 20px 40px rgba(0,0,0,0.18);
  padding: 22px;
}

.login-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.login-head h3 {
  margin: 0;
  color: var(--blue-dark);
}

.login-text {
  color: var(--muted);
  margin: 10px 0 16px;
}

.login-form {
  display: grid;
  gap: 14px;
}

.login-form label {
  display: grid;
  gap: 6px;
  font-weight: 700;
  color: var(--blue-dark);
}

.login-form input {
  min-height: 46px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 0 14px;
  font-size: 1rem;
}

.login-submit {
  width: 100%;
  margin-top: 6px;
}

.login-status {
  min-height: 24px;
  margin: 12px 0 0;
  font-weight: 700;
  color: #b42318;
}

.login-status.ok { color: #027a48; }

.login-demo {
  margin-top: 14px;
  padding: 12px;
  border-radius: 12px;
  background: #f8fafc;
  color: var(--muted);
  font-size: 0.95rem;
}

/* Página individual */
.product-page {
  padding: 28px 0 60px;
}

.product-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--muted);
  margin-bottom: 20px;
  font-size: 0.95rem;
}

.product-detail-layout {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 34px;
  align-items: start;
}

.product-gallery {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 18px;
}

.product-thumb-list {
  display: grid;
  gap: 14px;
}

.product-thumb {
  min-height: 96px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: linear-gradient(135deg, #edf4ff, #fff4e8);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  text-align: center;
  color: var(--blue);
  font-weight: 700;
  cursor: pointer;
}

.product-main-image {
  min-height: 520px;
  border-radius: 24px;
  background: linear-gradient(135deg, #edf4ff, #fff4e8);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 30px;
  text-align: center;
  color: var(--blue);
  font-size: 2rem;
  font-weight: 800;
  box-shadow: var(--shadow);
}

.product-category {
  margin: 0 0 10px;
  color: var(--muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.product-info h1 {
  margin: 0 0 18px;
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 1.08;
  color: #111827;
}

.product-price-main {
  font-size: 2rem;
  font-weight: 800;
  color: #111827;
  margin-bottom: 8px;
}

.product-tax-note {
  margin: 0 0 14px;
  color: var(--muted);
}

.product-highlight {
  margin: 0 0 22px;
  color: var(--blue);
  font-weight: 700;
}

.product-purchase-box {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 12px;
  margin-bottom: 14px;
}

.qty-selector {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 54px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #fff;
  overflow: hidden;
}

.qty-selector button {
  width: 44px;
  height: 54px;
  border: 0;
  background: #fff;
  font-size: 1.5rem;
  cursor: pointer;
}

.qty-selector span {
  font-size: 1.15rem;
  font-weight: 800;
}

.product-add-btn {
  min-height: 54px;
  font-size: 1.05rem;
}

.product-added-msg {
  min-height: 24px;
  margin: 0 0 18px;
  color: #027a48;
  font-weight: 700;
}

.product-accordion {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin: 18px 0 22px;
}

.product-accordion-btn {
  width: 100%;
  border: 0;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0;
  font-size: 1rem;
  font-weight: 800;
  cursor: pointer;
  color: var(--blue-dark);
}

.product-accordion-box {
  display: none;
  padding: 0 0 16px;
  color: var(--muted);
  line-height: 1.7;
}

.product-accordion-box.open {
  display: block;
}

.back-link {
  color: var(--blue);
  font-weight: 700;
}

@media (max-width: 980px) {
  .hero-grid,
  .contact-grid,
  .product-grid,
  .service-grid,
  .category-grid,
  .product-detail-layout {
    grid-template-columns: repeat(2, 1fr);
  }

  .product-grid { grid-template-columns: repeat(2, 1fr); }

  .header-wrap {
    flex-wrap: wrap;
    justify-content: center;
    padding: 14px 0;
  }

  .main-nav { justify-content: center; }
}

@media (max-width: 760px) {
  .product-detail-layout,
  .product-gallery,
  .product-purchase-box {
    grid-template-columns: 1fr;
  }

  .product-main-image {
    min-height: 320px;
    font-size: 1.5rem;
  }

  .product-thumb-list {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 640px) {
  .hero-grid,
  .contact-grid,
  .product-grid,
  .service-grid,
  .category-grid {
    grid-template-columns: 1fr;
  }

  .brand {
    width: 100%;
    justify-content: center;
  }

  .header-actions,
  .main-nav,
  .hero-actions {
    width: 100%;
    justify-content: center;
  }

  .site-header { position: static; }
  .hero { padding: 54px 0; }
  .section { padding: 52px 0; }
}


.section-head-flex{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}

.category-grid-home{
  grid-template-columns: repeat(4, 1fr);
}

.store-page{
  padding: 28px 0 60px;
}

.store-title{
  margin:0;
  font-size: clamp(2rem, 4vw, 3rem);
  color: var(--blue-dark);
}

.store-layout{
  display:grid;
  grid-template-columns: 290px 1fr;
  gap: 24px;
  align-items:start;
}

.store-sidebar{
  display:grid;
  gap:18px;
  position: sticky;
  top: 100px;
}

.filter-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 20px;
}

.filter-card h3{
  margin:0 0 14px;
  color: var(--blue-dark);
}

.filter-btn{
  width:100%;
  text-align:left;
  border:1px solid var(--border);
  background:#fff;
  color: var(--text);
  border-radius: 12px;
  padding: 11px 12px;
  margin-bottom: 10px;
  cursor:pointer;
  font-weight:700;
}

.filter-btn.active{
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
}

.store-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom: 22px;
  flex-wrap:wrap;
}

.search-input{
  flex:1;
  min-width: 260px;
  min-height: 48px;
  border:1px solid var(--border);
  border-radius: 14px;
  padding: 0 16px;
  font-size: 1rem;
  background:#fff;
}

.toolbar-note{
  color: var(--muted);
  font-weight:700;
}

.store-grid{
  grid-template-columns: repeat(3, 1fr);
}

.product-meta{
  margin: 0 0 12px;
  color: var(--muted);
  font-size: .95rem;
}

.empty-store{
  background:#fff;
  border:1px solid var(--border);
  border-radius: 18px;
  padding: 30px;
  color: var(--muted);
}

@media (max-width: 1100px){
  .store-grid{
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 900px){
  .store-layout{
    grid-template-columns: 1fr;
  }

  .store-sidebar{
    position: static;
  }

  .category-grid-home{
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px){
  .store-grid,
  .category-grid-home{
    grid-template-columns: 1fr;
  }
}


.locked-text{
  color: var(--muted);
  font-weight: 700;
}

.locked-text.small{
  font-size: 0.95rem;
  margin-bottom: 8px;
}

.product-stock{
  color: #027a48;
  font-weight: 700;
  margin: 0 0 10px;
}

.detail-stock{
  margin: 0 0 16px;
}

.detail-locked{
  margin: 0 0 16px;
  font-size: 1.05rem;
}


.auth-box {
  max-width: 520px;
}

.auth-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 14px 0 16px;
}

.auth-tab {
  min-height: 44px;
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 12px;
  font-weight: 800;
  cursor: pointer;
  color: var(--blue-dark);
}

.auth-tab.active {
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
}

.login-form select {
  min-height: 46px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 0 14px;
  font-size: 1rem;
  background: #fff;
}


.user-welcome {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  color: var(--blue-dark);
}

.logout-btn {
  padding: 6px 10px;
  font-size: 0.9rem;
}


.header-pro {
  min-height: 96px;
  gap: 20px;
}

.brand {
  flex-shrink: 0;
}

.brand-logo {
  height: 64px;
  width: auto;
  object-fit: contain;
  display: block;
}

.main-nav {
  flex: 1;
  justify-content: center;
}

.header-search {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 280px;
  max-width: 360px;
  width: 100%;
}

.header-search input {
  flex: 1;
  min-height: 44px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 0 14px;
  font-size: 0.98rem;
  background: #fff;
}

.search-btn {
  min-height: 44px;
  border: 0;
  border-radius: 12px;
  padding: 0 16px;
  background: var(--blue);
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.search-btn:hover {
  background: var(--blue-dark);
}

.user-welcome {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  color: var(--blue-dark);
  flex-wrap: wrap;
}

.logout-btn {
  padding: 6px 10px;
  font-size: 0.9rem;
}

@media (max-width: 1180px) {
  .header-pro {
    flex-wrap: wrap;
    justify-content: center;
    padding: 12px 0;
  }

  .main-nav {
    order: 3;
    width: 100%;
    justify-content: center;
  }

  .header-search {
    order: 2;
    max-width: 520px;
  }

  .header-actions {
    order: 2;
  }
}

@media (max-width: 720px) {
  .brand-logo {
    height: 56px;
  }

  .header-search {
    min-width: 100%;
  }

  .header-actions {
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
  }
}


.header-dynamic {
  min-height: 130px;
  padding: 10px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
}

.brand-large {
  flex-shrink: 0;
}

.brand-logo-xl {
  height: 110px;
  width: auto;
  object-fit: contain;
  display: block;
}

.public-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 26px;
  flex: 1;
  flex-wrap: wrap;
}

.public-nav a,
.menu-dropdown-box a {
  font-weight: 700;
  color: var(--blue-dark);
}

.header-auth-public {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.header-private {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex: 1;
}

.header-private-right {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.header-search {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 320px;
  max-width: 420px;
  width: 100%;
}

.cart-inline-btn {
  white-space: nowrap;
}

.menu-dropdown {
  position: relative;
}

.menu-toggle-btn {
  min-height: 44px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 0 16px;
  background: #fff;
  color: var(--blue-dark);
  font-weight: 700;
  cursor: pointer;
}

.menu-dropdown-box {
  position: absolute;
  right: 0;
  top: calc(100% + 10px);
  min-width: 220px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--shadow);
  padding: 10px;
  display: none;
  z-index: 60;
}

.menu-dropdown-box.open {
  display: grid;
}

.menu-dropdown-box a {
  padding: 10px 12px;
  border-radius: 10px;
}

.menu-dropdown-box a:hover {
  background: #f4f7fb;
}

.user-welcome {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  color: var(--blue-dark);
  flex-wrap: wrap;
}

@media (max-width: 1150px) {
  .header-dynamic {
  min-height: 130px;
  padding: 10px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
}

  .public-nav {
    order: 3;
    width: 100%;
  }

  .header-private,
  .header-auth-public {
    order: 2;
    width: 100%;
    justify-content: center;
  }

  .header-private {
    flex-direction: column;
  }

  .header-private-right {
    justify-content: center;
  }
}

@media (max-width: 720px) {
  .brand-logo-xl {
  height: 110px;
  width: auto;
  object-fit: contain;
  display: block;
}

  .public-nav {
    gap: 14px;
  }

  .header-search {
    min-width: 100%;
  }

  .user-welcome {
    justify-content: center;
  }
}


.header-dynamic {
  min-height: 130px;
  padding: 10px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 26px;
}

.brand-logo-xl {
  height: 110px;
  width: auto;
  object-fit: contain;
  display: block;
}

.header-search-always {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 320px;
  max-width: 620px;
  width: 100%;
}

.header-search-always input {
  flex: 1;
  min-height: 50px;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 0 16px;
  font-size: 1rem;
  background: #fff;
}

.header-right-zone {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.user-box-inline {
  display: flex;
  align-items: center;
}

.user-welcome-inline {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  color: var(--blue-dark);
  flex-wrap: wrap;
}

.header-menu-public .menu-toggle-btn {
  min-height: 46px;
}

.cart-inline-btn {
  min-height: 46px;
  white-space: nowrap;
}

@media (max-width: 1180px) {
  .header-dynamic {
    flex-wrap: wrap;
    justify-content: center;
    padding: 12px 0;
  }

  .header-search-always {
    order: 2;
    max-width: 100%;
  }

  .header-right-zone {
    order: 3;
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 720px) {
  .brand-logo-xl {
    height: 90px;
  }

  .header-search-always {
    min-width: 100%;
  }

  .user-welcome-inline {
    justify-content: center;
  }
}


.user-box-inline {
  display: flex;
  align-items: center;
  min-width: fit-content;
}

.user-welcome-inline {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: nowrap;
  white-space: nowrap;
}

.logout-btn {
  min-height: 42px;
}


.account-page {
  padding: 28px 0 60px;
}

.account-header h1 {
  margin: 0 0 8px;
  font-size: clamp(2rem, 4vw, 3rem);
  color: var(--blue-dark);
}

.account-header p {
  margin: 0 0 24px;
  color: var(--muted);
}

.account-layout {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 22px;
  align-items: start;
}

.account-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: var(--shadow);
  padding: 24px;
}

.account-card h2,
.account-card h3 {
  margin-top: 0;
  color: var(--blue-dark);
}

.account-form {
  display: grid;
  gap: 14px;
}

.account-form label {
  display: grid;
  gap: 6px;
  font-weight: 700;
  color: var(--blue-dark);
}

.account-form input,
.account-form select {
  min-height: 46px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 0 14px;
  font-size: 1rem;
  background: #fff;
}

.account-summary p {
  margin: 0 0 12px;
  color: var(--text);
}

.account-status {
  min-height: 24px;
  margin-top: 12px;
  font-weight: 700;
  color: #b42318;
}

.account-status.ok {
  color: #027a48;
}

.account-logged-out {
  max-width: 680px;
}

@media (max-width: 900px) {
  .account-layout {
    grid-template-columns: 1fr;
  }
}


.field-help {
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 400;
}


.price-box {
  display: grid;
  gap: 4px;
}

.price-tag,
.product-price-type,
.user-type-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 4px 10px;
  border-radius: 999px;
  background: #e8eef8;
  color: var(--blue-dark);
  font-size: 0.82rem;
  font-weight: 800;
}

.user-type-badge {
  background: #fff3e6;
  color: var(--orange-dark);
}

.product-price-type {
  margin-bottom: 8px;
}

.product-price-main {
  margin-top: 0;
}


.cart-client-type {
  padding: 12px 20px 0;
  color: var(--blue-dark);
  font-weight: 700;
}

.cart-client-type strong {
  color: var(--orange-dark);
}


.admin-page {
  padding: 28px 0 60px;
}

.admin-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}

.admin-head h1 {
  margin: 0 0 8px;
  font-size: clamp(2rem, 4vw, 3rem);
  color: var(--blue-dark);
}

.admin-head p {
  margin: 0;
  color: var(--muted);
}

.admin-login-wrap {
  max-width: 620px;
}

.admin-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: var(--shadow);
  padding: 24px;
}

.admin-login-card h2 {
  margin-top: 0;
  color: var(--blue-dark);
}

.admin-note {
  margin-top: 14px;
  padding: 12px;
  border-radius: 12px;
  background: #f8fafc;
  color: var(--muted);
}

.admin-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-bottom: 22px;
}

.admin-stat-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--shadow);
  padding: 20px;
  display: grid;
  gap: 8px;
}

.admin-stat-card span {
  color: var(--muted);
  font-weight: 700;
}

.admin-stat-card strong {
  font-size: 2rem;
  color: var(--blue-dark);
}

.admin-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 22px;
  flex-wrap: wrap;
}

.admin-layout {
  display: grid;
  grid-template-columns: 1.3fr 0.7fr;
  gap: 22px;
  align-items: start;
}

.admin-table-wrap {
  overflow-x: auto;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
}

.admin-table th,
.admin-table td {
  border-bottom: 1px solid var(--border);
  padding: 14px 12px;
  text-align: left;
  vertical-align: top;
}

.admin-table th {
  color: var(--blue-dark);
  font-size: 0.95rem;
}

.admin-row-btn {
  min-height: 40px;
}

.admin-no-results {
  color: var(--muted);
  text-align: center;
  padding: 20px;
}

.admin-type-pill {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: #e8eef8;
  color: var(--blue-dark);
  font-weight: 800;
  font-size: 0.85rem;
}

.admin-type-pill.is-mayorista {
  background: #fff3e6;
  color: var(--orange-dark);
}

.admin-detail-list p {
  margin: 0 0 12px;
}

.admin-type-actions {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.admin-empty-box {
  color: var(--muted);
  line-height: 1.6;
}

@media (max-width: 980px) {
  .admin-layout {
    grid-template-columns: 1fr;
  }

  .admin-stats {
    grid-template-columns: 1fr;
  }
}


.forgot-pass-btn {
  margin-top: 10px;
  border: 0;
  background: transparent;
  color: var(--blue);
  font-weight: 700;
  cursor: pointer;
  text-align: left;
  padding: 0;
}


.forgot-pass-help {
  margin-top: 10px;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.5;
}


.admin-sep {
  border: 0;
  border-top: 1px solid var(--border);
  margin: 22px 0;
}

.admin-invoice-form {
  display: grid;
  gap: 12px;
  margin-bottom: 18px;
}

.admin-invoice-form label {
  display: grid;
  gap: 6px;
  font-weight: 700;
  color: var(--blue-dark);
}

.admin-invoice-form input[type="text"],
.admin-invoice-form input[type="file"] {
  min-height: 46px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 10px 14px;
  background: #fff;
}

.facturas-lista {
  display: grid;
  gap: 12px;
}

.factura-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #fff;
  flex-wrap: wrap;
}

.factura-info {
  display: grid;
  gap: 4px;
}

.factura-info strong {
  color: var(--blue-dark);
}

.factura-info span {
  color: var(--muted);
  font-size: 0.92rem;
}

.factura-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}


.pedidos-lista {
  display: grid;
  gap: 14px;
}

.pedido-item {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px;
  background: #fff;
}

.pedido-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}

.pedido-top div {
  display: grid;
  gap: 4px;
}

.pedido-top span {
  color: var(--muted);
  font-size: 0.92rem;
}

.pedido-estado {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: #fff3e6;
  color: var(--orange-dark) !important;
  font-weight: 800;
  font-size: 0.82rem !important;
}

.pedido-items {
  margin: 0 0 12px 18px;
  color: var(--text);
}

.pedido-items li {
  margin-bottom: 6px;
}

.pedido-bottom {
  color: var(--blue-dark);
  font-weight: 700;
}


.admin-toolbar-right {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.admin-notice-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #fff3e6;
  color: var(--orange-dark);
  font-weight: 800;
}

.admin-layout.single-column {
  grid-template-columns: 1fr;
}

.admin-order-badge {
  display: inline-flex;
  min-width: 34px;
  height: 34px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #eef3fb;
  color: var(--blue-dark);
  font-weight: 800;
}

.admin-order-badge.has-orders {
  background: #ffe7e7;
  color: #b42318;
}

.admin-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  align-items: start;
}

.pedido-estado-select {
  min-height: 38px;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0 10px;
  background: #fff;
  font-weight: 700;
}

@media (max-width: 980px) {
  .admin-detail-grid {
    grid-template-columns: 1fr;
  }
}


/* Estados visuales de pedidos */
.pedido-estado,
.pedido-estado-select {
  font-weight: 800;
}

.pedido-estado.estado-pendiente {
  background: #fff3cd;
  color: #8a6d00 !important;
}

.pedido-estado.estado-proceso {
  background: #dbeafe;
  color: #1d4ed8 !important;
}

.pedido-estado.estado-entregado {
  background: #dcfce7;
  color: #15803d !important;
}

.pedido-estado-select.estado-pendiente {
  background: #fff8dc;
  color: #8a6d00;
  border-color: #f3d36b;
}

.pedido-estado-select.estado-proceso {
  background: #eff6ff;
  color: #1d4ed8;
  border-color: #93c5fd;
}

.pedido-estado-select.estado-entregado {
  background: #f0fdf4;
  color: #15803d;
  border-color: #86efac;
}


.receipt-body {
  background: #eef3fb;
}

.receipt-page {
  padding: 28px 16px 60px;
}

.receipt-card {
  max-width: 1100px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 24px;
  box-shadow: var(--shadow);
  padding: 28px;
}

.receipt-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}

.receipt-brand {
  display: flex;
  align-items: center;
  gap: 16px;
}

.receipt-logo {
  width: 120px;
  height: auto;
  object-fit: contain;
}

.receipt-brand h1 {
  margin: 0 0 6px;
  color: var(--blue-dark);
  font-size: 2rem;
}

.receipt-brand p {
  margin: 0;
  color: var(--muted);
}

.receipt-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.receipt-grid,
.receipt-bottom {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 18px;
}

.receipt-box {
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 18px;
  background: #fff;
}

.receipt-box h3 {
  margin-top: 0;
  color: var(--blue-dark);
}

.receipt-box p {
  margin: 0 0 10px;
  color: var(--text);
}

.receipt-table-wrap {
  overflow-x: auto;
}

.receipt-table {
  width: 100%;
  border-collapse: collapse;
}

.receipt-table th,
.receipt-table td {
  padding: 12px 10px;
  border-bottom: 1px solid var(--border);
  text-align: left;
}

.receipt-table th {
  color: var(--blue-dark);
}

.receipt-total-box {
  align-self: start;
}

.receipt-total-line {
  font-size: 1.2rem;
  color: var(--blue-dark);
}

.pedido-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

@media print {
  .no-print {
    display: none !important;
  }

  body {
    background: #fff !important;
  }

  .receipt-page {
    padding: 0;
  }

  .receipt-card {
    box-shadow: none;
    border: 0;
    padding: 0;
    max-width: 100%;
  }
}

@media (max-width: 900px) {
  .receipt-grid,
  .receipt-bottom {
    grid-template-columns: 1fr;
  }
}


.btn-wsp {
  background: #25D366;
  color: #fff;
  border: none;
  font-weight: 800;
}

.btn-wsp:hover {
  background: #1ebe5d;
}


.admin-wsp-box {
  margin-top: 12px;
}


/* Pedido card más premium */
.pedido-item {
  padding: 20px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.04);
}

.pedido-top {
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 14px;
}

.pedido-top div strong {
  display: block;
  font-size: 1.15rem;
  color: var(--blue-dark);
  margin-bottom: 4px;
}

.pedido-top div span {
  font-size: 0.96rem;
}

.pedido-items {
  margin: 10px 0 0;
  padding: 14px 18px 6px 28px;
  background: #f8fafc;
  border: 1px solid #e8eef8;
  border-radius: 14px;
}

.pedido-items li {
  margin-bottom: 8px;
  line-height: 1.45;
}

.pedido-bottom {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid #e8eef8;
}

.pedido-bottom > span {
  font-size: 1.05rem;
  color: var(--blue-dark);
}

.pedido-bottom .btn {
  align-self: flex-end;
  min-height: 46px;
  padding-inline: 18px;
  border-radius: 14px;
  font-weight: 800;
}

.pedido-bottom .btn.btn-outline {
  border: 1px solid #cfd8e3;
  background: #fff;
}

.pedido-bottom .btn.btn-outline:hover {
  background: #f8fafc;
}

.pedido-estado-select {
  min-width: 165px;
  min-height: 42px;
  border-radius: 12px;
  padding: 0 12px;
}

@media (max-width: 640px) {
  .pedido-item {
    padding: 16px;
  }

  .pedido-bottom .btn {
    align-self: stretch;
    width: 100%;
    justify-content: center;
  }

  .pedido-estado-select {
    width: 100%;
  }
}


.admin-productos-grid {
  display: grid;
  grid-template-columns: 0.8fr 1.2fr;
  gap: 22px;
  margin-bottom: 22px;
}

.simple-inline-form {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.simple-inline-form input {
  flex: 1;
  min-height: 46px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 0 14px;
  background: #fff;
}

.chips-list {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.category-chip-admin {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #eef3fb;
  color: var(--blue-dark);
  font-weight: 700;
}

.category-chip-admin button {
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: 1rem;
  font-weight: 900;
}

.chip-actions-inline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.category-chip-admin .chip-edit {
  color: var(--blue-dark);
}

.category-chip-admin .chip-remove {
  color: #b42318;
}

.bulk-price-grid,
.product-form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

.bulk-price-grid label,
.product-form-grid label {
  display: grid;
  gap: 6px;
  font-weight: 700;
  color: var(--blue-dark);
}

.bulk-price-grid input,
.bulk-price-grid select,
.product-form-grid input,
.product-form-grid select,
.product-form-grid textarea {
  min-height: 46px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 10px 14px;
  background: #fff;
  font-size: 1rem;
}

.product-form-grid textarea {
  min-height: 110px;
  resize: vertical;
}

.full-col {
  grid-column: 1 / -1;
}

.bulk-buttons,
.product-form-actions,
.table-actions {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.table-subtext {
  color: var(--muted);
  font-size: .9rem;
  margin-top: 4px;
  max-width: 340px;
}

.danger-outline {
  color: #b42318;
  border-color: #f0b4b4;
}

@media (max-width: 980px) {
  .admin-productos-grid,
  .bulk-price-grid,
  .product-form-grid {
    grid-template-columns: 1fr;
  }
}


.image-preview-box {
  border: 1px dashed var(--border);
  border-radius: 16px;
  padding: 14px;
  background: #f8fafc;
}

.image-preview-label {
  font-weight: 700;
  color: var(--blue-dark);
  margin-bottom: 10px;
}

.image-preview {
  display: none;
  max-width: 220px;
  max-height: 220px;
  border-radius: 14px;
  border: 1px solid var(--border);
  object-fit: contain;
  background: #fff;
}


.image-preview-grid {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.image-preview-item {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid #ddd;
}


.product-thumb-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.product-detail-image {
  width: 100%;
  max-height: 360px;
  object-fit: contain;
  display: block;
}

.product-thumb-mini {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.product-card p {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 6.2em;
}

.table-subtext {
  display: none;
}

.image-preview-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(70px, 1fr));
  gap: 10px;
}

.image-preview-item {
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid #ddd;
  background: #fff;
}

@media (max-width: 700px) {
  .image-preview-grid {
    grid-template-columns: repeat(3, minmax(70px, 1fr));
  }
}


/* --- Mejoras visuales de imágenes admin y producto --- */
.image-preview-box {
  border: 1px dashed var(--border);
  border-radius: 18px;
  padding: 18px;
  background: #f8fafc;
}

.image-preview-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(110px, 1fr));
  gap: 14px;
  align-items: start;
}

.image-preview-item {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  border-radius: 14px;
  border: 1px solid #d9e2ef;
  background: #fff;
  padding: 8px;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04);
}

.admin-product-row {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.admin-product-thumb {
  width: 72px;
  height: 72px;
  flex: 0 0 72px;
  border-radius: 14px;
  border: 1px solid #d9e2ef;
  background: #f8fafc;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.admin-product-thumb span {
  font-weight: 900;
  color: var(--blue-dark);
  font-size: 1.2rem;
}

.admin-product-thumb-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Página producto */
.product-thumb-media {
  overflow: hidden;
  padding: 10px;
  background: #fff;
}

.product-thumb-mini {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.product-detail-image {
  width: 100%;
  max-height: 420px;
  object-fit: contain;
  display: block;
}

.product-main-image {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
}

.product-main-image img {
  max-width: 100%;
  max-height: 420px;
  object-fit: contain;
}

/* Cards tienda/home */
.product-thumb-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  padding: 10px;
  background: #fff;
}

.product-image {
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

@media (max-width: 900px) {
  .image-preview-grid {
    grid-template-columns: repeat(3, minmax(90px, 1fr));
  }

  .admin-product-thumb {
    width: 60px;
    height: 60px;
    flex-basis: 60px;
  }
}

@media (max-width: 620px) {
  .image-preview-grid {
    grid-template-columns: repeat(2, minmax(90px, 1fr));
  }
}


/* Ajuste cuadrado estilo Mercado Libre */
.image-preview-grid {
  grid-template-columns: repeat(5, minmax(120px, 120px));
  justify-content: start;
}

.image-preview-item {
  width: 120px;
  height: 120px;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  padding: 10px;
  background: #fff;
}

.product-main-image {
  aspect-ratio: 1 / 1;
  min-height: 420px;
  max-height: 520px;
  border-radius: 24px;
  background: #fff;
  padding: 22px;
}

.product-main-image img,
.product-detail-image {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.product-thumb-media {
  aspect-ratio: 1 / 1;
  width: 120px;
  min-height: 120px;
  border-radius: 18px;
  background: #fff;
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.product-thumb-mini {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

@media (max-width: 900px) {
  .image-preview-grid {
    grid-template-columns: repeat(3, minmax(100px, 100px));
  }

  .image-preview-item {
    width: 100px;
    height: 100px;
  }

  .product-thumb-media {
    width: 96px;
    min-height: 96px;
  }

  .product-main-image {
    min-height: 320px;
    padding: 16px;
  }
}

@media (max-width: 620px) {
  .image-preview-grid {
    grid-template-columns: repeat(2, minmax(90px, 90px));
  }

  .image-preview-item {
    width: 90px;
    height: 90px;
  }
}


/* Cards más prolijas tipo ecommerce */
.product-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-radius: 22px;
  overflow: hidden;
}

.product-image {
  min-height: 220px;
  max-height: 220px;
  background: #fff;
  border-bottom: 1px solid #eef2f7;
}

.product-card .product-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 18px 18px 16px;
  height: 100%;
}

.product-card h3 {
  font-size: 1.02rem;
  line-height: 1.18;
  margin: 0;
  min-height: 3.6em;
}

.product-desc {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 3.1em;
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}

.product-stock {
  margin: 0;
}

.login-hint {
  margin: 0;
  font-size: 0.94rem;
  color: var(--muted);
  line-height: 1.35;
}

.product-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: auto;
}

.product-link-main {
  font-weight: 800;
  font-size: 1rem;
}

.price-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  align-items: start;
}

.price-box {
  gap: 6px;
}

.price {
  font-size: 1.05rem;
  font-weight: 900;
}

.price-row .btn {
  width: 100%;
  min-height: 48px;
  border-radius: 14px;
}

.product-card .locked-text.small {
  display: none;
}

@media (max-width: 640px) {
  .product-image {
    min-height: 180px;
    max-height: 180px;
  }

  .product-card .product-body {
    padding: 16px;
  }
}


/* Tienda más compacta estilo ML sobre base estable */
.product-card {
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  background: #fff;
  box-shadow: none;
  overflow: hidden;
}

.product-image {
  min-height: 210px;
  max-height: 210px;
  padding: 12px;
  background: #fff;
  border-bottom: 1px solid #eef2f7;
  display: flex;
  align-items: center;
  justify-content: center;
}

.product-thumb-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.product-card .product-body {
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.product-card h3 {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.28;
  min-height: 2.6em;
  font-weight: 500;
  color: #111827;
}

.product-desc,
.product-meta {
  display: none;
}

.price {
  font-size: 1.12rem;
  font-weight: 700;
  color: #111827;
}

.login-hint {
  font-size: 0.92rem;
  color: #6b7280;
  line-height: 1.3;
  margin: 0;
}

.product-stock {
  font-size: 0.92rem;
  color: #059669;
  font-weight: 700;
}

.product-link-main {
  margin-top: 4px;
  font-size: 0.96rem;
  font-weight: 700;
}

@media (max-width: 640px) {
  .product-image {
    min-height: 180px;
    max-height: 180px;
  }
}


/* Ajuste spacing galería producto */
.product-gallery {
  display: flex;
  gap: 14px; /* distancia miniaturas vs imagen principal */
}

.product-thumbs {
  display: flex;
  flex-direction: column;
  gap: 12px; /* separación entre miniaturas */
}

.product-thumb-media {
  width: 90px;
  height: 90px;
  border-radius: 16px;
  background: #fff;
  padding: 8px;
  transition: border 0.2s ease;
}

.product-thumb-media:hover {
  border: 2px solid #2563eb;
}


.product-description {
  white-space: pre-line;
  line-height: 1.6;
}


.product-description {
  white-space: normal;
  line-height: 1.75;
}

.product-description br {
  content: "";
}

/* ===== Admin productos compacto v2 ===== */
.admin-compact-page .container {
  max-width: 1180px;
}
.compact-head {
  margin-bottom: 14px;
  align-items: center;
}
.admin-head-actions,
.toolbar-actions-right {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.compact-card {
  padding: 16px;
  border-radius: 16px;
}
.compact-stats {
  gap: 14px;
  margin-bottom: 14px;
}
.compact-grid {
  grid-template-columns: .75fr 1.25fr;
  gap: 14px;
  margin-bottom: 14px;
}
.compact-inline-form input,
.compact-bulk-grid input,
.compact-bulk-grid select,
.editor-grid-compact input,
.editor-grid-compact select,
.editor-grid-compact textarea {
  min-height: 40px;
  padding: 8px 11px;
  font-size: .95rem;
  border-radius: 10px;
}
.compact-bulk-grid,
.editor-grid-compact {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.compact-check {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 10px !important;
  min-height: 40px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #fff;
  padding: 8px 11px;
}
.compact-check input {
  min-height: auto !important;
  width: 18px;
  height: 18px;
}
.compact-toolbar {
  gap: 10px;
  align-items: center;
}
.compact-toolbar .search-input {
  min-height: 40px;
}
.compact-table-wrap {
  max-height: 65vh;
}
.compact-admin-table th,
.compact-admin-table td {
  padding: 10px 12px;
  font-size: .94rem;
}
.compact-editor-shell {
  max-width: 1180px;
}
.compact-editor-card {
  display: grid;
  gap: 12px;
}
.pricing-dual-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.compact-price-box {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px;
  background: #f9fbff;
}
.compact-price-box h3,
.compact-summary-box h4 {
  margin: 0 0 10px;
}
.compact-summary-box {
  padding: 12px !important;
  margin-top: 0 !important;
}
.compact-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px 14px;
  font-size: .95rem;
}
.compact-actions {
  gap: 10px;
}
@media (max-width: 980px) {
  .compact-grid,
  .compact-bulk-grid,
  .editor-grid-compact,
  .pricing-dual-grid,
  .compact-summary-grid {
    grid-template-columns: 1fr;
  }
}


/* ===== Admin editor prolijo v3 ===== */
body {
  background: linear-gradient(180deg, #f4f7fc 0%, #eef3fb 100%);
}
.admin-compact-page {
  padding-top: 18px;
}
.compact-editor-shell {
  max-width: 1220px;
}
.compact-head {
  margin-bottom: 18px;
}
.compact-head .back-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
  font-weight: 700;
}
.compact-head h1 {
  margin: 0 0 6px;
  font-size: 2rem;
  color: #123b74;
}
.compact-head p {
  margin: 0;
  color: #5f7290;
}
.compact-editor-card {
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(37,99,235,.10);
  border-radius: 24px;
  padding: 20px;
  box-shadow: 0 22px 55px rgba(15, 23, 42, .08);
  gap: 16px;
}
.editor-grid-compact {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 12px;
}
.editor-grid-compact > label {
  display: grid;
  gap: 6px;
  font-size: .9rem;
  font-weight: 700;
  color: #27476f;
}
.editor-grid-compact > label:nth-child(1) { grid-column: span 4; }
.editor-grid-compact > label:nth-child(2) { grid-column: span 3; }
.editor-grid-compact > label:nth-child(3) { grid-column: span 2; }
.editor-grid-compact > label:nth-child(4) { grid-column: span 1; }
.editor-grid-compact > label:nth-child(5) { grid-column: span 1; }
.editor-grid-compact > label:nth-child(6) { grid-column: span 1; }
.pricing-dual-grid {
  gap: 16px;
}
.compact-price-box {
  background: linear-gradient(180deg, #fbfdff 0%, #f2f7ff 100%);
  border: 1px solid rgba(37,99,235,.12);
  border-radius: 20px;
  padding: 16px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}
.compact-price-box h3 {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  margin-bottom: 14px;
  background: #eaf2ff;
  color: #12407d;
  font-size: 1.05rem;
}
.compact-price-box .editor-grid-compact {
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}
.compact-price-box .editor-grid-compact > label,
.compact-price-box .editor-grid-compact > .compact-check {
  grid-column: span 1;
}
.editor-grid-compact input,
.editor-grid-compact select,
.editor-grid-compact textarea {
  min-height: 42px;
  border-radius: 14px;
  border: 1px solid #d5def0;
  background: #fff;
  padding: 9px 12px;
  font-size: .96rem;
  box-shadow: 0 1px 0 rgba(255,255,255,.9);
}
.editor-grid-compact input:focus,
.editor-grid-compact select:focus,
.editor-grid-compact textarea:focus {
  outline: none;
  border-color: #2563eb;
  box-shadow: 0 0 0 4px rgba(37,99,235,.10);
}
.compact-check {
  min-height: 42px;
  border-radius: 14px;
  border: 1px solid #d5def0;
  background: #f9fbff;
  padding: 9px 12px;
}
.compact-check span {
  font-size: .92rem;
  color: #26476e;
}
#producto-descripcion {
  min-height: 110px;
  border-radius: 16px;
  border: 1px solid #d5def0;
  padding: 12px 14px;
  resize: vertical;
}
.compact-summary-box {
  border-radius: 20px;
  border: 1px solid rgba(37,99,235,.12);
  background: linear-gradient(180deg, #f8fbff 0%, #eef4ff 100%);
  padding: 16px !important;
}
.compact-summary-box h4 {
  font-size: 1rem;
  color: #123b74;
  margin-bottom: 14px;
}
.compact-summary-grid {
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
.compact-summary-grid > div {
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(37,99,235,.08);
  color: #29486d;
}
.image-preview-box {
  border: 1px dashed #bfd0ef;
  border-radius: 18px;
  background: #f8fbff;
  padding: 14px;
}
.product-form-actions {
  position: sticky;
  bottom: 12px;
  z-index: 5;
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  box-shadow: 0 14px 32px rgba(15, 23, 42, .10);
}
.product-form-actions .btn {
  min-width: 180px;
}
#producto-status {
  margin: 0;
}
@media (max-width: 980px) {
  .editor-grid-compact,
  .compact-price-box .editor-grid-compact,
  .compact-summary-grid,
  .pricing-dual-grid {
    grid-template-columns: 1fr !important;
  }
  .editor-grid-compact > label,
  .compact-price-box .editor-grid-compact > label,
  .compact-price-box .editor-grid-compact > .compact-check {
    grid-column: 1 / -1 !important;
  }
  .product-form-actions {
    position: static;
    flex-direction: column;
  }
  .product-form-actions .btn {
    width: 100%;
  }
}


/* ===== Admin editor orden visual v4 ===== */
.compact-editor-shell {
  max-width: 1280px;
}
.compact-head h1 {
  font-size: 1.8rem;
}
.compact-head p {
  font-size: .92rem;
}
.compact-editor-card {
  gap: 14px;
  padding: 18px;
}
.editor-grid-compact > label {
  min-width: 0;
}
.editor-grid-compact > label[class],
.editor-grid-compact > .compact-check {
  min-width: 0;
}
.editor-grid-top {
  align-items: end;
}
.editor-grid-top .field-name { grid-column: span 4; }
.editor-grid-top .field-category { grid-column: span 3; }
.editor-grid-top .field-cost { grid-column: span 2; }
.editor-grid-top .field-iva-compra { grid-column: span 1; }
.editor-grid-top .field-cost-iva { grid-column: span 1; }
.editor-grid-top .field-iva-venta { grid-column: span 1; }
.editor-grid-top .field-cost-iva span {
  line-height: 1.05;
  max-width: 92px;
}
.editor-grid-offer {
  align-items: end;
}
.editor-grid-offer .field-offer-toggle { grid-column: span 2; }
.editor-grid-offer .field-offer-start { grid-column: span 2; }
.editor-grid-offer .field-offer-end { grid-column: span 2; }
.editor-grid-offer .field-stock { grid-column: span 1; }
.editor-grid-offer .field-image-ref { grid-column: span 3; }
.editor-grid-offer .field-image-upload { grid-column: span 2; }
.editor-grid-compact input,
.editor-grid-compact select,
.editor-grid-compact textarea {
  width: 100%;
  max-width: 100%;
}
.editor-grid-compact input[type="file"] {
  padding: 8px 10px;
  font-size: .88rem;
  overflow: hidden;
}
.editor-grid-compact input[type="file"]::file-selector-button {
  margin-right: 10px;
  padding: 8px 10px;
  border: 1px solid #c8d6ef;
  border-radius: 10px;
  background: #f4f8ff;
  color: #123b74;
  font-weight: 700;
  cursor: pointer;
}
.field-description {
  display: grid;
  gap: 8px;
}
#producto-descripcion {
  min-height: 160px;
  width: 100%;
}
.compact-check {
  gap: 8px !important;
}
.compact-check input[type="checkbox"] {
  flex: 0 0 auto;
}
@media (max-width: 1180px) {
  .editor-grid-top .field-name { grid-column: span 4; }
  .editor-grid-top .field-category { grid-column: span 3; }
  .editor-grid-top .field-cost { grid-column: span 2; }
  .editor-grid-top .field-iva-compra,
  .editor-grid-top .field-cost-iva,
  .editor-grid-top .field-iva-venta { grid-column: span 1; }
  .editor-grid-offer .field-offer-toggle { grid-column: span 2; }
  .editor-grid-offer .field-offer-start,
  .editor-grid-offer .field-offer-end { grid-column: span 2; }
  .editor-grid-offer .field-stock { grid-column: span 1; }
  .editor-grid-offer .field-image-ref { grid-column: span 3; }
  .editor-grid-offer .field-image-upload { grid-column: span 2; }
}
@media (max-width: 980px) {
  .editor-grid-top,
  .editor-grid-offer,
  .editor-grid-compact,
  .compact-price-box .editor-grid-compact,
  .compact-summary-grid,
  .pricing-dual-grid {
    grid-template-columns: 1fr !important;
  }
  .editor-grid-top .field-name,
  .editor-grid-top .field-category,
  .editor-grid-top .field-cost,
  .editor-grid-top .field-iva-compra,
  .editor-grid-top .field-cost-iva,
  .editor-grid-top .field-iva-venta,
  .editor-grid-offer .field-offer-toggle,
  .editor-grid-offer .field-offer-start,
  .editor-grid-offer .field-offer-end,
  .editor-grid-offer .field-stock,
  .editor-grid-offer .field-image-ref,
  .editor-grid-offer .field-image-upload {
    grid-column: 1 / -1 !important;
  }
}


/* ===== Admin editor orden visual v5 ===== */
.editor-support-grid {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 16px;
  align-items: stretch;
}
.support-box {
  padding: 16px;
}
.support-box h3 {
  margin-bottom: 12px;
}
.editor-grid-media {
  grid-template-columns: 1fr;
  gap: 12px;
}
.editor-grid-media .field-image-ref,
.editor-grid-media .field-image-upload {
  grid-column: 1 / -1;
}
.editor-grid-offer {
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 12px;
}
.editor-grid-offer .field-offer-toggle {
  grid-column: span 2;
}
.editor-grid-offer .field-offer-start,
.editor-grid-offer .field-offer-end {
  grid-column: span 1;
}
.editor-grid-offer .field-stock {
  grid-column: span 4;
  max-width: 180px;
}
.editor-grid-top {
  grid-template-columns: minmax(0,3.4fr) minmax(0,2.5fr) minmax(0,1.8fr) minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);
  gap: 12px;
}
.editor-grid-top .field-name,
.editor-grid-top .field-category,
.editor-grid-top .field-cost,
.editor-grid-top .field-iva-compra,
.editor-grid-top .field-cost-iva,
.editor-grid-top .field-iva-venta {
  grid-column: span 1;
}
.editor-grid-top .field-cost-iva {
  min-height: 42px;
  align-self: end;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px !important;
  padding: 8px 12px;
}
.editor-grid-top .field-cost-iva span {
  max-width: none;
  line-height: 1.1;
  font-size: .9rem;
}
.editor-grid-top .field-cost-iva input {
  width: 18px;
  height: 18px;
}
.field-description {
  margin-top: 2px;
}
#producto-descripcion {
  min-height: 180px;
}
@media (max-width: 1180px) {
  .editor-support-grid {
    grid-template-columns: 1fr;
  }
  .editor-grid-top {
    grid-template-columns: repeat(3, minmax(0,1fr));
  }
}
@media (max-width: 980px) {
  .editor-support-grid,
  .editor-grid-offer,
  .editor-grid-media {
    grid-template-columns: 1fr !important;
  }
  .editor-grid-offer .field-offer-toggle,
  .editor-grid-offer .field-offer-start,
  .editor-grid-offer .field-offer-end,
  .editor-grid-offer .field-stock,
  .editor-grid-media .field-image-ref,
  .editor-grid-media .field-image-upload {
    grid-column: 1 / -1 !important;
    max-width: 100%;
  }
}


.image-upload-box {
  margin-bottom: 14px;
}
.image-editor-box {
  padding: 16px;
}
.image-editor-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.image-upload-inline {
  display: block;
  margin-bottom: 12px;
}
.image-upload-inline input[type="file"] {
  display: block;
  width: 100%;
  margin-top: 8px;
  padding: 10px 12px;
  border: 1px dashed #bfd0ef;
  border-radius: 14px;
  background: #fff;
}
.image-upload-help {
  margin: 4px 0 0;
  font-size: .92rem;
  color: #5a7193;
}
.image-preview-shell {
  border: 1px solid #d9e5f7;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(244,248,255,.94));
  padding: 14px;
}
.image-preview-subtitle {
  font-size: 1rem;
  font-weight: 700;
  color: #163f7a;
  margin-bottom: 12px;
}
.image-preview-grid-editor {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 14px;
}
.image-preview-card {
  position: relative;
  overflow: hidden;
  border: 1px solid #d6e2f7;
  border-radius: 18px;
  background: #fff;
  padding: 10px;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .06);
}
.image-preview-media {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  background: #f8fafc;
}
.image-preview-grid-editor .image-preview-item {
  width: 100%;
  height: 220px;
  display: block;
  border-radius: 14px;
  object-fit: contain;
  border: 1px solid #dbe4f0;
  background: #f8fafc;
}
.image-cover-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #2563eb;
  color: #fff;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .02em;
  z-index: 3;
}
.image-preview-actions {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease;
  background: linear-gradient(180deg, rgba(13,25,46,.04) 0%, rgba(13,25,46,.3) 100%);
}
.image-preview-media:hover .image-preview-actions,
.image-preview-media:focus-within .image-preview-actions {
  opacity: 1;
  pointer-events: auto;
}
.image-action-btn {
  min-width: 42px !important;
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.65);
  background: rgba(255,255,255,.84);
  color: #163f7a;
  box-shadow: 0 8px 18px rgba(15,23,42,.18);
  backdrop-filter: blur(4px);
}
.image-action-btn:hover:not(:disabled) {
  transform: translateY(-1px);
}
.image-action-btn:disabled {
  opacity: .45;
  cursor: not-allowed;
}
.image-action-group {
  display: flex;
  gap: 8px;
}
.image-action-delete {
  align-self: flex-start;
}
.image-action-delete span,
.image-action-btn span {
  pointer-events: none;
}
.image-preview-empty {
  border: 1px dashed #d2def2;
  border-radius: 16px;
  padding: 28px 22px;
  text-align: center;
  color: #6b7f9d;
  background: rgba(255,255,255,.75);
}
@media (max-width: 640px) {
  .image-preview-grid-editor {
    grid-template-columns: 1fr;
  }
  .image-preview-grid-editor .image-preview-item {
    height: 200px;
  }
}


.tag-oferta {
  position: absolute;
  top: 10px;
  left: 10px;
  background: #0b57d0;
  color: #fff;
  font-size: 11px;
  font-weight: bold;
  padding: 4px 8px;
  border-radius: 6px;
  z-index: 3;
  letter-spacing: 0.5px;
}
.image-preview-media{
  position: relative;
}


/* Ajuste real botón aplicar actualización masiva */
.bulk-buttons {
  margin-top: 18px;
}

#btn-aplicar-bulk {
  margin-top: 0 !important;
}


.product-image {
  position: relative;
}

.tag-oferta-store {
  background: #0b57d0;
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  padding: 6px 10px;
  border-radius: 8px;
  box-shadow: 0 10px 22px rgba(11, 87, 208, 0.22);
}

.search-input-select {
  flex: 0 0 230px;
  min-width: 230px;
  padding-right: 40px;
}

.admin-offer-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 8px;
  padding: 4px 8px;
  border-radius: 999px;
  background: #0b57d0;
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .4px;
}

@media (max-width: 900px) {
  .search-input-select {
    flex: 1 1 100%;
    min-width: 100%;
  }
}


.contact-photolife .section-sub {
  margin: 8px 0 0;
  color: var(--muted);
}

.contacto-photolife-top {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 22px;
  align-items: stretch;
}

.contacto-card {
  padding: 24px;
  border-radius: 22px;
  border: 1px solid rgba(15, 79, 168, 0.14);
  background: linear-gradient(180deg, #ffffff 0%, #f7f9fd 100%);
  box-shadow: 0 14px 32px rgba(15, 79, 168, 0.10);
}

.contacto-card h3 {
  margin: 0 0 14px;
  color: var(--blue);
  font-size: 1.55rem;
}

.contacto-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.75;
}

.contact-map-embed {
  margin-bottom: 16px;
}

.contact-map-embed iframe {
  height: 300px;
}

.contacto-whatsapp-card {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 100%;
  padding: 30px 28px;
  border-radius: 24px;
  border: 1px solid rgba(15, 79, 168, 0.16);
  background:
    radial-gradient(circle at top right, rgba(242, 139, 32, 0.16), transparent 36%),
    radial-gradient(circle at top left, rgba(15, 79, 168, 0.14), transparent 42%),
    linear-gradient(135deg, #0a3774 0%, #0f4fa8 56%, #1360c7 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 18px 36px rgba(10, 55, 116, 0.22);
}

.contacto-whatsapp-card h3 {
  color: #ffffff;
  font-size: clamp(1.9rem, 3.2vw, 2.35rem);
  line-height: 1.08;
  margin-bottom: 14px;
}

.contacto-whatsapp-card p {
  color: rgba(255, 255, 255, 0.86);
  font-size: 1.04rem;
  line-height: 1.7;
  max-width: none;
  margin-bottom: 18px;
}

.contacto-wa-form {
  display: grid;
  gap: 14px;
}

.contacto-wa-field {
  display: grid;
  gap: 8px;
}

.contacto-wa-field span {
  color: #ffffff;
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.contacto-wa-field input,
.contacto-wa-field textarea {
  width: 100%;
  border: 1px solid rgba(255,255,255,0.22);
  border-radius: 14px;
  background: rgba(255,255,255,0.14);
  color: #ffffff;
  padding: 14px 16px;
  font: inherit;
  outline: none;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.contacto-wa-field input::placeholder,
.contacto-wa-field textarea::placeholder {
  color: rgba(255,255,255,0.64);
}

.contacto-wa-field input:focus,
.contacto-wa-field textarea:focus {
  border-color: rgba(242, 139, 32, 0.95);
  background: rgba(255,255,255,0.18);
  box-shadow: 0 0 0 3px rgba(242, 139, 32, 0.18);
}

.contacto-wa-field textarea {
  min-height: 132px;
  resize: vertical;
}

.contacto-wa-btn {
  margin-top: 4px;
  width: 100%;
  border: none;
  border-radius: 16px;
  padding: 15px 24px;
  font-size: 1.02rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  color: #fff;
  background: linear-gradient(135deg, var(--orange) 0%, #ff9e33 100%);
  box-shadow: 0 10px 24px rgba(242, 139, 32, 0.28);
}

.contacto-wa-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(242, 139, 32, 0.34);
}

.contacto-photolife-bottom {
  margin-top: 22px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  padding: 20px;
  border-radius: 22px;
  background: linear-gradient(135deg, var(--blue-dark) 0%, var(--blue) 100%);
  color: var(--white);
  box-shadow: 0 14px 32px rgba(10, 55, 116, 0.18);
}

.contacto-dato {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.contacto-dato-label {
  font-size: 0.84rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  opacity: 0.78;
  font-weight: 700;
}

.contacto-photolife-bottom a,
.contacto-photolife-bottom span {
  color: var(--white);
  line-height: 1.6;
  word-break: break-word;
}

@media (max-width: 980px) {
  .contacto-photolife-top {
    grid-template-columns: 1fr;
  }

  .contacto-photolife-bottom {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .contacto-photolife-bottom {
    grid-template-columns: 1fr;
  }

  .contacto-wa-btn {
    width: 100%;
    min-width: 0;
  }

  .contacto-card {
    padding: 20px;
  }

  .contacto-whatsapp-card h3 {
    font-size: 1.7rem;
  }

  .contacto-whatsapp-card p {
    font-size: 1.02rem;
    max-width: none;
  }
}




.footer-oestech-custom {
  margin-top: 0;
  padding: 24px 0 22px;
  background: linear-gradient(180deg, var(--blue) 0%, var(--blue-dark) 100%);
  color: var(--white);
  border-top: 1px solid rgba(255,255,255,0.18);
}

.footer-top-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 24px;
  padding: 4px 0 12px;
}

.footer-brand-compact {
  flex: 0 1 420px;
  max-width: 420px;
  text-align: left;
}

.footer-brand-compact h3 {
  margin: 0 0 10px;
  font-size: clamp(1.35rem, 1.8vw, 2rem);
  line-height: 1.12;
  color: var(--white);
}

.footer-brand-compact p,
.footer-copy-centered p {
  margin: 0;
  color: rgba(255,255,255,0.96);
  line-height: 1.55;
  font-size: 0.95rem;
}

.footer-brand-compact p + p {
  margin-top: 4px;
}

.footer-brand-compact a,
.footer-contact-mail a,
.footer-nav-centered a {
  color: var(--white);
  text-decoration: none;
}

.footer-brand-compact a:hover,
.footer-contact-mail a:hover,
.footer-nav-centered a:hover {
  text-decoration: underline;
}

.footer-contact-simple {
  flex: 0 1 320px;
  max-width: 320px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 10px 16px;
  border-radius: 16px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.16);
  box-shadow: 0 10px 24px rgba(10, 55, 116, 0.14);
}

.footer-mail-label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  color: rgba(255,255,255,0.82);
}

.footer-contact-mail a {
  font-size: 0.93rem;
  font-weight: 700;
  word-break: break-word;
}

.footer-nav-row {
  padding-top: 6px;
}

.footer-nav-centered {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 10px 24px;
}

.footer-nav-centered a {
  font-weight: 700;
  font-size: 0.98rem;
}

.footer-copy-row {
  padding-top: 14px;
}

.footer-copy-centered {
  text-align: center;
}

.footer-copy-centered p {
  font-size: 0.9rem;
}

@media (max-width: 900px) {
  .footer-top-row {
    flex-direction: column;
    align-items: center;
    gap: 16px;
  }

  .footer-brand-compact,
  .footer-contact-simple {
    width: 100%;
    max-width: 560px;
    text-align: center;
  }
}

@media (max-width: 640px) {
  .footer-oestech-custom {
    padding: 22px 0 18px;
  }

  .footer-brand-compact h3 {
    font-size: 1.4rem;
  }

  .footer-brand-compact p,
  .footer-contact-mail a,
  .footer-nav-centered a,
  .footer-copy-centered p {
    font-size: 0.92rem;
  }

  .footer-nav-centered {
    gap: 10px 16px;
  }
}


.adv-floating-contact {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 1200;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}

.adv-float-action,
.adv-float-main,
.adv-float-top {
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.98);
  color: var(--blue-dark);
  box-shadow: 0 10px 24px rgba(15, 79, 168, 0.14);
}

.adv-float-action {
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  min-width: 154px;
  height: 48px;
  padding: 0 14px;
  border-radius: 15px;
  transform: translateX(10px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .22s ease, transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}

.adv-floating-contact.open .adv-float-action {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}

.adv-float-whatsapp {
  border-color: rgba(37, 211, 102, 0.85);
  color: #25D366;
  box-shadow: 0 10px 24px rgba(37, 211, 102, 0.14);
}

.adv-float-instagram {
  color: var(--blue);
  border-color: rgba(15, 79, 168, 0.24);
}

.adv-float-main,
.adv-float-top {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease, border-color .2s ease, background .2s ease;
}

.adv-float-main:hover,
.adv-float-top:hover,
.adv-float-action:hover {
  transform: translateY(-2px);
  border-color: rgba(15, 79, 168, 0.35);
  box-shadow: 0 14px 28px rgba(15, 79, 168, 0.18);
}

.adv-float-whatsapp:hover {
  border-color: #25D366;
  background: #f7fffa;
  box-shadow: 0 14px 28px rgba(37, 211, 102, 0.18);
}

.adv-float-instagram:hover,
.adv-float-main:hover,
.adv-float-top:hover {
  background: #f7faff;
}

.adv-floating-contact.open .adv-float-main {
  transform: rotate(90deg);
}

.adv-float-top {
  opacity: 0;
  pointer-events: none;
}

.adv-floating-contact.show-top .adv-float-top {
  opacity: 1;
  pointer-events: auto;
}

.adv-float-icon {
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 20px;
}

.adv-float-icon svg {
  width: 20px;
  height: 20px;
}

.adv-float-label {
  font-size: .95rem;
  font-weight: 800;
  letter-spacing: 0.01em;
}

.adv-float-dots {
  font-size: 1.45rem;
  line-height: 1;
  transform: translateY(-1px);
}

.adv-float-arrow {
  font-size: 1.2rem;
  line-height: 1;
}

@media (max-width: 640px) {
  .adv-floating-contact {
    right: 10px;
    bottom: 12px;
    gap: 8px;
  }

  .adv-float-action {
    min-width: 142px;
    height: 44px;
    padding: 0 12px;
    border-radius: 14px;
  }

  .adv-float-main,
  .adv-float-top {
    width: 50px;
    height: 50px;
  }

  .adv-float-label {
    font-size: .9rem;
  }
}


/* Carrito rápido en cards */

.quick-add-popover {
  position: fixed;
  z-index: 220;
  width: min(280px, calc(100vw - 24px));
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 16px 34px rgba(15, 79, 168, 0.16);
  padding: 12px;
}

.quick-add-popover[hidden] { display: none !important; }

.quick-add-title {
  margin: 0 0 8px;
  color: var(--blue-dark);
  font-size: .92rem;
  font-weight: 800;
  line-height: 1.25;
}

.quick-add-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.quick-add-stepper {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  background: #f8fafc;
}

.quick-add-stepper button {
  width: 34px;
  height: 34px;
  border: 0;
  background: transparent;
  color: var(--blue-dark);
  font-size: 1.2rem;
  font-weight: 700;
  cursor: pointer;
}

.quick-add-stepper button:hover { background: #eef4ff; }

.quick-add-input {
  width: 44px;
  height: 34px;
  border: 0;
  border-left: 1px solid var(--border);
  border-right: 1px solid var(--border);
  background: #fff;
  text-align: center;
  font-weight: 800;
  color: var(--blue-dark);
  font-size: .98rem;
  outline: none;
}

.quick-add-confirm {
  flex: 1 1 auto;
  min-height: 36px;
  padding: 0 14px;
  border-radius: 12px;
  border: 0;
  background: var(--orange);
  color: #fff;
  font-weight: 800;
  font-size: .92rem;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(242, 139, 32, 0.24);
}

.quick-add-confirm:hover { background: var(--orange-dark); }

.quick-add-hint {
  margin-top: 8px;
  color: var(--muted);
  font-size: .77rem;
}

@media (max-width: 520px) {
  .quick-add-popover {
    width: min(260px, calc(100vw - 20px));
    padding: 10px;
    border-radius: 14px;
  }
  .quick-add-title { font-size: .86rem; }
  .quick-add-row { gap: 8px; }
  .quick-add-stepper button { width: 30px; height: 30px; }
  .quick-add-input { width: 38px; height: 30px; font-size: .9rem; }
  .quick-add-confirm { min-height: 32px; font-size: .84rem; padding: 0 10px; }
  .quick-add-hint { font-size: .72rem; }
}

.product-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: auto;
}

.product-card-footer .product-link,
.product-card-footer .product-link-main {
  margin-top: 0;
}

.product-cart-btn {
  width: 38px;
  height: 38px;
  min-width: 38px;
  border-radius: 50%;
  border: 1px solid #d7dfeb;
  background: #ffffff;
  color: #0f4fa8;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 4px 10px rgba(15, 79, 168, 0.10);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.product-cart-btn:hover {
  transform: translateY(-1px);
  border-color: #0f4fa8;
  box-shadow: 0 8px 16px rgba(15, 79, 168, 0.16);
}

.product-cart-btn:active {
  transform: translateY(0);
}

@media (max-width: 520px){
  .cart-panel{ width: 100vw; max-width: 100vw; }
  .cart-header{ padding: 12px 14px 8px; }
  .cart-header h3{ font-size: 1.25rem; }
  .cart-items{ padding: 6px 14px 2px; }
  .cart-item{ grid-template-columns: 56px 1fr; gap: 8px; padding: 8px 0; }
  .cart-item-media{ width:56px; height:56px; border-radius: 12px; }
  .cart-item h4{ font-size: .86rem; }
  .cart-item-meta{ font-size: .76rem; margin-bottom: 6px; }
  .cart-item-price-row{ align-items:flex-start; flex-direction:column; gap:4px; margin-bottom:6px; }
  .cart-unit-price, .cart-line-total{ font-size: .82rem; }
  .cart-actions button{ padding: 5px 8px; font-size: .82rem; }
  .cart-shipping, .cart-note, .cart-footer{ padding-left: 14px; padding-right: 14px; }
  .cart-note textarea{ min-height: 64px; }
  .cart-summary-row{ font-size: .88rem; }
  .cart-total-row{ font-size: .95rem; }
  .cart-main-btn{ min-height: 46px; font-size: .96rem; }
  .cart-secondary-btn{ min-height: 40px; font-size: .9rem; }
  .cart-link-btn{ font-size: .9rem; }
}


.cart-full-btn{ width:100%; }
.full-cart-page{ background:#eef3fb; min-height:100vh; padding:28px 0 44px; }
.full-cart-head{ display:flex; justify-content:space-between; align-items:center; gap:16px; margin-bottom:20px; }
.full-cart-head h1{ margin:0 0 6px; color:#123f84; font-size:2rem; }
.full-cart-head p{ margin:0; color:#5b6d8c; }
.full-cart-layout{ display:grid; grid-template-columns:minmax(0,1.7fr) minmax(320px,0.9fr); gap:22px; align-items:start; }
.full-cart-list-wrap,.full-cart-box{ background:#fff; border:1px solid #dbe4f1; border-radius:24px; box-shadow:0 10px 28px rgba(18,63,132,.08); }
.full-cart-list-head{ display:flex; justify-content:space-between; align-items:center; padding:18px 22px; border-bottom:1px solid #e4ebf5; color:#123f84; }
.full-cart-items{ padding:10px 18px 18px; display:grid; gap:14px; }
.full-cart-item{ display:grid; grid-template-columns:100px minmax(0,1fr); gap:16px; align-items:center; border:1px solid #e2e9f3; border-radius:20px; padding:14px; }
.full-cart-media{ width:100px; height:100px; border-radius:18px; overflow:hidden; display:flex; align-items:center; justify-content:center; background:#f4f7fb; border:1px solid #dbe4f1; color:#123f84; font-weight:800; }
.full-cart-media img{ width:100%; height:100%; object-fit:contain; }
.full-cart-body h3{ margin:0 0 6px; font-size:1.15rem; color:#16233c; }
.full-cart-meta{ margin:0 0 10px; color:#6a7a96; font-size:.95rem; }
.full-cart-prices{ display:flex; justify-content:space-between; gap:12px; align-items:center; margin-bottom:12px; color:#123f84; }
.full-cart-prices strong{ font-size:1.4rem; }
.full-cart-actions{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.full-cart-summary{ position:sticky; top:110px; }
.full-cart-box{ padding:20px; }
.full-cart-box h3{ margin:0 0 14px; color:#123f84; }
.full-cart-summary-row{ display:flex; justify-content:space-between; gap:14px; padding:10px 0; border-bottom:1px solid #ecf1f7; color:#5f6e89; }
.full-cart-summary-row strong{ color:#123f84; text-align:right; }
.full-cart-note-row strong{ max-width:190px; }
.full-cart-total{ display:flex; justify-content:space-between; gap:14px; padding:14px 0 16px; font-size:1.35rem; color:#16233c; }
.full-cart-box .cart-main-btn,.full-cart-box .cart-secondary-btn{ width:100%; margin-top:10px; }
@media (max-width: 920px){ .full-cart-layout{ grid-template-columns:1fr; } .full-cart-summary{ position:static; } }
@media (max-width: 640px){ .full-cart-head{ flex-direction:column; align-items:flex-start; } .full-cart-item{ grid-template-columns:72px minmax(0,1fr); gap:12px; padding:12px; } .full-cart-media{ width:72px; height:72px; border-radius:14px; } .full-cart-body h3{ font-size:1rem; } .full-cart-prices strong{ font-size:1.15rem; } }





/* Carrito header inherits site header */


/* V33: carrito mini alineado con precio */
.price-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}

.price-row .price-box{
  flex:1 1 auto;
  min-width:0;
}

.price-old{
  text-decoration:line-through !important;
  opacity:.6;
  font-size:.95rem;
}

.price-row .product-cart-btn{
  flex:0 0 auto;
  margin-top:2px;
}

.product-card .product-cart-btn{
  width:42px;
  height:42px;
  border-radius:50%;
  border:1px solid #d9e1ee;
  background:#f7f9fc;
  cursor:pointer;
  font-size:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 10px rgba(0,0,0,.06);
}

.product-card .product-cart-btn:hover{
  transform:translateY(-1px);
}


/* V34: limpiar caja de precio sin etiqueta */
.price-box{
  display:flex;
  flex-direction:column;
  gap:4px;
}


.admin-pedidos-head {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:12px;
  flex-wrap:wrap;
}

.admin-pedidos-help {
  margin:4px 0 0;
  color: var(--muted);
}

@media (max-width: 720px) {
  .admin-pedidos-head {
    align-items:stretch;
  }
  .admin-pedidos-head .btn,
  .admin-pedidos-head .pedido-estado-select {
    width:100%;
  }
}



.btn-danger {
  background:#ffe5e5;
  color:#b42318;
  border:1px solid #f5c2c2;
  font-weight:700;
}
.btn-danger:hover {
  background:#f8d7da;
}


.historial-filtros-box {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.historial-fecha-input {
  min-height: 40px;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0 12px;
  background: #fff;
  color: var(--text);
  font: inherit;
}

@media (max-width: 860px) {
  .historial-filtros-box {
    width: 100%;
    justify-content: stretch;
  }

  .historial-filtros-box > * {
    flex: 1 1 180px;
  }
}


.admin-stock-inline{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.admin-stock-input{
  width:88px;
  min-height:40px;
  border:1px solid var(--border);
  border-radius:10px;
  padding:0 10px;
  background:#fff;
  font:inherit;
  font-weight:700;
  color:var(--text);
}

.admin-stock-save{
  min-height:40px;
  padding:0 12px;
  font-size:.92rem;
}


.admin-inline-form {
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin:12px 0;
}

.admin-inline-form input,
.admin-inline-form select {
  flex:1 1 240px;
}


.compact-muted {
  margin: 0 0 10px;
  color: var(--muted);
}

#producto-proveedor {
  min-height: 48px;
}



.admin-productos-layout{
  display:grid;
  grid-template-columns: 240px 1fr;
  gap:20px;
  align-items:start;
}

.admin-productos-sidebar{
  position:sticky;
  top:110px;
  display:grid;
  gap:10px;
}

.admin-side-btn{
  min-height:46px;
  padding:0 16px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--blue-dark);
  font:inherit;
  font-weight:700;
  text-align:left;
  cursor:pointer;
}

.admin-side-btn.is-active{
  background:var(--blue);
  color:#fff;
  border-color:var(--blue);
}

.admin-productos-content{
  min-width:0;
}

.admin-tab-panel{
  display:none;
}

.admin-tab-panel.is-active{
  display:block;
}

@media (max-width: 980px){
  .admin-productos-layout{
    grid-template-columns: 1fr;
  }

  .admin-productos-sidebar{
    position:static;
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

@media (max-width: 640px){
  .admin-productos-sidebar{
    grid-template-columns: 1fr;
  }
}


.stock-alert-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:12px;
}

.stock-alert-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.stock-bajo-wrap{
  overflow:auto;
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
}

.stock-bajo-table{
  width:100%;
  min-width:640px;
}

.stock-bajo-table th,
.stock-bajo-table td{
  padding:14px 16px;
  border-bottom:1px solid var(--border);
  text-align:left;
}

.stock-bajo-table tbody tr:last-child td{
  border-bottom:0;
}

.stock-bajo-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  min-height:34px;
  padding:0 10px;
  border-radius:999px;
  background:#fff3cd;
  color:#8a6d00;
  font-weight:800;
}

@media (max-width: 640px){
  .stock-alert-actions{
    width:100%;
  }
  .stock-alert-actions .btn{
    width:100%;
  }
}


.admin-shell{
  display:grid;
  grid-template-columns: 240px 1fr;
  gap:20px;
  align-items:start;
}

.admin-shell-sidebar{
  position:sticky;
  top:110px;
  display:grid;
  gap:10px;
}

.admin-shell-btn{
  min-height:48px;
  padding:0 16px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--blue-dark);
  font:inherit;
  font-weight:800;
  text-align:left;
  cursor:pointer;
}

.admin-shell-btn.is-active{
  background:var(--blue);
  color:#fff;
  border-color:var(--blue);
}

.admin-shell-content{
  min-width:0;
}

.admin-main-panel{
  display:none;
}

.admin-main-panel.is-active{
  display:block;
}

.admin-products-shortcuts,
.admin-local-grid{
  display:grid;
  gap:18px;
}

.admin-shortcuts-grid{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:14px;
}

.admin-local-grid{
  grid-template-columns: 1fr 1fr;
  margin-top:16px;
}

.admin-local-box{
  border:1px solid var(--border);
  border-radius:16px;
  padding:16px;
  background:#fff;
}

.admin-local-list{
  margin:12px 0 0 18px;
  padding:0;
}

.admin-local-list li{
  margin-bottom:8px;
}

@media (max-width: 980px){
  .admin-shell{
    grid-template-columns: 1fr;
  }
  .admin-shell-sidebar{
    position:static;
    grid-template-columns: repeat(3, minmax(0,1fr));
  }
  .admin-local-grid{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px){
  .admin-shell-sidebar{
    grid-template-columns: 1fr;
  }
}


.local-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
  flex-wrap:wrap;
}

.local-head-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.local-grid{
  display:grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap:18px;
  align-items:start;
}

.local-col{
  min-width:0;
}

.local-search-box{
  margin-bottom:14px;
}

.local-search-box label{
  display:block;
  margin-bottom:8px;
  color:var(--blue-dark);
}

.local-results-box,
.local-ticket-box{
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
  padding:16px;
}

.local-results-head,
.local-ticket-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:14px;
  flex-wrap:wrap;
}

.local-product-results{
  display:grid;
  gap:10px;
  max-height:520px;
  overflow:auto;
}

.local-product-card{
  width:100%;
  border:1px solid var(--border);
  border-radius:14px;
  background:#fff;
  padding:14px;
  text-align:left;
  cursor:pointer;
}

.local-product-card-top,
.local-product-card-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}

.local-product-card-bottom{
  margin-top:8px;
  color:var(--muted);
}

.local-stock-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 10px;
  border-radius:999px;
  background:#e8f1ff;
  color:var(--blue);
  font-weight:700;
  font-size:.92rem;
}

.local-stock-pill.is-low{
  background:#fff3cd;
  color:#8a6d00;
}

.local-ticket-items{
  display:grid;
  gap:10px;
  margin-bottom:14px;
}

.local-ticket-item{
  border:1px solid var(--border);
  border-radius:14px;
  padding:12px;
  display:grid;
  gap:10px;
}

.local-ticket-info{
  display:grid;
  gap:4px;
}

.local-ticket-info span{
  color:var(--muted);
}

.local-ticket-controls{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.local-qty-btn,
.local-remove-btn{
  min-height:36px;
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
  font:inherit;
  font-weight:700;
  cursor:pointer;
}

.local-qty-btn{
  min-width:36px;
}

.local-remove-btn{
  padding:0 12px;
  color:#b42318;
}

.local-qty-value{
  min-width:22px;
  text-align:center;
  font-weight:800;
}

.local-line-total{
  margin-left:auto;
  color:var(--blue-dark);
}

.local-summary{
  display:grid;
  gap:12px;
}

.local-total-box{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 14px;
  border-radius:14px;
  background:#f8fbff;
  color:var(--blue-dark);
}

.local-total-box strong{
  font-size:1.35rem;
}

.local-actions{
  display:flex;
  justify-content:flex-end;
}

@media (max-width: 1100px){
  .local-grid{
    grid-template-columns: 1fr;
  }
}


.pos-body{
  background:#eef3fb;
}

.pos-page{
  padding:22px;
}

.pos-shell{
  max-width:1380px;
  margin:0 auto;
}

.pos-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:18px;
}

.pos-back-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:46px;
  padding:0 18px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  font-weight:700;
}

.pos-branch-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:0 14px;
  border-radius:12px;
  background:#6b7280;
  color:#fff;
  font-weight:800;
}

.pos-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:22px;
  padding:26px;
  box-shadow:var(--shadow);
}

.pos-meta-grid{
  display:grid;
  grid-template-columns: 220px 220px 1fr;
  gap:18px;
  margin-bottom:22px;
}

.pos-field{
  display:grid;
  gap:10px;
}

.pos-field > span,
.pos-section-label{
  font-weight:800;
  color:#374151;
}

.pos-client-row{
  display:grid;
  grid-template-columns:1fr 48px;
  gap:10px;
}

.pos-plus-btn{
  min-height:48px;
  border:0;
  border-radius:12px;
  background:var(--blue);
  color:#fff;
  font-size:2rem;
  line-height:1;
  cursor:pointer;
}

.pos-search-area{
  position:relative;
  margin-bottom:22px;
}

.pos-search-box{
  position:relative;
}

.pos-product-search{
  width:100%;
  font-size:1.05rem;
  padding-left:20px;
  min-height:52px;
  border-radius:18px;
  padding-left:18px;
}

.pos-results-note{
  margin-top:8px;
  color:var(--muted);
  font-size:.95rem;
}

.pos-product-results{
  display:none;
  position:absolute;
  left:0;
  right:0;
  top:100%;
  z-index:20;
  max-height:280px;
  overflow:auto;
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  box-shadow:var(--shadow);
  margin-top:10px;
  display:grid;
  gap:8px;
  padding:10px;
}

.pos-product-results:empty{
  display:none;
}

.pos-ticket-table{
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  margin-bottom:18px;
  background:#fafcff;
}

.pos-ticket-head-row{
  display:grid;
  grid-template-columns: 200px 1fr 180px 160px 160px;
  gap:16px;
  padding:18px 22px;
  background:#f2f6fd;
  color:#374151;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.04em;
}

.pos-ticket-empty{
  margin:16px;
}

.pos-ticket-items{
  display:grid;
  gap:0;
}

.local-ticket-item{
  display:grid;
  grid-template-columns: 200px 1fr 180px 160px 160px;
  gap:16px;
  padding:16px 22px;
  border-top:1px solid var(--border);
  align-items:center;
  background:#fff;
}

.pos-row-description{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.pos-row-description strong{
  font-size:1rem;
}

.pos-row-qty{
  display:flex;
  align-items:center;
  gap:10px;
}

.pos-row-price,
.pos-row-total{
  font-weight:800;
  color:#374151;
}

.pos-info-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  margin-bottom:18px;
}

.pos-dashed-card{
  border:2px dashed #dbe6f5;
  border-radius:20px;
  padding:16px 18px;
  background:#fbfdff;
}

.pos-dashed-card label{
  display:grid;
  gap:10px;
}

.pos-dashed-card span{
  font-weight:800;
  color:#64748b;
  text-transform:uppercase;
  letter-spacing:.03em;
}

.pos-totals-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:16px;
  margin-bottom:18px;
}

.pos-total-card{
  border:1px solid var(--border);
  border-radius:14px;
  background:#fff;
  padding:18px;
  display:grid;
  gap:8px;
}

.pos-total-card span{
  color:#6b7280;
  font-weight:700;
}

.pos-total-card strong{
  font-size:1.1rem;
  color:#374151;
}

.pos-total-card.is-total strong{
  color:#16a34a;
  font-size:1.4rem;
}

.pos-bottom-actions{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}

.pos-status-wrap{
  display:grid;
  gap:10px;
}

.pos-ticket-count{
  color:#64748b;
  font-weight:700;
}

.pos-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.local-qty-btn,
.local-remove-btn{
  min-height:34px;
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
  font:inherit;
  font-weight:800;
  cursor:pointer;
}

.local-qty-btn{
  min-width:34px;
}

.local-remove-btn{
  padding:0 12px;
  color:#b42318;
}

.local-qty-value{
  min-width:24px;
  text-align:center;
  font-weight:800;
}

@media (max-width: 1100px){
  .pos-meta-grid{
    grid-template-columns:1fr 1fr;
  }
  .pos-client-field{
    grid-column:1 / -1;
  }
  .pos-ticket-head-row,
  .local-ticket-item{
    grid-template-columns: 140px 1fr 150px 120px 120px;
  }
  .pos-totals-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width: 760px){
  .pos-page{
    padding:14px;
  }
  .pos-card{
    padding:18px;
  }
  .pos-meta-grid,
  .pos-info-grid,
  .pos-totals-grid{
    grid-template-columns:1fr;
  }
  .pos-ticket-head-row{
    display:none;
  }
  .local-ticket-item{
    grid-template-columns:1fr;
    gap:10px;
  }
  .pos-row-description{
    flex-direction:column;
    align-items:flex-start;
  }
  .pos-row-qty{
    justify-content:flex-start;
  }
}


/* V51 refinado visual sistema local */
.pos-card{
  border-radius: 26px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.pos-topbar{
  margin-bottom: 14px;
}

.pos-back-link{
  box-shadow: 0 8px 18px rgba(15,79,168,0.08);
}

.pos-branch-badge{
  box-shadow: 0 8px 18px rgba(0,0,0,0.10);
}

.pos-field input,
.pos-field select,
.pos-dashed-card input,
.pos-dashed-card select{
  min-height: 50px;
  border-radius: 14px;
  border: 1px solid #d7e1f0;
  background: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}

.pos-product-search{
  width:100%;
  font-size:1.05rem;
  padding-left:20px;
  min-height: 58px;
  border-radius: 18px;
  border: 1px solid #d7e1f0;
  background: linear-gradient(180deg, #f8fbff 0%, #f1f6fd 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.9);
}

.pos-search-hint{
  padding: 18px;
  border: 1px dashed #d7e1f0;
  border-radius: 16px;
  background: #fbfdff;
  color: #74849b;
  text-align: center;
  font-weight: 700;
}

.pos-product-results{
  display:none;
  background: #fff;
  border-radius: 20px;
  padding: 12px;
}

.local-product-card{
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  box-shadow: 0 8px 18px rgba(15,79,168,0.06);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.local-product-card:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 22px rgba(15,79,168,0.10);
  border-color: #bfd0ea;
}

.local-product-card-top strong{
  color: var(--blue-dark);
  font-size: 1rem;
}

.local-ticket-item{
  border-top: 1px solid #e8eef8;
  background: linear-gradient(180deg, #ffffff 0%, #fcfdff 100%);
}

.pos-ticket-table{
  border-radius: 20px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}

.pos-ticket-head-row{
  background: linear-gradient(180deg, #f5f8fd 0%, #edf3fb 100%);
}

.pos-dashed-card{
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.pos-total-card{
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  box-shadow: 0 8px 18px rgba(15,79,168,0.05);
}

.pos-total-card.is-total{
  border-color: #b7e2c0;
  background: linear-gradient(180deg, #ffffff 0%, #f4fff7 100%);
}

.pos-actions .btn{
  min-width: 150px;
}

.local-remove-btn{
  background: #fff5f5;
  border-color: #f0c8c8;
}

.local-qty-btn{
  background: #f8fbff;
}

.local-stock-pill{
  box-shadow: inset 0 -1px 0 rgba(0,0,0,0.04);
}


/* V52 ajustes buscador */
.pos-search-area{
  width:100%;
}

.pos-search-box{
  width:100%;
}

.pos-product-search{
  width:100%;
  min-height:60px;
  font-size:1.1rem;
}


.pos-client-results{
  display:none;
  gap:8px;
  margin-top:10px;
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
  box-shadow:var(--shadow);
  padding:10px;
}

.pos-client-item{
  width:100%;
  border:1px solid #e5edf8;
  border-radius:14px;
  background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  padding:12px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  text-align:left;
  cursor:pointer;
}

.pos-client-item:hover{
  border-color:#bfd0ea;
}

.pos-client-item-main{
  display:grid;
  gap:4px;
}

.pos-client-item-main span{
  color:var(--muted);
}

.pos-client-item-side{
  color:var(--blue-dark);
  font-weight:800;
}

.pos-client-empty{
  padding:14px;
  border-radius:12px;
  background:#fbfdff;
  color:#74849b;
  text-align:center;
  font-weight:700;
}


/* V55 dropdown cliente sin romper layout */
.pos-client-field{
  position: relative;
}

.pos-client-results{
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 10px);
  z-index: 30;
  max-height: 260px;
  overflow: auto;
  margin-top: 0 !important;
}

@media (max-width: 760px){
  .pos-client-results{
    position: static;
    top: auto;
    max-height: none;
    margin-top: 10px !important;
  }
}


.pos-balances-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:16px;
  margin-bottom:18px;
}

.pos-balance-card{
  border:1px solid var(--border);
  border-radius:16px;
  background:linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  padding:18px;
  display:grid;
  gap:8px;
  box-shadow:0 8px 18px rgba(15,79,168,0.05);
}

.pos-balance-card span{
  color:#64748b;
  font-weight:700;
}

.pos-balance-card strong{
  font-size:1.2rem;
  color:#0a3774;
}

.pos-history-section{
  margin-top:22px;
}

.pos-history-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:12px;
  flex-wrap:wrap;
}

.pos-tickets-wrap{
  overflow:auto;
  border:1px solid var(--border);
  border-radius:18px;
  background:#fff;
}

.pos-tickets-table{
  width:100%;
  min-width:760px;
  border-collapse:collapse;
}

.pos-tickets-table th,
.pos-tickets-table td{
  padding:14px 16px;
  border-bottom:1px solid var(--border);
  text-align:left;
}

.pos-tickets-table thead th{
  background:#f2f6fd;
  color:#374151;
  font-weight:800;
}

.pos-tickets-table tbody tr:last-child td{
  border-bottom:0;
}

.pos-print-btn{
  min-height:38px;
}

@media (max-width: 1100px){
  .pos-balances-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width: 760px){
  .pos-balances-grid{
    grid-template-columns:1fr;
  }
}


.pos-caja-filtros{
  display:grid;
  grid-template-columns: 220px 220px;
  gap:16px;
  margin-bottom:18px;
}

@media (max-width: 760px){
  .pos-caja-filtros{
    grid-template-columns:1fr;
  }
}


.admin-section-head-inline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
  flex-wrap:wrap;
}


/* Cuenta corriente */
.admin-filter-select{max-width:180px;}
.cc-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:14px 0 18px;}
.cc-summary-box{background:#f6f8fc;border:1px solid #dce4ef;border-radius:14px;padding:14px;display:grid;gap:6px;}
.cc-summary-box span{font-size:13px;color:#6b7280;}
.cc-summary-box strong{font-size:22px;color:#0f172a;}
.cc-status-pill,.cc-mov-pill{display:inline-flex;align-items:center;justify-content:center;padding:7px 12px;border-radius:999px;font-weight:700;font-size:13px;border:1px solid transparent;}
.cc-status-pill.is-ok{background:#ecfdf3;color:#157347;border-color:#b7ebc6;}
.cc-status-pill.is-debt{background:#fff1f2;color:#be123c;border-color:#fecdd3;}
.cc-status-pill.is-favor{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe;}
.cc-mov-pill.is-payment{background:#ecfdf3;color:#157347;}
.cc-mov-pill.is-charge{background:#fff7ed;color:#c2410c;}
.cc-payment-form{margin-top:16px;}
.cc-history-head{margin-top:18px;}
@media (max-width: 860px){.cc-summary-grid{grid-template-columns:1fr;}}


.devolucion-modal {
  position: fixed;
  inset: 0;
  background: rgba(7, 16, 32, 0.72);
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
}
.devolucion-modal.is-open {
  display: flex !important;
}
.devolucion-modal-box {
  width: min(760px, 100%);
  max-height: 90vh;
  overflow: auto;
  background: #fff;
  border-radius: 22px;
  padding: 22px;
  box-shadow: 0 24px 80px rgba(12, 25, 49, 0.28);
  display: grid;
  gap: 16px;
}
.devolucion-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.devolucion-items {
  display: grid;
  gap: 12px;
}
.devolucion-item {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) 110px 120px;
  gap: 12px;
  align-items: end;
  border: 1px solid #dbe6f5;
  border-radius: 16px;
  padding: 14px;
  background: #f8fbff;
}
.devolucion-item strong {
  display: block;
  margin-bottom: 4px;
}
.devolucion-item span {
  display: block;
  color: #5d6b7d;
  font-size: 13px;
}
.devolucion-item input {
  min-height: 42px;
}
.devolucion-item-total {
  font-weight: 700;
  color: #0a3774;
  text-align: right;
}
.devolucion-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.devolucion-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  flex-wrap: wrap;
}
.ticket-return-note {
  font-size: 12px;
  color: #0a7a44;
  font-weight: 700;
}
.ticket-returned-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: #eef7ff;
  color: #0f4fa8;
  font-size: 12px;
  font-weight: 700;
}
.pos-actions-stack {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
@media (max-width: 720px) {
  .devolucion-item,
  .devolucion-grid {
    grid-template-columns: 1fr;
  }
}


.home-rubros-carousel-wrap{
  position:relative;
  display:flex;
  align-items:center;
  gap:14px;
}

.home-rubros-carousel{
  display:flex;
  gap:18px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  padding:8px 4px 14px;
  width:100%;
  scrollbar-width:none;
}

.home-rubros-carousel::-webkit-scrollbar{
  display:none;
}

.rubros-nav{
  width:46px;
  min-width:46px;
  height:46px;
  border:none;
  border-radius:999px;
  background:#0d4593;
  color:#fff;
  font-size:2rem;
  line-height:1;
  display:grid;
  place-items:center;
  box-shadow:0 12px 28px rgba(13,69,147,.18);
  cursor:pointer;
  transition:transform .2s ease, opacity .2s ease, background .2s ease;
}

.rubros-nav:hover{
  transform:translateY(-2px);
  background:#0a3776;
}

.rubro-slide-card{
  flex:0 0 292px;
  min-height:372px;
  border-radius:36px;
  overflow:hidden;
  text-decoration:none;
  background:#ff8500;
  box-shadow:0 18px 38px rgba(19,28,51,.14);
  scroll-snap-align:start;
  transition:transform .22s ease, box-shadow .22s ease;
}

.rubro-slide-card:hover{
  transform:translateY(-5px);
  box-shadow:0 24px 44px rgba(19,28,51,.18);
}

.rubro-slide-top{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:246px;
  padding:28px 24px 18px;
  background:
    radial-gradient(circle at center, rgba(255,255,255,.08) 0, rgba(255,255,255,0) 58%),
    linear-gradient(180deg, #5b37c9 0%, #43269b 100%);
  border-bottom-left-radius:120px;
}

.rubro-slide-circle{
  width:174px;
  height:174px;
  border-radius:50%;
  border:10px solid #ff971e;
  background:linear-gradient(180deg, #2740c7 0%, #1c2d94 100%);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px;
  box-shadow:inset 0 0 24px rgba(255,255,255,.12), 0 12px 24px rgba(0,0,0,.15);
}

.rubro-slide-image-wrap{
  width:100%;
  height:100%;
  border-radius:50%;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}

.rubro-slide-image-wrap.is-hidden{
  display:none;
}

.rubro-slide-image{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:50%;
  filter:drop-shadow(0 8px 12px rgba(0,0,0,.22));
}

.rubro-slide-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:58px;
  min-height:34px;
  padding:6px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.14);
  color:#fff;
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.14em;
}

.rubro-slide-bottom{
  min-height:126px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:20px 24px 28px;
  color:#fff;
}

.rubro-slide-title{
  font-size:2rem;
  font-weight:700;
  line-height:1.05;
  letter-spacing:.01em;
  text-transform:uppercase;
}

.rubro-slide-subtitle{
  margin-top:10px;
  font-size:.95rem;
  font-weight:500;
  letter-spacing:.02em;
  color:rgba(255,255,255,.9);
}

@media (max-width: 900px){
  .rubro-slide-card{
    flex-basis:260px;
    min-height:338px;
  }

  .rubro-slide-top{
    min-height:218px;
  }

  .rubro-slide-circle{
    width:154px;
    height:154px;
  }

  .rubro-slide-title{
    font-size:1.72rem;
  }
}

@media (max-width: 640px){
  .home-rubros-carousel-wrap{
    gap:8px;
  }

  .rubros-nav{
    width:38px;
    min-width:38px;
    height:38px;
    font-size:1.5rem;
  }

  .rubro-slide-card{
    flex-basis:220px;
    min-height:300px;
    border-radius:28px;
  }

  .rubro-slide-top{
    min-height:190px;
    border-bottom-left-radius:90px;
  }

  .rubro-slide-circle{
    width:132px;
    height:132px;
    border-width:8px;
  }

  .rubro-slide-title{
    font-size:1.42rem;
  }

  .rubro-slide-subtitle{
    font-size:.84rem;
  }
}


  .rubros-nav{
    width:38px;
    min-width:38px;
    height:38px;
    font-size:1.5rem;
  }

  .rubro-slide-card{
    flex-basis:220px;
    min-height:295px;
    border-radius:28px;
  }

  .rubro-slide-top{
    min-height:190px;
    border-bottom-left-radius:90px;
  }

  .rubro-slide-circle{
    width:126px;
    height:126px;
    border-width:8px;
  }

  .rubro-slide-icon{
    font-size:2.3rem;
  }

  .rubro-slide-bottom{
    min-height:92px;
    font-size:1.35rem;
    padding:16px 18px 22px;
  }
}



.home-rubros-carousel-wrap{
  position: relative;
  overflow: visible;
  padding: 10px 60px;
}
.home-rubros-carousel{
  display: flex;
  gap: 16px;
  width: 100%;
  overflow: hidden;
  scroll-behavior: smooth;
}
.home-rubros-carousel::-webkit-scrollbar{ display:none; }
.rubros-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 56px;
  height: 56px;
  border-radius: 999px;
  border: 0;
  background: var(--blue);
  color: #fff;
  font-size: 2.05rem;
  line-height: 1;
  cursor: pointer;
  z-index: 10;
  box-shadow: 0 12px 26px rgba(15,79,168,.22);
  opacity: 1;
  display:flex;
  align-items:center;
  justify-content:center;
}
.rubros-nav-prev{ left: 8px; }
.rubros-nav-next{ right: 8px; }
.rubros-nav:hover{ background: var(--blue-dark); }
.rubro-slide-card{
  flex: 0 0 calc((100% - 48px) / 4);
  min-width: calc((100% - 48px) / 4);
  max-width: calc((100% - 48px) / 4);
  border-radius: 30px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 12px 26px rgba(27, 46, 94, .10);
  transition: transform .18s ease, box-shadow .18s ease;
}
.rubro-slide-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 34px rgba(27,46,94,.16);
}
.rubro-slide-top{
  display:flex;
  align-items:flex-end;
  justify-content:center;
  height: 202px;
  padding: 18px 14px 26px;
  background: radial-gradient(circle at 30% 20%, #6540d6 0%, #4d2cb8 55%, #4327a7 100%);
  border-bottom-left-radius: 80px;
}
.rubro-slide-circle{
  width: 116px;
  height: 116px;
  border-radius: 999px;
  background: #2f40b9;
  border: 4px solid #ff971c;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.07);
}
.rubro-slide-image-wrap{
  width: 100%;
  height: 100%;
  border-radius: 999px;
  overflow: hidden;
  background: #f5f7ff;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 12px;
}
.rubro-slide-image-wrap.is-hidden{ display:none; }
.rubro-slide-image{
  width:100%;
  height:100%;
  object-fit: contain;
}
.rubro-slide-badge{ display:none !important; }
.rubro-slide-bottom{
  background: #ff8a00;
  color: #fff;
  min-height: 124px;
  padding: 18px 16px 22px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
}
.rubro-slide-title{
  display:block;
  width:100%;
  max-width: 94%;
  font-size: clamp(.92rem, 1.16vw, 1.28rem);
  line-height: 1.08;
  font-weight: 600;
  letter-spacing: 0;
  text-wrap: balance;
  overflow-wrap: anywhere;
  word-break: normal;
}
.rubro-slide-subtitle{
  display:block;
  width:100%;
  max-width: 92%;
  margin-top: 9px;
  font-size: .82rem;
  line-height: 1.2;
  font-weight: 400;
  opacity: .97;
}
@media (max-width: 1100px){
  .rubro-slide-card{
    flex-basis: calc((100% - 32px) / 3);
    min-width: calc((100% - 32px) / 3);
    max-width: calc((100% - 32px) / 3);
  }
}
@media (max-width: 820px){
  .home-rubros-carousel-wrap{ padding: 6px 50px; }
  .rubros-nav{ width: 46px; height: 46px; font-size: 1.8rem; }
  .rubros-nav-prev{ left: 4px; }
  .rubros-nav-next{ right: 4px; }
  .rubro-slide-card{
    flex-basis: calc((100% - 16px) / 2);
    min-width: calc((100% - 16px) / 2);
    max-width: calc((100% - 16px) / 2);
  }
  .rubro-slide-top{ height: 190px; }
  .rubro-slide-circle{ width: 110px; height: 110px; }
  .rubro-slide-bottom{ min-height: 108px; }
}
@media (max-width: 560px){
  .home-rubros-carousel-wrap{ padding: 0 42px; }
  .rubro-slide-card{
    flex-basis: 100%;
    min-width: 100%;
    max-width: 100%;
  }
  .rubro-slide-top{ height: 182px; padding-bottom: 22px; }
  .rubro-slide-circle{ width: 108px; height: 108px; }
  .rubro-slide-bottom{ min-height: 102px; padding: 16px 14px 18px; }
  .rubro-slide-title{ font-size: 1.32rem; }
  .rubro-slide-subtitle{ font-size: .86rem; }
}


.compact-rubro-logo-box {
  margin-top: 12px;
}


.compact-rubro-logo-box .image-preview-grid {
  margin-top: 10px;
}

.rubro-slide-image-wrap{
  width: 100%;
  height: 100%;
  border-radius: 999px;
  overflow: hidden;
  background: #f5f7ff;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 0 !important;
}

.rubro-slide-image{
  width: 112% !important;
  height: 112% !important;
  object-fit: cover !important;
  padding: 0 !important;
  display:block;
}

.rubro-estado-lista {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.rubro-estado-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid rgba(34, 74, 160, 0.14);
  border-radius: 14px;
  background: #fff;
}

.rubro-estado-item strong {
  color: var(--blue-dark);
  font-size: .95rem;
}

.rubro-estado-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 800;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: .82rem;
}

.rubro-estado-badge.activo {
  background: rgba(44, 170, 80, 0.12);
  color: #1f8a44;
}

.rubro-estado-badge.inactivo {
  background: rgba(205, 66, 66, 0.12);
  color: #b13232;
}

.rubro-preview-card {
  width: min(100%, 240px);
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 16px 32px rgba(24, 40, 110, 0.15);
  background: #fff;
  margin-top: 10px;
}

.rubro-preview-top {
  height: 190px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 18px 14px 24px;
  background: radial-gradient(circle at 30% 20%, #6540d6 0%, #4d2cb8 55%, #4327a7 100%);
  border-bottom-left-radius: 80px;
}

.rubro-preview-circle {
  width: 118px;
  height: 118px;
  border-radius: 999px;
  background: #2f40b9;
  border: 4px solid #ff971c;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.07);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.rubro-preview-inner {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  overflow: hidden;
  background: #f5f7ff;
}

.rubro-preview-inner img {
  width: 112%;
  height: 112%;
  object-fit: cover;
  display: block;
}

.rubro-preview-bottom {
  background: #ff8a00;
  color: #fff;
  text-align: center;
  padding: 20px 16px 22px;
}

.rubro-preview-bottom strong {
  display: block;
  font-size: 1.05rem;
  line-height: 1.1;
  text-transform: uppercase;
}

.rubro-preview-bottom span {
  display: block;
  margin-top: 8px;
  font-size: .88rem;
}


/* --- Admin categorías compacto V91 --- */
.categoria-add-form {
  align-items: stretch;
}

.categoria-editor-shell {
  margin-top: 10px;
}

.categoria-editor-shell label,
.categoria-editor-main label,
.categoria-subrubros-box label {
  display: grid;
  gap: 8px;
  color: var(--blue-dark);
  font-weight: 700;
}

.categoria-editor-shell select,
.categoria-editor-main input,
.categoria-editor-main select,
.categoria-subrubros-box input {
  min-height: 48px;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 0 14px;
  background: #fff;
}

.categoria-editor-empty {
  margin-top: 14px;
}

.categoria-editor-panel {
  margin-top: 16px;
  padding: 20px;
  border: 1px solid rgba(34, 74, 160, 0.12);
  border-radius: 22px;
  background: linear-gradient(180deg, #f9fbff 0%, #f3f7ff 100%);
}

.categoria-editor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(260px, .9fr);
  gap: 18px;
  align-items: start;
}

.categoria-editor-main,
.categoria-editor-preview-box,
.categoria-subrubros-box {
  background: #fff;
  border: 1px solid rgba(34, 74, 160, 0.12);
  border-radius: 18px;
  padding: 18px;
}

.categoria-editor-main h4,
.categoria-editor-preview-box h4,
.categoria-subrubros-box h4 {
  margin: 0 0 12px;
}

.categoria-inline-actions {
  align-items: stretch;
}

.categoria-inline-actions .btn {
  white-space: nowrap;
}

.categoria-editor-hidden-selects {
  display: none;
}

.categoria-toggle-block {
  margin-top: 14px;
  padding: 14px;
  border-radius: 16px;
  background: #f4f7fd;
  border: 1px solid rgba(34, 74, 160, 0.08);
}

.categoria-toggle-title {
  display: block;
  color: var(--blue-dark);
  font-weight: 800;
  margin-bottom: 10px;
}

.categoria-toggle-row {
  display: inline-flex !important;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  color: var(--blue-dark);
}

.categoria-toggle-row input {
  width: 18px;
  height: 18px;
  min-height: 18px;
  padding: 0;
}

.categoria-image-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 14px;
}

.categoria-image-actions input[type="file"] {
  flex: 1;
  min-width: 220px;
  min-height: 48px;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 10px 12px;
  background: #fff;
}

.categoria-editor-preview-box .image-preview-grid {
  margin-top: 10px;
  justify-items: center;
}

.categoria-subrubros-box {
  margin-top: 18px;
}

@media (max-width: 900px) {
  .categoria-editor-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .categoria-inline-actions,
  .categoria-image-actions,
  .categoria-add-form {
    flex-direction: column;
  }

  .categoria-inline-actions .btn,
  .categoria-image-actions .btn,
  .categoria-add-form .btn {
    width: 100%;
  }

  .categoria-editor-panel {
    padding: 14px;
  }
}

/* ===== Proveedores compacto ===== */
.proveedor-editor-shell{margin-top:16px;max-width:360px}
.proveedor-editor-panel{margin-top:18px}
.proveedor-grid-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
.proveedor-grid-fields .full-col{grid-column:1/-1}
.proveedor-preview-card{display:grid;gap:10px;padding:16px;border:1px solid rgba(15,79,168,.12);border-radius:18px;background:linear-gradient(180deg,#fff,#f7fbff)}
.proveedor-preview-row{display:flex;justify-content:space-between;gap:12px;font-size:14px;color:#234}
.proveedor-preview-row strong{white-space:nowrap}
.proveedor-preview-row.total{padding-top:10px;border-top:1px dashed rgba(15,79,168,.18);font-weight:700}

/* ===== Producto / proveedores ===== */
.provider-check-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.provider-check-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid rgba(15,79,168,.14);border-radius:14px;background:#fff}
.provider-check-item input{transform:scale(1.05)}
.field-label-block{display:block;font-weight:600;margin-bottom:8px}
.field-help-inline{margin:8px 0 0;color:#667085;font-size:13px}
.provider-summary-box{padding-top:4px}
.provider-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.provider-summary-grid > div{padding:10px 12px;border-radius:14px;background:#f8fbff;border:1px solid rgba(15,79,168,.10)}

@media (max-width: 768px){
  .proveedor-grid-fields,.provider-summary-grid{grid-template-columns:1fr}
}


/* v93 producto simplificado */
.legacy-price-hidden{display:none!important}
.field-price-note{grid-column:span 3;background:#f3f7ff;border:1px dashed #bfd1f7;color:#17478c;padding:12px 14px;border-radius:14px;font-weight:600}
.pricing-simple-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:18px 0}
.pricing-simple-fields{grid-template-columns:1fr 1fr}
@media (max-width:900px){.pricing-simple-grid,.pricing-simple-fields{grid-template-columns:1fr}}

/* Importación Excel */
.compact-import-box{margin-bottom:18px;padding:20px;border:1px dashed rgba(26,82,160,.18);border-radius:20px;background:#f8fbff}
.import-head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:14px}
.import-new-product-btn{white-space:nowrap;align-self:flex-start}
.import-grid{align-items:end}
.import-grid-inline{display:grid;grid-template-columns:minmax(320px,1fr) auto;gap:16px}
.import-file-field{display:flex;flex-direction:column;gap:8px;margin:0}
.import-file-field input[type="file"]{width:100%;max-width:none;padding:10px 12px;border:1px solid rgba(26,82,160,.16);border-radius:16px;background:#fff;overflow:hidden;text-overflow:ellipsis}
.import-actions{justify-content:flex-end;margin-top:8px}
.import-actions-inline{margin-top:0;align-self:end}
.import-actions-inline .btn{min-width:170px}
@media (max-width: 780px){.import-grid-inline{grid-template-columns:1fr}.import-actions-inline{justify-content:flex-start;width:100%}.import-actions-inline .btn{width:100%}}


/* V118 sistema local - alta rápida de cliente sin salir */
.local-client-modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(7,16,32,.68);
  z-index:10000;
}
.local-client-modal.is-open{
  display:flex;
}
.local-client-modal-box{
  width:min(720px, 100%);
  max-height:90vh;
  overflow:auto;
  background:#fff;
  border-radius:24px;
  padding:22px;
  box-shadow:0 24px 80px rgba(12,25,49,.28);
}
.local-client-modal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:16px;
}
.local-client-modal-head h3{
  margin:0 0 4px;
  color:var(--blue-dark);
}
.local-client-modal-head p{
  margin:0;
  color:var(--muted);
  font-weight:600;
}
.local-client-modal-close{
  width:42px;
  height:42px;
  border:0;
  border-radius:14px;
  background:#eef4fc;
  color:#0f4fa8;
  font-size:1.8rem;
  line-height:1;
  cursor:pointer;
}
.local-client-form{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.local-client-form label{
  display:grid;
  gap:8px;
  font-weight:800;
  color:#374151;
}
.local-client-form input,
.local-client-form select{
  min-height:48px;
  border-radius:14px;
  border:1px solid #d7e1f0;
  padding:0 14px;
  font:inherit;
  background:#fff;
}
.local-client-form-status{
  grid-column:1 / -1;
  min-height:20px;
  margin:0;
  color:#b42318;
  font-weight:800;
}
.local-client-form-actions{
  grid-column:1 / -1;
  display:flex;
  justify-content:flex-end;
  gap:12px;
  flex-wrap:wrap;
}
@media (max-width:760px){
  .local-client-form{
    grid-template-columns:1fr;
  }
}


/* Observaciones en sistema local */
.pos-observaciones-card{
  grid-column: 1 / -1;
}
.pos-observaciones-card textarea{
  width:100%;
  min-height:88px;
  resize:vertical;
  border-radius:14px;
  border:1px solid #d7e1f0;
  background:#fff;
  padding:14px 16px;
  font-size:1rem;
  font-family:inherit;
  outline:none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}
.pos-observaciones-card textarea:focus{
  border-color:#0f4fa8;
  box-shadow:0 0 0 3px rgba(15,79,168,0.12);
}


/* Ticket modal sistema local */
.local-ticket-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
}
.local-ticket-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 20, 40, .55);
  backdrop-filter: blur(3px);
}
.local-ticket-modal-box {
  position: relative;
  z-index: 1;
  width: min(430px, 96vw);
  max-height: 92vh;
  overflow: auto;
  background: #f8fbff;
  border-radius: 18px;
  border: 1px solid #d7e3f5;
  box-shadow: 0 20px 60px rgba(0,0,0,.28);
  padding: 16px;
}
.local-ticket-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}
.local-ticket-modal-head h3 { margin: 0; font-size: 20px; color: #22324b; }
.local-ticket-modal-x {
  width: 38px; height: 38px; border-radius: 999px; border: 0;
  background: #e8eef8; color: #22324b; font-size: 26px; line-height: 1; cursor: pointer;
}
.local-ticket-modal-actions { display: flex; gap: 10px; margin-bottom: 14px; }
.local-ticket-modal-actions .btn { flex: 1; justify-content: center; }
.local-ticket-paper {
  width: 300px; max-width: 100%; margin: 0 auto; background: #fff; color: #111;
  border: 1px solid #ddd; box-shadow: 0 8px 24px rgba(0,0,0,.12); padding: 12px;
}
.local-ticket-paper pre {
  margin: 0; white-space: pre-wrap; font-family: "Courier New", monospace;
  font-size: 12px; line-height: 1.25;
}
@media print {
  body * { visibility: hidden !important; }
  #local-ticket-modal, #local-ticket-modal * { visibility: visible !important; }
  #local-ticket-modal { position: absolute !important; inset: 0 auto auto 0 !important; display: block !important; padding: 0 !important; background: #fff !important; }
  .local-ticket-modal-backdrop, .local-ticket-modal-head, .local-ticket-modal-actions { display: none !important; }
  .local-ticket-modal-box { width: 280px !important; max-height: none !important; overflow: visible !important; box-shadow: none !important; border: 0 !important; border-radius: 0 !important; padding: 0 !important; background: #fff !important; }
  .local-ticket-paper { width: 280px !important; box-shadow: none !important; border: 0 !important; padding: 0 !important; }
  .local-ticket-paper pre { font-size: 12px !important; }
}



/* ADV módulos: reparaciones y usuarios */
.repair-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.repair-full {
  grid-column: 1 / -1;
}

.repair-grid textarea {
  width: 100%;
  min-height: 82px;
  resize: vertical;
  border-radius: 12px;
  border: 1px solid #d7e3f5;
  padding: 10px 12px;
  font: inherit;
  box-sizing: border-box;
}

.repair-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.repair-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.repair-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px;
  border: 1px solid #d7e3f5;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 8px 24px rgba(15, 35, 70, .06);
}

.repair-item strong,
.repair-item span,
.repair-item small {
  display: block;
}

.repair-item small {
  color: #63708a;
  margin-top: 4px;
}

.repair-item-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

@media (max-width: 720px) {
  .repair-grid {
    grid-template-columns: 1fr;
  }

  .repair-item {
    align-items: stretch;
    flex-direction: column;
  }

  .repair-item-actions {
    justify-content: flex-start;
  }
}


/* ADV permisos de usuarios */
.employee-permissions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 12px;
  background: #f8fbff;
  border: 1px solid #d7e3f5;
  border-radius: 14px;
}

.employee-permissions label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  color: #22324b;
}

.permission-help {
  display: block;
  margin-top: 8px;
  color: #63708a;
}

@media (max-width: 720px) {
  .employee-permissions {
    grid-template-columns: 1fr;
  }
}

/* Cierre de caja PRO */
.caja-head-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.cierre-caja-modal-box {
  width: min(620px, 96vw);
}

.cierre-caja-resumen {
  margin: 12px 0;
}

.cierre-caja-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.cierre-caja-grid div {
  background: #fff;
  border: 1px solid #d7e3f5;
  border-radius: 14px;
  padding: 12px;
}

.cierre-caja-grid span {
  display: block;
  color: #5d6f8c;
  font-weight: 700;
  margin-bottom: 4px;
}

.cierre-caja-grid strong {
  color: #0f3d7a;
  font-size: 18px;
}

.cierre-caja-grid .is-total {
  grid-column: 1 / -1;
  background: #f3fff7;
  border-color: #9fe3b4;
}

.cierre-caja-grid .is-total strong {
  color: #10803d;
  font-size: 24px;
}

.cierre-caja-nota textarea {
  width: 100%;
  min-height: 74px;
  resize: vertical;
  border-radius: 12px;
  border: 1px solid #d7e3f5;
  padding: 10px;
  box-sizing: border-box;
}

@media (max-width: 720px) {
  .cierre-caja-grid {
    grid-template-columns: 1fr;
  }
}

/* Reparaciones clientes ADV */
.repair-client-search-row {
  display: flex;
  gap: 10px;
  align-items: center;
}

.repair-client-search-row input {
  flex: 1;
}

.repair-client-selected {
  margin-top: 8px;
  color: #63708a;
  font-weight: 700;
  font-size: 13px;
}

.repair-client-selected.ok {
  color: #10803d;
}

.repair-client-modal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

@media (max-width: 720px) {
  .repair-client-modal-grid {
    grid-template-columns: 1fr;
  }
}

/* Reparaciones PRO ADV */
.repair-item-pro {
  border-left: 6px solid #9db2ce;
}

.repair-status-pill,
.repair-money-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 9px;
  font-size: 12px;
  font-weight: 800;
  margin: 6px 5px 0 0;
  background: #eef4ff;
  color: #25466b;
}

.repair-money-pill.ok {
  background: #e7f9ee;
  color: #12813e;
}

.repair-money-pill.pending {
  background: #fff4e0;
  color: #9a5a00;
}

.repair-item-pro.estado-ingresado,
.repair-status-pill.estado-ingresado {
  border-left-color: #7187a3;
}

.repair-item-pro.estado-revision,
.repair-status-pill.estado-revision {
  border-left-color: #e0a100;
}

.repair-item-pro.estado-presupuestado,
.repair-status-pill.estado-presupuestado {
  border-left-color: #7b61ff;
}

.repair-item-pro.estado-reparado,
.repair-status-pill.estado-reparado {
  border-left-color: #16a34a;
}

.repair-item-pro.estado-entregado,
.repair-status-pill.estado-entregado {
  border-left-color: #0ea5e9;
}

.repair-item-pro.estado-sin,
.repair-status-pill.estado-sin {
  border-left-color: #ef4444;
}

.repair-status-pill.estado-ingresado { background:#eef4ff; color:#25466b; }
.repair-status-pill.estado-revision { background:#fff7db; color:#8a5a00; }
.repair-status-pill.estado-presupuestado { background:#efeaff; color:#4c35b5; }
.repair-status-pill.estado-reparado { background:#e7f9ee; color:#12813e; }
.repair-status-pill.estado-entregado { background:#e6f7ff; color:#0873a3; }
.repair-status-pill.estado-sin { background:#ffecec; color:#b32626; }

.repair-cobro-detalle {
  background: #f8fbff;
  border: 1px solid #d7e3f5;
  border-radius: 14px;
  padding: 12px;
  margin-bottom: 12px;
  color: #22324b;
  line-height: 1.5;
}

#repair-cobro-nota {
  width: 100%;
  min-height: 74px;
  resize: vertical;
  border-radius: 12px;
  border: 1px solid #d7e3f5;
  padding: 10px;
  box-sizing: border-box;
}


/* Agenda y recordatorios ADV */
.agenda-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.agenda-form-grid textarea{width:100%;min-height:105px;resize:vertical;border-radius:12px;border:1px solid #d7e3f5;padding:10px 12px;box-sizing:border-box;font:inherit}
.agenda-filter-row{display:flex;gap:10px;flex-wrap:wrap}
.agenda-filter-row input[type="date"]{border-radius:999px;border:1px solid #d7e3f5;padding:10px 12px;background:#fff}
.agenda-list{display:flex;flex-direction:column;gap:12px}
.agenda-item{display:flex;justify-content:space-between;gap:16px;border:1px solid #d7e3f5;border-left:6px solid #94a3b8;border-radius:18px;background:#fff;padding:15px;box-shadow:0 8px 24px rgba(15,35,70,.06)}
.agenda-item.agenda-importante{border-left-color:#f59e0b}.agenda-item.agenda-urgente{border-left-color:#ef4444}.agenda-item.is-done{opacity:.68}
.agenda-item-main h3{margin:6px 0;color:#22324b}.agenda-item-main p{margin:0 0 8px;color:#40516b;white-space:pre-wrap}
.agenda-item-top{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.agenda-item-top strong,.agenda-item-top span,.agenda-item-top em{border-radius:999px;padding:5px 9px;font-size:12px;font-weight:800;font-style:normal;background:#eef4ff;color:#25466b}
.agenda-alert-list{display:flex;flex-direction:column;gap:10px;margin:12px 0}
.agenda-alert-item{background:#fff;border:1px solid #d7e3f5;border-left:5px solid #0f62fe;border-radius:14px;padding:12px}
.agenda-alert-item strong,.agenda-alert-item span{display:block}.agenda-alert-item p{white-space:pre-wrap;margin:8px 0 0}
@media(max-width:720px){.agenda-form-grid{grid-template-columns:1fr}.agenda-item{flex-direction:column}}

/* Caja movimientos ADV */
#movimiento-caja-nota {
  width: 100%;
  min-height: 80px;
  resize: vertical;
  border-radius: 12px;
  border: 1px solid #d7e3f5;
  padding: 10px;
  box-sizing: border-box;
}
.caja-head-actions {
  gap: 10px;
}

/* Clientes plus admin ADV */
.admin-add-client-plus {
  flex: 0 0 auto;
  width: 42px;
  height: 42px;
  font-size: 24px;
  font-weight: 900;
}

/* Reparaciones: fecha y cliente en la misma línea */
.repair-grid > label.pos-field:first-child {
  grid-column: span 1;
}
.repair-grid > .repair-client-field {
  grid-column: span 1;
}
.repair-client-field .repair-client-search-row {
  width: 100%;
}
@media (max-width: 720px) {
  .repair-grid > label.pos-field:first-child,
  .repair-grid > .repair-client-field {
    grid-column: 1 / -1;
  }
}


/* Reparaciones FIX final: Fecha compacta + cliente amplio + dropdown correcto */
.repair-date-client-row{
  grid-column: 1 / -1;
  display:grid;
  grid-template-columns: minmax(190px, 260px) minmax(0, 1fr);
  gap:16px;
  align-items:start;
}
.repair-date-field{min-width:0;}
.repair-date-field input{width:100%; box-sizing:border-box;}
.repair-client-field{position:relative; min-width:0; z-index:20;}
.repair-client-field .repair-client-search-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) 48px;
  gap:10px;
  align-items:center;
  width:100%;
}
.repair-client-field .repair-client-search-row input{width:100%; box-sizing:border-box;}
.repair-client-field .pos-client-results{
  position:absolute !important;
  left:0 !important;
  right:58px !important;
  top:92px !important;
  z-index:99999 !important;
  max-height:240px;
  overflow:auto;
  margin-top:0 !important;
  display:none;
  background:#fff;
  border:1px solid #d7e3f5;
  border-radius:16px;
  box-shadow:0 16px 35px rgba(15,35,70,.18);
  padding:10px;
}
.repair-client-field .pos-client-item{box-sizing:border-box;}
@media (max-width:720px){
  .repair-date-client-row{grid-template-columns:1fr;}
  .repair-client-field .pos-client-results{position:static !important; right:auto !important; top:auto !important; margin-top:10px !important;}
}


/* V145 Reparaciones: resultado de cliente pegado al buscador */
.repair-client-search-wrap{
  position:relative;
  width:100%;
  min-width:0;
}
.repair-client-search-wrap > input{
  width:100%;
  box-sizing:border-box;
}
.repair-client-search-wrap > .pos-client-results{
  position:absolute !important;
  left:0 !important;
  right:0 !important;
  top:calc(100% + 8px) !important;
  z-index:999999 !important;
  max-height:240px;
  overflow:auto;
  margin-top:0 !important;
  display:none;
  background:#fff;
  border:1px solid #d7e3f5;
  border-radius:16px;
  box-shadow:0 16px 35px rgba(15,35,70,.18);
  padding:10px;
}
.repair-client-field{
  overflow:visible !important;
}
.repair-date-client-row{
  overflow:visible !important;
}
@media (max-width:720px){
  .repair-client-search-wrap > .pos-client-results{
    position:absolute !important;
    top:calc(100% + 8px) !important;
  }
}


/* ADV v146 - contraseña editable en clientes */
.admin-password-box {
  margin-top: 16px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  display: grid;
  gap: 10px;
}
.admin-password-box h4 {
  margin: 0;
  font-size: 1rem;
}
.admin-password-field {
  display: grid;
  gap: 6px;
  font-weight: 700;
}
.admin-password-field input {
  width: 100%;
}

/* FIX V148 - Header login/menu restaurado */
.header-right-zone .user-login-btn,
.header-right-zone .user-logout-btn {
  min-height: 46px;
  border-radius: 14px;
  padding: 0 16px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}
.header-right-zone .user-login-btn {
  background: #fff;
  color: var(--blue-dark);
  border: 1px solid var(--border);
}
.header-right-zone .user-login-btn:hover,
.header-right-zone .user-logout-btn:hover {
  box-shadow: var(--shadow-soft);
  transform: translateY(-1px);
}
.header-menu-public .menu-dropdown-box {
  z-index: 9999;
}
@media (min-width: 1181px) {
  .header-dynamic { flex-wrap: nowrap; }
  .header-right-zone { flex-wrap: nowrap; }
}


/* FIX HOME OFERTAS COMPACTO - evita tarjetas largas con espacios gigantes */
#ofertas-grid{
  align-items:start;
}

#ofertas-grid .product-card{
  height:auto;
  min-height:0;
  align-self:start;
}

#ofertas-grid .product-image{
  height:210px;
  min-height:210px;
  max-height:210px;
  padding:10px;
}

#ofertas-grid .product-card .product-body{
  height:auto;
  min-height:0;
  flex:0 0 auto;
  padding:12px 14px 14px;
  gap:7px;
}

#ofertas-grid .product-card h3{
  min-height:0;
  margin:0;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

#ofertas-grid .product-card p{
  min-height:0 !important;
  margin:0;
  line-height:1.3;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

#ofertas-grid .product-stock{
  margin:2px 0 0;
}

#ofertas-grid .price-row{
  margin:0;
  gap:4px;
}

#ofertas-grid .login-hint{
  margin:2px 0 0;
}

#ofertas-grid .product-card-footer{
  margin-top:4px;
}

@media (max-width:640px){
  #ofertas-grid .product-image{
    height:180px;
    min-height:180px;
    max-height:180px;
  }
}

/* Fix cliente: acciones juntas en detalle */
.admin-client-actions-inline {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.admin-client-actions-inline .btn {
  min-width: 190px;
}
