/* Namespaced to avoid theme/admin conflicts */
.yetka-qb-wrap { max-width: 1180px; margin: 0 auto; padding: 18px; }
.yetka-qb-front { font-family: inherit; }
.yetka-qb-header { margin-bottom: 14px; }
.yetka-qb-title { margin: 0 0 4px; font-size: 34px; line-height: 1.1; }
.yetka-qb-subtitle { color: #6b7280; font-size: 14px; }

.yetka-qb-grid { display: grid; grid-template-columns: 360px 1fr; gap: 18px; }
@media (max-width: 980px){ .yetka-qb-grid { grid-template-columns: 1fr; } }

.yetka-qb-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 8px 24px rgba(0,0,0,.04);
}

.yetka-qb-card h3 { margin: 0 0 12px; font-size: 22px; }

.yetka-qb-form { display: grid; gap: 10px; }
.yetka-qb-field span { display:block; font-size: 13px; color: #374151; margin-bottom: 6px; }
.yetka-qb-input {
  width: 100%;
  height: 40px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.12);
  padding: 0 12px;
  outline: none;
  background: #fff;
}
.yetka-qb-input:focus { border-color: rgba(0,0,0,.25); }

.yetka-qb-help { color:#6b7280; font-size: 12px; }

.yetka-qb-inline-error{
  margin-top:6px;
  font-size:12px;
  color:rgba(185, 28, 28, 0.85);
}

.yetka-qb-addline { display:flex; gap: 10px; align-items:center; margin-bottom: 10px; }
.yetka-qb-btn {
  height: 40px;
  border-radius: 5px;
  border: 1px solid rgba(0,0,0,.12);
  background: #0f172a;
  color: #fff;
  padding: 0 16px;
  cursor: pointer;
  font-weight: 600;
  white-space: nowrap;
}
.yetka-qb-btn:hover { opacity:.95; }
.yetka-qb-btn-primary { background:#0f172a; }
.yetka-qb-btn-ghost { background:#fff; color:#0f172a; }
.yetka-qb-link { color:#0f172a; text-decoration: underline; }

.yetka-qb-tablewrap { margin-top: 6px; }
.yetka-qb-table { width: 100%; border-collapse: collapse; overflow:hidden; border-radius: 10px; }
.yetka-qb-table th, .yetka-qb-table td { border-bottom: 1px solid rgba(0,0,0,.06); padding: 10px; font-size: 13px; }
.yetka-qb-table thead th { background: rgba(15,23,42,.04); color:#111827; text-align:left; font-weight:700; }

.yetka-qb-mini { width: 86px; height: 34px; border-radius: 10px; }
.yetka-qb-x {
  width: 34px; height: 34px; border-radius: 10px;
  border: 1px solid rgba(0,0,0,.12); background:#0086cd; cursor:pointer;
}

.yetka-qb-totals { display:flex; flex-wrap:wrap; gap: 18px; justify-content:flex-end; padding: 12px 0 6px; color:#374151; }
.yetka-qb-actions { display:flex; gap: 10px; flex-wrap: wrap; justify-content:flex-end; margin-top: 10px; }

/* Badge con el número de cotización cuando se está editando */
.yetka-qb-quote-badge{
  margin: 6px 0 10px 0;
  padding: 8px 12px;
  border: 1px dashed rgba(0,0,0,.18);
  border-radius: 12px;
  background: rgba(0,0,0,.03);
  font-weight: 700;
}

/* Encabezado de sección (título + acción a la derecha) */
.yetka-qb-section-head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.yetka-qb-section-head h3{
  margin: 0;
}

.yetka-qb-note { margin-top: 10px; padding: 10px 12px; border-radius: 12px; display:none; }
.yetka-qb-note.is-ok { background: rgba(34,197,94,.10); border: 1px solid rgba(34,197,94,.25); color:#14532d; }
.yetka-qb-note.is-err { background: rgba(239,68,68,.10); border: 1px solid rgba(239,68,68,.25); color:#7f1d1d; }

.yetka-qb-alert { padding: 12px 14px; border-radius: 12px; background: rgba(15,23,42,.06); }

.yetka-qb-suggestions{
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 10px;
}
.yetka-qb-sug-item{
  display:flex; align-items:center; gap: 10px;
  padding: 10px;
  cursor:pointer;
  background:#fff;
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.yetka-qb-sug-item:hover{ background: rgba(15,23,42,.03); }
.yetka-qb-sug-img{ width: 34px; height: 34px; border-radius: 8px; object-fit: cover; }
.yetka-qb-sug-txt{ flex:1; font-size: 13px; color:#111827; }
.yetka-qb-sug-price{ font-weight:700; font-size: 13px; color:#0f172a; }

.yetka-qb-row{ display:flex; align-items:center; justify-content:space-between; margin-bottom: 8px; }
.yetka-qb-kv{ display:grid; grid-template-columns: 1fr 1fr; gap: 8px; margin: 10px 0; color:#374151; }
@media (max-width: 680px){ .yetka-qb-kv{ grid-template-columns: 1fr; } }

/* Modal */
.yetka-qb-modal { position: fixed; inset: 0; z-index: 99999; }
.yetka-qb-modal-backdrop { position:absolute; inset:0; background: rgba(0,0,0,.45); }
.yetka-qb-modal-card {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: min(760px, 92vw);
  background: #fff;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.10);
  box-shadow: 0 18px 60px rgba(0,0,0,.22);
  padding: 14px;
}
.yetka-qb-modal-head { display:flex; align-items:flex-start; justify-content:space-between; gap: 12px; margin-bottom: 10px; }
.yetka-qb-modal-title { font-weight: 800; font-size: 18px; }
.yetka-qb-modal-sub { color:#6b7280; font-size: 13px; margin-top: 2px; }
.yetka-qb-modal-x {
  width: 38px; height: 38px; border-radius: 12px;
  border: 1px solid rgba(0,0,0,.12); background:#fff; cursor:pointer; font-size: 22px; line-height: 1;
}
.yetka-qb-modal-actions { display:flex; justify-content:flex-end; gap: 10px; margin-top: 12px; }

.yetka-qb-var-wrap { display:grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 720px){ .yetka-qb-var-wrap { grid-template-columns: 1fr; } }
.yetka-qb-var-row { display:grid; gap: 6px; }
.yetka-qb-var-label { color:#374151; font-size: 13px; font-weight: 700; }
.yetka-qb-var-list { margin-top: 12px; padding-top: 10px; border-top: 1px solid rgba(0,0,0,.08); }
.yetka-qb-var-hint { color:#6b7280; font-size: 12px; margin-bottom: 8px; }
.yetka-qb-var-item { font-size: 12px; padding: 6px 8px; border: 1px solid rgba(0,0,0,.06); border-radius: 10px; margin-bottom: 6px; background: rgba(15,23,42,.02); }

/* Admin helpers */
.yetka-qb-admin-grid { display:grid; grid-template-columns: 1.1fr .9fr; gap: 14px; }
@media (max-width: 1100px){ .yetka-qb-admin-grid { grid-template-columns: 1fr; } }
.yetka-qb-admin-card { background:#fff; padding: 14px; border: 1px solid #e5e7eb; border-radius: 12px; }
.yetka-qb-admin-card h2 { margin: 0 0 10px; }

/* Marca de agua (solo en el quote-builder del asesor cuando el cliente modificó) */
.yetka-qb-client-watermark{
  margin-top:4px;
  font-size:12px;
  line-height:1.3;
  color:#64748b;
  opacity:0.9;
  font-style:italic;
}

/* Icon buttons + tooltip */
.yetka-qb-icon-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  line-height:1;
}
.yetka-qb-icon-btn svg{display:block}
.yetka-qb-item-actions{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:nowrap;
}
.yetka-qb-item-actions .yetka-qb-btn,
.yetka-qb-item-actions .yetka-qb-x{
  margin:0;
}

[data-yqbtip]{ position:relative; }
[data-yqbtip]::after{
  content: attr(data-yqbtip);
  position:absolute;
  left:50%;
  bottom:calc(100% + 8px);
  transform:translateX(-50%) translateY(4px);
  background:#0f172a;
  color:#fff;
  font-size:12px;
  padding:6px 8px;
  border-radius:8px;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:opacity .12s ease, transform .12s ease;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
  z-index:9999;
}
[data-yqbtip]:hover::after,
[data-yqbtip]:focus::after,
[data-yqbtip].yqbtip-show::after{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}

/* ------------------------------------------------------------
   Responsive adjustments (tablet-first)
   Objective: keep the same UI/structure, but make tables and
   key actions usable on tablets and mobile.
------------------------------------------------------------ */

/* Tablet: enable horizontal scroll for tables without changing markup */
@media (max-width: 1100px){
  .yetka-qb-card{
    overflow-x:auto;
    -webkit-overflow-scrolling: touch;
  }
  .yetka-qb-tablewrap{
    overflow-x:auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Force a minimum table width so columns do not collapse */
  .yetka-qb-table{ min-width: 920px; }

  /* Client quotes grid can be slightly narrower */
  #yetka-qb-client-quotes-wrap .yetka-qb-table{ min-width: 740px; }

  /* Portal/Public quote tables */
  .yetka-qb-front .yetka-qb-table{ min-width: 760px; }

  /* Keep product column readable */
  .yetka-qb-table td:first-child{ min-width: 260px; }

  /* Inputs inside tables stay usable */
  .yetka-qb-table .yetka-qb-input{ min-width: 86px; }
}

/* Mobile: stack controls cleanly (no structural changes) */
@media (max-width: 768px){
  .yetka-qb-wrap{ padding: 12px; }
  .yetka-qb-title{ font-size: 26px; }

  .yetka-qb-addline{ flex-wrap: wrap; }
  .yetka-qb-addline .yetka-qb-input{ flex: 1 1 100%; }

  .yetka-qb-totals{ justify-content:flex-start; gap: 10px; }
  .yetka-qb-actions{ justify-content:flex-start; }
  .yetka-qb-actions .yetka-qb-btn,
  .yetka-qb-actions a.yetka-qb-btn{ flex: 1 1 auto; }

  .yetka-qb-modal-card{
    max-height: 90vh;
    overflow: auto;
  }
}