/* ═══ MC01 SHARED — Estilos de transaccion reutilizados por MR01/MR02/MR03/MR05/MR10 ═══ */

.mc01 {
    padding: 10px 14px 16px;
    color: var(--g-text);
    font-size: 12px;
}

/* Select / option theming */
.mc01 select,
.mc01 select option {
    background: var(--g-surface);
    color: var(--g-text);
}

.mc01 select:focus {
    outline: none;
    border-color: var(--g-create);
    box-shadow: 0 0 0 2px var(--g-focus-ring);
}

.mc01-message {
    border: 1px solid var(--g-border-strong);
    background: var(--g-surface);
}

.mc01-shell {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.mc01-head,
.mc01-panel,
.mc01-grid-card,
.mc01-footer {
    background: var(--g-surface);
}

.mc01-message {
    margin-bottom: 8px;
    padding: 8px 10px;
    font-size: 11px;
    font-weight: 600;
}

.mc01-message-error { background: var(--g-err-bg); color: var(--g-err); }
.mc01-message-success { background: var(--g-ok-bg); color: var(--g-ok); }
.mc01-message-warn { background: var(--g-warn-bg); color: var(--g-warn); }

.mc01-head {
    padding: 6px 10px;
    border-top: 3px solid var(--g-consult);
}

.mc01-head-row {
    display: grid;
    grid-template-columns: auto minmax(240px, 320px) auto minmax(110px, 126px) minmax(140px, 200px) max-content auto 118px;
    gap: 5px;
    align-items: center;
}

.mc01-head-row label,
.mc01-label,
.mc01-vendor-grid span,
.mc01-summary span {
    font-size: 11px;
    font-weight: 500;
    color: var(--g-text-muted);
}

.mc01-control,
.mc01-grid-input {
    width: 100%;
    min-height: 24px;
    border: 1px solid var(--g-border-strong);
    background: var(--g-surface);
    color: var(--g-text);
    padding: 2px 6px;
    font: inherit;
    font-size: 11px;
}

.mc01-control:focus,
.mc01-grid-input:focus,
.mc01-grid-wrap:focus {
    outline: none;
    border-color: var(--g-create);
    box-shadow: 0 0 0 2px var(--g-focus-ring);
}

.mc01-control.readonly,
.mc01-grid-input.readonly {
    background: var(--g-surface-sub);
    color: var(--g-text-sec);
}

.mc01-icon-btn {
    min-height: 24px;
    border: 1px solid var(--g-border-strong, #2d3e50);
    border-radius: 4px;
    background: var(--g-surface);
    color: var(--g-text, #e0e0e0);
    padding: 2px 6px;
    cursor: pointer;
    font-size: 14px;
}

.mc01-icon-btn:disabled {
    cursor: not-allowed;
    opacity: .55;
}

.mc01-mini {
    min-height: 24px;
    display: inline-flex;
    align-items: center;
    padding: 0 8px;
    border: 1px solid var(--g-border-strong);
    background: var(--g-surface-sub);
    font-size: 11px;
    color: var(--g-text-sec);
}

.mc01-tabs {
    display: flex;
    gap: 4px;
    padding: 0 4px;
    border-bottom: 1px solid var(--g-border);
}

.mc01-tab {
    border: none;
    border-bottom: 2px solid transparent;
    background: transparent;
    color: var(--g-text-sec);
    padding: 8px 14px;
    margin-bottom: -1px;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: color 150ms ease-out, border-bottom-color 150ms ease-out;
}

.mc01-tab:hover:not(.active) { color: var(--g-text); }

.mc01-tab.active {
    color: var(--g-text);
    border-bottom-color: var(--accent);
    font-weight: 600;
}

.mc01-panel { padding: 8px 4px; }
.mc01-panel-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.mc01-card { border: 1px solid var(--g-border); padding: 12px; background: var(--g-surface); }
.mc01-card-title { margin-bottom: 10px; font-size: 14px; font-weight: 600; color: var(--g-text); }
.mc01-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px 12px; }
.mc01-form-grid.single { grid-template-columns: 1fr; }
.mc01-costing-grid { margin-bottom: 10px; }
.mc01-field { display: grid; grid-template-columns: 118px minmax(0, 1fr); gap: 8px; align-items: center; }
.mc01-data-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px 12px; }
.mc01-data-grid .mc01-field { grid-template-columns: 92px minmax(0, 1fr); gap: 6px; }
.mc01-field-tight { grid-template-columns: 64px minmax(0, 1fr) !important; }
.mc01-field-span-2 { grid-column: span 2; }
.mc01-field-span-3 { grid-column: span 3; }
.mc01-inline-group { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.mc01-textarea { min-height: 72px; resize: vertical; }
.mc01-note { font-size: 11px; color: var(--g-text-muted); margin-bottom: 8px; }
.mc01-form-grid.org-grid .mc01-field { grid-template-columns: 110px minmax(0, 1fr); }

.mc01-grid-card { padding: 8px 10px 10px; }
.mc01-grid-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 8px;
}

.mc01-grid-head strong { display: block; font-size: 12px; margin-bottom: 2px; }
.mc01-grid-head span, .mc01-hint { font-size: 11px; color: var(--g-text-muted); }
.mc01-grid-meta { display: flex; gap: 8px; align-items: center; }

.mc01-grid-wrap {
    overflow: auto;
    border: 1px solid var(--g-border-strong);
    max-height: 340px;
    background: var(--g-surface);
}

.mc01-grid-wrap.compact { max-height: 210px; }

.mc01-table { width: 100%; min-width: 1160px; border-collapse: collapse; }
.mc01-table.items { min-width: 1680px; }
.mc01-table thead th {
    position: sticky;
    top: 0;
    z-index: 1;
    padding: 7px 9px;
    background: linear-gradient(180deg, var(--g-surface-sub) 0%, var(--g-surface-sec) 100%);
    border-bottom: 1px solid var(--g-border-strong);
    text-align: left;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--g-text-sec);
    letter-spacing: .05em;
    white-space: nowrap;
}

.mc01-table td { border-bottom: 1px solid var(--g-border); padding: 0; }
/* Variante "linear" (listas read-only tipo MB51/MB52): 1 linea por fila, el scroll
   horizontal resuelve el ancho. Evita que celdas con nombres largos agranden la fila. */
.mc01-table.linear td { white-space: nowrap; padding: 8px 10px; vertical-align: middle; }
.mc01-table.linear tbody tr td { background: var(--g-surface-sub); }
.mc01-table.linear tbody tr:hover td { background: var(--g-selected-bg); }
.mc01-table tbody tr:hover { background: var(--g-surface-sub); }
.mc01-table tbody tr.selected { background: var(--g-selected-bg); }
.mc01-table tbody tr.deleted { opacity: .45; }
.mc01-table tbody tr.deleted td { text-decoration: line-through; }
.mc01-table tbody tr.closed { background: var(--g-surface-sec); }

.mc01-grid-input {
    min-height: 28px;
    border: 1px solid transparent;
    background: transparent;
    padding: 5px 7px;
}

.mc01-grid-input.readonly { background: transparent; }
.mc01-grid-input.num { text-align: right; }
.mc01-table .tiny { width: 28px; }
.mc01-table .center { text-align: center; }

/* Punto de estado de fila (ALV): primitivo de grilla compartido (estilo MB1C). */
.mc01-rowdot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--g-surface-sec); }
.mc01-rowdot.ok { background: var(--g-ok); }
.mc01-rowdot.danger { background: var(--g-err); }
.mc01-rowdot.warn { background: var(--g-warn); }
.mc01-rowdot.muted { background: var(--g-text-sec); opacity: .5; }
.mc01-rowdot.empty { background: transparent; border: 1px solid var(--g-border); }

.mc01-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 3px 7px;
    border-radius: 999px;
    font-size: 9px;
    font-weight: 700;
}

.mc01-chip.ok { background: var(--g-ok-bg); color: var(--g-ok); }
.mc01-chip.muted, .mc01-chip.soft { background: var(--g-surface-sec); color: var(--g-text-sec); }

.mc01-summary {
    margin-top: 10px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.mc01-summary > div {
    padding: 8px;
    border: 1px solid var(--g-border-strong);
    background: var(--g-surface-sub);
}

.mc01-summary strong {
    display: block;
    margin-top: 3px;
    font-size: 12px;
    color: var(--g-text);
}

/* Strip de stats inline compacto (label valor   label valor) —
   alternativa liviana a los boxes contenedores de .mc01-summary. */
.mc01-statline {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px 22px;
    padding: 6px 2px 12px;
    font-size: 12px;
    color: var(--g-text-muted);
}
.mc01-statline > span strong {
    margin-left: 6px;
    font-weight: 700;
    color: var(--g-text);
}

.mc01-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 8px 10px;
    position: sticky;
    bottom: 0;
}

.mc01-footer-msg { color: var(--g-text-muted); font-size: 11px; }
.mc01-footer-actions { display: flex; gap: 8px; }

.mc01-btn {
    border: 1px solid var(--g-border-strong);
    background: var(--g-surface);
    color: var(--g-text);
    padding: 6px 10px;
    font-size: 11px;
    font-weight: 700;
    cursor: pointer;
}

.mc01-btn.primary { background: var(--g-create); border-color: var(--g-create); color: var(--accent-contrast); }
.mc01-btn.danger { border-color: var(--g-err-border); color: var(--g-err); }
.mc01-btn:disabled { opacity: .55; cursor: not-allowed; }

.mc01-code {
    font-family: "DM Mono", Consolas, Monaco, monospace;
}

.w-code-xs { max-width: 56px; }
.w-code-sm { max-width: 84px; }
.w-code-md { max-width: 98px; }
.w-date { max-width: 126px; }
.w-name-sm { max-width: 150px; }
.w-name-md { min-width: 170px; max-width: 220px; }
.w-combo-sm { max-width: 110px; }
.w-combo-md { max-width: 160px; }

/* ── Iconos SVG tokenizados (PR1 impeccable audit 2026-05-27) ── */
.mc01-status-icon {
    display: inline-block;
    vertical-align: middle;
    flex-shrink: 0;
}

.mc01-status-icon-info { color: var(--g-warn); }
.mc01-status-icon-info circle { stroke: currentColor; fill: none; }
.mc01-status-icon-info circle:nth-of-type(2) { fill: currentColor; stroke: none; }
.mc01-status-icon-info rect { fill: currentColor; }

.mc01-status-icon-err { color: var(--g-err); }
.mc01-status-icon-err circle { fill: currentColor; }
.mc01-status-icon-err path { stroke: var(--inverse-text); fill: none; }

.mc01-status-icon-warn { color: var(--g-warn); }
.mc01-status-icon-warn path { fill: currentColor; }
.mc01-status-icon-warn rect,
.mc01-status-icon-warn circle { fill: var(--inverse-text); }

.mc01-search-icon {
    color: var(--g-text-sec);
    display: inline-block;
    vertical-align: middle;
}
.mc01-icon-btn:hover:not(:disabled) .mc01-search-icon { color: var(--g-text); }

/* ── Status Panel rediseño (PR2 impeccable audit 2026-05-27) ── */
.mc01-status {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 2px;
}

.mc01-status-hero {
    padding: 16px 18px;
    background: var(--g-surface-sub);
    border: 1px solid var(--g-border);
    border-radius: var(--radius-md, 8px);
}

.mc01-status-hero-eyebrow {
    font-size: 10px;
    font-weight: 700;
    color: var(--g-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.mc01-status-hero-title {
    margin-top: 4px;
    font-size: 22px;
    font-weight: 600;
    color: var(--g-text);
    line-height: 1.15;
    letter-spacing: -0.005em;
}

.mc01-status-hero-sub {
    margin-top: 4px;
    font-size: 12px;
    color: var(--g-text-sec);
    font-weight: 400;
}

.mc01-status-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.mc01-status-section {
    padding: 12px 14px;
    background: var(--g-surface);
    border: 1px solid var(--g-border);
    border-radius: var(--radius-sm, 4px);
}

.mc01-status-section-title {
    margin-bottom: 10px;
    font-size: 10px;
    font-weight: 700;
    color: var(--g-text-sec);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.mc01-status-dl {
    margin: 0;
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 6px 16px;
    align-items: baseline;
}

.mc01-status-dl dt {
    font-size: 11px;
    color: var(--g-text-muted);
    font-weight: 400;
}

.mc01-status-dl dd {
    margin: 0;
    font-size: 13px;
    color: var(--g-text);
    font-weight: 500;
}

.mc01-status-dl-horizontal {
    grid-template-columns: max-content 1fr max-content 1fr;
}

.mc01-status-fraction {
    color: var(--g-text-muted);
    font-size: 11px;
    font-weight: 400;
    margin-left: 2px;
}

.mc01-status-totals {
    padding: 14px 16px;
    background: var(--g-surface);
    border: 1px solid var(--g-border);
    border-radius: var(--radius-sm, 4px);
}

.mc01-status-totals-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    align-items: end;
}

.mc01-status-total {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.mc01-status-total-label {
    font-size: 11px;
    color: var(--g-text-muted);
    font-weight: 400;
}

.mc01-status-total-value {
    font-size: 16px;
    font-weight: 600;
    color: var(--g-text);
    font-variant-numeric: tabular-nums;
    line-height: 1.2;
}

.mc01-status-total-value em {
    font-style: normal;
    font-size: 11px;
    color: var(--g-text-muted);
    font-weight: 400;
    margin-left: 4px;
}

.mc01-status-total-highlight .mc01-status-total-value {
    font-size: 20px;
    font-weight: 700;
    color: var(--accent);
}

.mc01-status-total-highlight .mc01-status-total-value em {
    color: var(--g-text-sec);
}

.mc01-status-import {
    background: var(--g-surface-sub);
}

/* ── Utilidades (PR3 impeccable audit 2026-05-27) ── */
.mc01-empty-state {
    padding: 32px 16px;
    text-align: center;
    color: var(--g-text-muted);
    font-style: italic;
    font-size: 12px;
}

.mc01-action-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.mc01-stack-sm { margin: 8px 0; }

.mc01-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 3px 7px;
    border-radius: 999px;
    font-size: 9px;
    font-weight: 700;
}
.mc01-chip.ok { background: var(--g-ok-bg); color: var(--g-ok); }
.mc01-chip.muted, .mc01-chip.soft { background: var(--g-surface-sec); color: var(--g-text-sec); }
.mc01-chip.warn, .mc01-chip.warning { background: var(--g-warn-bg); color: var(--g-warn); }
.mc01-chip.danger { background: var(--g-err-bg); color: var(--g-err); }
.mc01-chip.info { background: var(--g-info-bg); color: var(--g-info); }
.mc01-chip.mini { padding: 1px 5px; font-size: 8px; }

.mc01-btn.sm {
    padding: 4px 10px;
    font-size: 10px;
}

.w-bp-code { width: 100px; }
.w-select-md { min-width: 200px; max-width: 260px; }
.w-col-action { min-width: 260px; }

.mc01-chip-inline-tag {
    padding: 1px 5px;
    font-size: 8px;
    margin-left: 3px;
}

@media (max-width: 1260px) {
    .mc01-head-row { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .mc01-field,
    .mc01-form-grid.org-grid .mc01-field { grid-template-columns: 1fr; }
    .mc01-data-grid { grid-template-columns: 1fr; }
    .mc01-data-grid .mc01-field { grid-template-columns: 1fr; }
    .mc01-field-span-2,
    .mc01-field-span-3 { grid-column: auto; }
    .mc01-panel-grid, .mc01-form-grid, .mc01-vendor-grid, .mc01-summary { grid-template-columns: 1fr; }
    .mc01-grid-head, .mc01-footer { flex-direction: column; align-items: stretch; }
    .mc01-status-grid { grid-template-columns: 1fr; }
    .mc01-status-totals-row { grid-template-columns: 1fr; }
    .mc01-status-dl-horizontal { grid-template-columns: max-content 1fr; }
}
