/**
 * OM Portal v2 — Refinamiento visual premium (COMPLETO)
 * Paleta OM oficial · Tipografía Inter · Stripe/Linear/Attio
 * NO modifica lógica · sobrescribe om-portal.css
 */

:root {
    --v2-bg:#fafafa; --v2-surf:#ffffff; --v2-surf-soft:#f8fafc; --v2-surf-hover:#f1f5f9;
    --v2-border:#e8ebf0; --v2-border-muted:#f1f5f9; --v2-border-strong:#dcdee3; --v2-border-focus:#c8a8f0;
    --v2-text:#0f172a; --v2-text-m2:#475569; --v2-text-m1:#64748b; --v2-text-muted:#94a3b8;
    --v2-primary:#7835E8; --v2-primary-deep:#5C1F9E; --v2-primary-dark:#3f2161;
    --v2-primary-soft:#f7f4fc; --v2-primary-border:#ede8f3; --v2-primary-light:#c5bbd1;
    --v2-success:#10b981; --v2-success-soft:#ecfdf5; --v2-success-text:#046438; --v2-success-border:#bbf3db;
    --v2-warn:#f59e0b; --v2-warn-soft:#fffbeb; --v2-warn-border:#fde68a; --v2-warn-text:#92400e;
    --v2-err:#ef4444; --v2-err-soft:#fef2f2; --v2-err-text:#9c2328;
    --v2-r6:6px; --v2-r7:7px; --v2-r8:8px; --v2-r10:10px; --v2-r12:12px; --v2-r999:999px;
    --v2-sh-sm:0 1px 2px rgba(15,23,42,0.04);
    --v2-sh:0 1px 2px rgba(15,23,42,0.04),0 1px 3px rgba(15,23,42,0.04);
    --v2-sh-md:0 2px 4px rgba(15,23,42,0.04),0 4px 12px rgba(15,23,42,0.06);
    --v2-sh-lg:0 8px 24px rgba(15,23,42,0.08),0 2px 8px rgba(15,23,42,0.04);
}

body {
    font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: var(--v2-text); background: var(--v2-bg);
    font-feature-settings: 'cv11', 'ss01', 'ss03';
}

.omp-kpi-num, .omp-stat-num, .kpi-num, .tbl-numeric, .com-big, .com-v,
.foot-r, .it-num, .omc-comision-monto, .omc-cotiz-kpi-value,
.omc-detalle-total-value, .omc-repetir-total {
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.01em;
}

.omp-app { background: var(--v2-bg) !important; }

/* SIDEBAR */
.omp-sidebar, .omp-app-aside {
    background: var(--v2-surf) !important;
    border-right: 1px solid var(--v2-border) !important;
    padding: 20px 14px !important;
}
.omp-sidebar-brand, .omp-app-brand {
    padding: 0 8px 20px !important;
    margin-bottom: 16px !important;
    border-bottom: 1px solid var(--v2-border-muted) !important;
}
.omp-nav-section, .omp-nav-section-label, .omp-sidebar-section {
    font-size: 10px !important; font-weight: 600 !important;
    text-transform: uppercase !important; letter-spacing: 0.08em !important;
    color: var(--v2-text-muted) !important;
    padding: 14px 8px 7px !important; margin: 0 !important;
}
.omp-nav-item {
    display: flex !important; align-items: center !important; gap: 10px !important;
    padding: 7px 9px !important; font-size: 13px !important;
    color: var(--v2-text-m2) !important; border-radius: var(--v2-r6) !important;
    margin: 1px 0 !important; font-weight: 500 !important;
    text-decoration: none !important; transition: all 0.15s !important;
}
.omp-nav-item:hover { background: var(--v2-surf-hover) !important; color: var(--v2-text) !important; }
.omp-nav-item.is-active {
    background: var(--v2-primary-soft) !important;
    color: var(--v2-primary) !important; font-weight: 600 !important;
}
.omp-nav-item.is-active svg { color: var(--v2-primary) !important; }
.omp-nav-item svg { flex-shrink: 0; color: var(--v2-text-m1); }
.omp-nav-item-badge {
    margin-left: auto !important; font-size: 9px !important; font-weight: 600 !important;
    letter-spacing: 0.04em !important; text-transform: uppercase !important;
    color: var(--v2-text-muted) !important; background: var(--v2-surf-hover) !important;
    padding: 2px 6px !important; border-radius: var(--v2-r6) !important;
}
.omp-nav-alert-badge {
    background: var(--v2-err) !important; color: #fff !important;
    border-radius: var(--v2-r999) !important; font-size: 10px !important;
    font-weight: 700 !important; min-width: 19px !important; height: 19px !important;
    padding: 0 6px !important;
}

/* TOPBAR + MAIN */
.omp-topbar, .omp-app-topbar {
    height: 55px !important; background: var(--v2-surf) !important;
    border-bottom: 1px solid var(--v2-border) !important; padding: 0 32px !important;
}
.omp-app-main { padding: 32px 32px 48px !important; background: var(--v2-bg) !important; }
.omp-section-head { margin-bottom: 16px !important; }
.omp-section-title {
    font-size: 14px !important; font-weight: 600 !important;
    color: var(--v2-text) !important; letter-spacing: -0.01em !important; margin: 0 !important;
}
.omp-app-main h1, .omp-page-title, .omc-page-wrap h1 {
    font-size: 23px !important; font-weight: 700 !important;
    letter-spacing: -0.02em !important; color: var(--v2-text) !important;
    margin: 0 0 4px !important;
}

/* BOTONES */
.omp-btn, .omc-btn, .omps-btn, .omfly-btn, .omcat-btn, .btn-primary {
    font-family: inherit !important; font-size: 13px !important;
    font-weight: 550 !important; padding: 9px 14px !important;
    border-radius: var(--v2-r7) !important; border: 1px solid !important;
    cursor: pointer; display: inline-flex; align-items: center; gap: 6px;
    transition: all 0.15s !important; line-height: 1.2;
}
.omp-btn-primary, .omc-btn-primary, .omps-btn-primary, .omfly-btn-primary,
.btn-primary, .omc-btn-new-libre, .omfly-btn-new {
    background: var(--v2-primary) !important; color: #fff !important;
    border-color: var(--v2-primary) !important;
}
.omp-btn-primary:hover, .omc-btn-primary:hover, .omfly-btn-primary:hover,
.omc-btn-new-libre:hover, .omfly-btn-new:hover {
    background: var(--v2-primary-deep) !important;
    border-color: var(--v2-primary-deep) !important;
    box-shadow: var(--v2-sh) !important;
}
.omp-btn-secondary, .omc-btn-ghost, .omfly-btn-ghost {
    background: var(--v2-surf) !important; color: var(--v2-text) !important;
    border-color: var(--v2-border) !important;
}
.omp-btn-secondary:hover, .omc-btn-ghost:hover, .omfly-btn-ghost:hover {
    border-color: var(--v2-border-strong) !important;
    background: var(--v2-surf-soft) !important;
}
.omc-btn-whatsapp { background: #25D366 !important; color: #fff !important; border-color: #25D366 !important; }
.omc-btn-whatsapp:hover { background: #1FAD55 !important; border-color: #1FAD55 !important; }
.omc-btn-danger, .omfly-btn-danger {
    background: var(--v2-surf) !important; color: var(--v2-err) !important;
    border-color: var(--v2-err-soft) !important;
}
.omc-btn-danger:hover, .omfly-btn-danger:hover {
    background: var(--v2-err-soft) !important; border-color: var(--v2-err) !important;
}
.omc-btn-small, .omfly-btn-sm { padding: 6px 10px !important; font-size: 12px !important; }
.omc-btn-export {
    background: var(--v2-surf) !important; color: var(--v2-text-m2) !important;
    border: 1px solid var(--v2-border) !important;
    padding: 9px 14px !important; font-size: 13px !important;
    border-radius: var(--v2-r7) !important;
}
.omc-btn-export:hover { border-color: var(--v2-border-strong) !important; background: var(--v2-surf-soft) !important; }

/* CARDS */
.omc-card, .omp-card, .omps-card {
    background: var(--v2-surf) !important;
    border: 1px solid var(--v2-border) !important;
    border-radius: var(--v2-r10) !important;
    box-shadow: none !important; overflow: hidden;
}
.omc-card-padded { padding: 20px 24px !important; }
.omc-card-title {
    font-size: 14px !important; font-weight: 600 !important;
    color: var(--v2-text) !important;
}
.omc-section-h3 {
    font-size: 13px !important; font-weight: 600 !important;
    color: var(--v2-text) !important; letter-spacing: -0.005em !important;
    margin-top: 0 !important; margin-bottom: 14px !important;
}

/* KPIs PANEL */
.omps-grid {
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 14px !important; margin-bottom: 32px !important;
}
.omps-card { padding: 20px !important; transition: all 0.15s; }
.omps-card:hover { border-color: var(--v2-border-strong) !important; box-shadow: var(--v2-sh) !important; }
.omps-label {
    font-size: 10px !important; text-transform: uppercase !important;
    letter-spacing: 0.06em !important; color: var(--v2-text-m1) !important;
    font-weight: 600 !important; margin-bottom: 10px !important;
}
.omps-big {
    font-size: 28px !important; font-weight: 700 !important;
    letter-spacing: -0.02em !important; line-height: 1.1 !important;
    color: var(--v2-text) !important;
}
.omps-sub {
    font-size: 11px !important; margin-top: 8px !important;
    color: var(--v2-text-m1) !important; opacity: 1 !important;
}
.omps-card-primary {
    background: linear-gradient(135deg, var(--v2-primary), var(--v2-primary-deep)) !important;
    border-color: var(--v2-primary) !important; color: #fff !important;
}
.omps-card-primary .omps-label { color: rgba(255,255,255,0.85) !important; }
.omps-card-primary .omps-big { color: #fff !important; }
.omps-card-primary .omps-sub { color: rgba(255,255,255,0.8) !important; }

/* KPIs COTIZACIONES */
.omc-cotiz-kpis {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 14px !important; margin-bottom: 24px !important;
}
.omc-cotiz-kpi {
    background: var(--v2-surf) !important;
    border: 1px solid var(--v2-border) !important;
    border-radius: var(--v2-r10) !important;
    padding: 20px !important; transition: all 0.15s;
}
.omc-cotiz-kpi:hover { border-color: var(--v2-border-strong) !important; box-shadow: var(--v2-sh) !important; }
.omc-cotiz-kpi-label {
    font-size: 10px !important; text-transform: uppercase !important;
    letter-spacing: 0.06em !important; color: var(--v2-text-m1) !important;
    font-weight: 600 !important; margin-bottom: 10px !important;
}
.omc-cotiz-kpi-value {
    font-size: 28px !important; font-weight: 700 !important;
    letter-spacing: -0.02em !important; color: var(--v2-text) !important;
    line-height: 1.1 !important;
}

/* TABLAS */
table { border-collapse: collapse !important; }
th {
    text-align: left !important; font-size: 10px !important;
    font-weight: 700 !important; text-transform: uppercase !important;
    letter-spacing: 0.06em !important; color: var(--v2-text-m1) !important;
    padding: 12px 16px 10px !important;
    border-bottom: 1px solid var(--v2-border-muted) !important;
    background: transparent !important;
}
td {
    padding: 14px 16px !important;
    border-bottom: 1px solid var(--v2-border-muted) !important;
    font-size: 13px !important; vertical-align: middle !important;
    color: var(--v2-text-m2);
}
tr:last-child td { border-bottom: 0 !important; }
tr:hover td { background: var(--v2-surf-soft) !important; }
.omc-folio, .omc-folio-link, .tbl-folio {
    font-family: ui-monospace, "SF Mono", Menlo, monospace !important;
    font-size: 12px !important; font-weight: 600 !important;
    color: var(--v2-text) !important;
}
.omc-folio-link:hover { color: var(--v2-primary) !important; }
.omc-row-link { color: var(--v2-text-m2) !important; transition: color 0.15s !important; }
.omc-row-link:hover { color: var(--v2-primary) !important; }
.omc-ver-btn {
    background: var(--v2-primary-soft) !important;
    color: var(--v2-primary) !important;
    border: 1px solid var(--v2-primary-border) !important;
    padding: 5px 10px !important; font-size: 11px !important;
    font-weight: 600 !important; border-radius: var(--v2-r6) !important;
}
.omc-ver-btn:hover { background: var(--v2-primary) !important; color: #fff !important; }
.omc-cotiz-table-card { overflow: visible !important; }

/* BADGES */
.omc-status, .omc-badge, .badg, .omc-tag {
    padding: 3px 9px !important; border-radius: var(--v2-r999) !important;
    font-size: 11px !important; font-weight: 550 !important;
    display: inline-flex; align-items: center; gap: 5px;
    text-transform: none !important; letter-spacing: 0 !important;
    border: none !important;
}
.omc-status-activa, .omc-status-pagada, .omc-status-ok {
    background: var(--v2-success-soft) !important; color: var(--v2-success-text) !important;
}
.omc-status-vencida, .omc-status-rejected {
    background: var(--v2-err-soft) !important; color: var(--v2-err-text) !important;
}
.omc-status-cancelada, .omc-status-missing {
    background: var(--v2-surf-hover) !important; color: var(--v2-text-m2) !important;
}
.omc-status-pending, .omc-badge-warn {
    background: var(--v2-warn-soft) !important; color: var(--v2-warn-text) !important;
}
.omc-status-dot {
    width: 6px !important; height: 6px !important;
    border-radius: 50% !important; background: currentColor !important;
    display: inline-block !important;
}
.omc-tag-required {
    background: var(--v2-primary-soft) !important;
    color: var(--v2-primary-deep) !important; font-size: 10px !important;
    text-transform: uppercase !important; letter-spacing: 0.04em !important;
    font-weight: 600 !important;
}
.omc-cotiz-pill {
    padding: 4px 10px !important; border-radius: var(--v2-r999) !important;
    font-size: 11px !important; font-weight: 600 !important;
    display: inline-flex !important; align-items: center !important; gap: 5px !important;
}
.omc-cotiz-dot { width: 6px !important; height: 6px !important; border-radius: 50% !important; }

/* FILTROS */
.omc-cotiz-filters {
    display: flex !important; gap: 10px !important;
    padding: 14px 20px !important;
    border-bottom: 1px solid var(--v2-border-muted) !important;
    flex-wrap: wrap !important; align-items: center !important;
}
.omc-filter-input, .omc-search,
input[type="text"].omc-search-input, input[type="search"] {
    padding: 8px 12px !important; border: 1px solid var(--v2-border) !important;
    border-radius: var(--v2-r999) !important; font-size: 12px !important;
    font-family: inherit; outline: none; transition: all 0.15s !important;
    background: var(--v2-surf) !important;
}
.omc-filter-input:focus, .omc-search:focus, input[type="search"]:focus {
    border-color: var(--v2-primary) !important;
    box-shadow: 0 0 0 3px rgba(120, 53, 232, 0.1) !important;
}
.omc-filter-select {
    padding: 7px 30px 7px 12px !important;
    border: 1px solid var(--v2-border) !important;
    border-radius: var(--v2-r7) !important;
    font-size: 12px !important; font-family: inherit !important;
    background: var(--v2-surf) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%2364748b' d='M0 0l5 6 5-6z'/></svg>") no-repeat right 10px center !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    cursor: pointer !important;
}

/* TIMELINE */
.omc-timeline-title { font-size: 13.5px !important; font-weight: 600 !important; color: var(--v2-text) !important; }
.omc-timeline-desc { font-size: 12.5px !important; color: var(--v2-text-m1) !important; }
.omc-timeline-meta { font-size: 11px !important; color: var(--v2-text-muted) !important; }
.omc-timeline-marker { box-shadow: 0 0 0 1px var(--v2-border) !important; }

/* INPUTS */
input[type="text"], input[type="email"], input[type="tel"],
input[type="number"], input[type="date"], input[type="url"],
input[type="password"], select, textarea,
.omc-input, .omc-textarea {
    font-family: inherit !important; font-size: 13px !important;
    padding: 9px 12px !important;
    border: 1px solid var(--v2-border) !important;
    border-radius: var(--v2-r6) !important;
    background: var(--v2-surf) !important; color: var(--v2-text) !important;
    transition: all 0.15s !important; line-height: 1.4;
}
input[type="text"]:focus, input[type="email"]:focus, input[type="tel"]:focus,
input[type="number"]:focus, input[type="date"]:focus, input[type="url"]:focus,
input[type="password"]:focus, select:focus, textarea:focus,
.omc-input:focus, .omc-textarea:focus {
    outline: none !important; border-color: var(--v2-primary) !important;
    box-shadow: 0 0 0 3px rgba(120, 53, 232, 0.1) !important;
}
label {
    font-size: 12px !important; font-weight: 600 !important;
    color: var(--v2-text-m2) !important;
}

/* DETALLE DE COTIZACIÓN */
.omc-back-link {
    font-size: 12px !important; color: var(--v2-text-m1) !important;
    font-weight: 500 !important; text-decoration: none !important;
    display: inline-flex !important; align-items: center !important; gap: 4px !important;
}
.omc-back-link:hover { color: var(--v2-primary) !important; }
.omc-folio-line {
    font-family: ui-monospace, monospace !important;
    font-size: 11px !important; color: var(--v2-text-m1) !important;
    font-weight: 600 !important; letter-spacing: 0.02em !important;
    margin-bottom: 6px !important;
}
.omc-detalle-header h1 {
    font-size: 22px !important; font-weight: 700 !important;
    letter-spacing: -0.02em !important; color: var(--v2-text) !important;
    margin: 0 0 4px !important;
}
.omc-detalle-actions {
    display: flex !important; gap: 8px !important;
    flex-wrap: wrap !important; margin-top: 16px !important;
}
.omc-detalle-grid {
    display: grid !important;
    grid-template-columns: 1fr 380px !important;
    gap: 24px !important; align-items: start !important;
}
@media (max-width: 1100px) { .omc-detalle-grid { grid-template-columns: 1fr !important; } }

.omc-comision-card {
    background: linear-gradient(155deg, var(--v2-success-soft), #fff) !important;
    border-color: var(--v2-success-border) !important;
    padding: 22px 24px !important;
}
.omc-comision-head {
    display: flex !important; justify-content: space-between !important;
    align-items: flex-start !important; gap: 16px !important;
    margin-bottom: 16px !important;
}
.omc-comision-eyebrow {
    font-size: 10px !important; text-transform: uppercase !important;
    letter-spacing: 0.08em !important; color: var(--v2-success-text) !important;
    font-weight: 700 !important; margin-bottom: 4px !important;
}
.omc-comision-tipo {
    font-size: 13px !important; font-weight: 600 !important;
    color: #18181b !important;
}
.omc-comision-monto {
    font-size: 30px !important; font-weight: 800 !important;
    color: #047857 !important; letter-spacing: -0.02em !important;
    line-height: 1 !important;
}
.omc-comision-row {
    display: flex !important; padding: 8px 0 !important;
    font-size: 12.5px !important; color: var(--v2-text-m1) !important;
}
.omc-comision-row > :first-child { flex: 1 !important; }
.omc-comision-row > :last-child { font-weight: 600 !important; color: var(--v2-text) !important; }
.omc-comision-row-total {
    border-top: 1px solid var(--v2-success-border) !important;
    padding-top: 12px !important; margin-top: 4px !important;
    font-size: 13px !important; font-weight: 600 !important;
}
.omc-comision-row-total > :last-child { font-size: 15px !important; color: #047857 !important; }
.omc-comision-note {
    font-size: 10.5px !important; color: var(--v2-text-m1) !important;
    line-height: 1.4 !important;
    margin-top: 12px !important; padding-top: 12px !important;
    border-top: 1px dashed var(--v2-success-border) !important;
}

.omc-items-table { width: 100% !important; border-collapse: collapse !important; }
.omc-items-table th {
    background: var(--v2-surf-soft) !important;
    padding: 10px 14px !important; font-size: 10px !important;
}
.omc-items-table td {
    padding: 14px !important;
    border-bottom: 1px solid var(--v2-border-muted) !important;
}

.omc-detalle-total {
    background: var(--v2-surf-soft) !important;
    border: 1px solid var(--v2-border) !important;
    border-radius: var(--v2-r8) !important;
    padding: 14px 20px !important;
    display: flex !important; justify-content: space-between !important;
    align-items: center !important; margin-top: 12px !important;
}
.omc-detalle-total-label {
    font-size: 13px !important; font-weight: 600 !important;
    color: var(--v2-text-m2) !important;
}
.omc-detalle-total-value {
    font-size: 20px !important; font-weight: 800 !important;
    color: var(--v2-primary) !important; letter-spacing: -0.02em !important;
}

.omc-dl { display: grid !important; gap: 10px !important; }
.omc-dl > div {
    display: flex !important; justify-content: space-between !important;
    padding: 8px 0 !important;
    border-bottom: 1px solid var(--v2-border-muted) !important;
    font-size: 13px !important;
}
.omc-dl > div:last-child { border-bottom: 0 !important; }
.omc-dl dt, .omc-dl > div > :first-child {
    font-size: 10.5px !important; text-transform: uppercase !important;
    letter-spacing: 0.06em !important; color: var(--v2-text-m1) !important;
    font-weight: 600 !important;
}
.omc-dl dd, .omc-dl > div > :last-child {
    font-weight: 600 !important; color: var(--v2-text) !important;
    text-align: right !important; margin: 0 !important;
}

/* MODAL REPETIR */
.omc-repetir-backdrop {
    background: rgba(15, 23, 42, 0.5) !important;
    backdrop-filter: blur(4px) !important;
}
.omc-repetir-modal {
    background: var(--v2-surf) !important;
    border-radius: var(--v2-r12) !important;
    box-shadow: var(--v2-sh-lg) !important;
    border: 1px solid var(--v2-border) !important;
}
.omc-repetir-content { padding: 24px 28px !important; }
.omc-repetir-field input,
.omc-repetir-field select,
.omc-repetir-field textarea { width: 100% !important; }
.omc-repetir-resumen {
    background: var(--v2-primary-soft) !important;
    border: 1px solid var(--v2-primary-border) !important;
    border-radius: var(--v2-r8) !important; padding: 14px 18px !important;
}
.omc-repetir-total {
    font-size: 20px !important; font-weight: 800 !important;
    color: var(--v2-primary) !important; letter-spacing: -0.02em !important;
}
.omc-repetir-actions {
    display: flex !important; gap: 10px !important;
    justify-content: flex-end !important;
    margin-top: 20px !important; padding-top: 20px !important;
    border-top: 1px solid var(--v2-border-muted) !important;
}

/* TOAST */
.omc-toast {
    background: var(--v2-text) !important; color: #fff !important;
    border-radius: var(--v2-r8) !important;
    font-size: 13px !important; font-weight: 600 !important;
    padding: 12px 22px !important; box-shadow: var(--v2-sh-lg) !important;
}

/* MI AGENCIA — DOCS */
.omc-docs-intro {
    font-size: 13px !important; color: var(--v2-text-m1) !important;
    line-height: 1.55 !important; margin-bottom: 20px !important;
}
.omc-docs-table { width: 100% !important; border-collapse: collapse !important; }
.omc-doc-row {
    display: grid !important;
    grid-template-columns: 48px 1fr auto auto !important;
    gap: 16px !important; align-items: center !important;
    padding: 16px 0 !important;
    border-bottom: 1px solid var(--v2-border-muted) !important;
}
.omc-doc-row:last-child { border-bottom: 0 !important; }
.omc-doc-icon {
    width: 40px !important; height: 40px !important;
    background: var(--v2-primary-soft) !important;
    color: var(--v2-primary) !important;
    border-radius: var(--v2-r8) !important;
    display: grid !important; place-items: center !important;
}
.omc-doc-name {
    font-size: 14px !important; font-weight: 600 !important;
    color: var(--v2-text) !important; margin-bottom: 2px !important;
}
.omc-doc-hint { font-size: 12px !important; color: var(--v2-text-m1) !important; }
.omc-doc-notas {
    font-size: 11px !important; color: var(--v2-warn-text) !important;
    background: var(--v2-warn-soft) !important;
    padding: 4px 8px !important; border-radius: var(--v2-r6) !important;
    display: inline-block !important; margin-top: 4px !important;
}
.omc-status-meta { font-size: 11px !important; color: var(--v2-text-muted) !important; }
.omc-doc-actions { display: flex !important; gap: 6px !important; }

/* INFO GRID */
.omc-info-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
    gap: 14px !important;
}
.omc-info-item {
    background: var(--v2-surf-soft) !important;
    border: 1px solid var(--v2-border-muted) !important;
    border-radius: var(--v2-r8) !important; padding: 14px 16px !important;
}
.omc-info-item-wide { grid-column: 1 / -1 !important; }
.omc-info-item > :first-child {
    font-size: 10px !important; text-transform: uppercase !important;
    letter-spacing: 0.06em !important; color: var(--v2-text-m1) !important;
    font-weight: 600 !important; margin-bottom: 4px !important;
}
.omc-info-item > :last-child {
    font-size: 14px !important; font-weight: 600 !important;
    color: var(--v2-text) !important;
}

/* CARDS PANEL */
.omc-card-row {
    display: flex !important; align-items: center !important; gap: 16px !important;
    padding: 18px 22px !important;
}
.omc-card-icon-lg {
    width: 44px !important; height: 44px !important;
    background: var(--v2-primary-soft) !important;
    color: var(--v2-primary) !important;
    border-radius: var(--v2-r10) !important;
    display: grid !important; place-items: center !important; flex-shrink: 0 !important;
}
.omc-card-body { flex: 1 !important; min-width: 0 !important; }
.omc-card-title {
    font-size: 14px !important; font-weight: 600 !important;
    color: var(--v2-text) !important; margin-bottom: 2px !important;
}
.omc-card-meta { font-size: 12px !important; color: var(--v2-text-m1) !important; }
.omc-card-arrow { color: var(--v2-text-muted) !important; }

/* MI EQUIPO */
.omc-team-table { width: 100% !important; border-collapse: collapse !important; }
.omc-team-row {
    display: grid !important;
    grid-template-columns: 44px 1fr auto !important;
    gap: 14px !important; align-items: center !important;
    padding: 14px 0 !important;
    border-bottom: 1px solid var(--v2-border-muted) !important;
}
.omc-team-row:last-child { border-bottom: 0 !important; }
.omc-team-avatar {
    width: 36px !important; height: 36px !important;
    border-radius: 999px !important;
    background: linear-gradient(135deg, var(--v2-primary), var(--v2-primary-deep)) !important;
    color: #fff !important; font-weight: 700 !important;
    font-size: 14px !important;
    display: grid !important; place-items: center !important; flex-shrink: 0 !important;
}
.omc-team-name {
    font-size: 13.5px !important; font-weight: 600 !important;
    color: var(--v2-text) !important;
}
.omc-team-email { font-size: 12px !important; color: var(--v2-text-m1) !important; }
.omc-team-me {
    background: var(--v2-primary-soft) !important;
    color: var(--v2-primary) !important; font-size: 10px !important;
    font-weight: 700 !important; text-transform: uppercase !important;
    letter-spacing: 0.06em !important; padding: 2px 7px !important;
    border-radius: var(--v2-r6) !important; margin-left: 6px !important;
}
.omc-team-foot {
    font-size: 12px !important; color: var(--v2-text-m1) !important;
    margin-top: 12px !important; padding-top: 12px !important;
    border-top: 1px solid var(--v2-border-muted) !important;
}

/* STATS PANEL */
.omps-status-list .omps-status-item { font-size: 12px !important; color: var(--v2-text-m2) !important; }
.omps-status-item strong { color: var(--v2-text) !important; font-weight: 600 !important; }
.omps-top-list li {
    padding: 12px 0 !important;
    border-bottom: 1px solid var(--v2-border-muted) !important;
}
.omps-top-rank {
    font-size: 15px !important; font-weight: 800 !important;
    color: var(--v2-primary) !important;
    font-variant-numeric: tabular-nums;
}
.omps-top-title {
    font-size: 13.2px !important; font-weight: 550 !important;
    color: var(--v2-text) !important;
}
.omps-top-title:hover { color: var(--v2-primary) !important; }
.omps-top-meta { font-size: 11px !important; color: var(--v2-text-m1) !important; }

/* CATÁLOGO */
.omcat-card {
    background: var(--v2-surf) !important;
    border: 1px solid var(--v2-border) !important;
    border-radius: var(--v2-r10) !important;
    overflow: hidden; transition: all 0.2s !important;
}
.omcat-card:hover {
    border-color: var(--v2-primary-border) !important;
    box-shadow: var(--v2-sh-md) !important;
    transform: translateY(-1px);
}
.omcat-card-title {
    font-size: 14px !important; font-weight: 600 !important;
    color: var(--v2-text) !important; line-height: 1.35 !important;
}
.omcat-card-tipo {
    background: rgba(255,255,255,0.95) !important;
    color: var(--v2-primary-deep) !important;
    font-size: 10px !important; font-weight: 700 !important;
    letter-spacing: 0.06em !important;
    padding: 4px 10px !important; border-radius: var(--v2-r6) !important;
}
.omcat-flyer-btn {
    background: var(--v2-primary-soft) !important;
    color: var(--v2-primary) !important;
    border-color: var(--v2-primary-border) !important;
    font-size: 11px !important; font-weight: 600 !important;
}
.omcat-flyer-btn:hover {
    background: var(--v2-primary) !important;
    color: #fff !important; border-color: var(--v2-primary) !important;
}

/* FLYERS */
.omfly-container { padding: 0 !important; }
.omfly-intro {
    font-size: 13px !important; color: var(--v2-text-m1) !important;
    line-height: 1.55 !important; margin-bottom: 20px !important;
}
.omfly-grid, .omfly-grid-2 { display: grid !important; gap: 16px !important; }
.omfly-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important; }
.omfly-grid-2 { grid-template-columns: 1fr 1fr !important; }
.omfly-grid-3 { display: grid !important; grid-template-columns: 1fr 1fr 1fr !important; gap: 12px !important; }

.omfly-card {
    background: var(--v2-surf) !important;
    border: 1px solid var(--v2-border) !important;
    border-radius: var(--v2-r10) !important;
    overflow: hidden !important; transition: all 0.2s !important;
}
.omfly-card:hover {
    border-color: var(--v2-primary-border) !important;
    box-shadow: var(--v2-sh-md) !important;
    transform: translateY(-1px);
}
.omfly-card-body { padding: 14px 16px !important; }
.omfly-card-title {
    font-size: 14px !important; font-weight: 600 !important;
    color: var(--v2-text) !important;
    margin-bottom: 4px !important; line-height: 1.35 !important;
}
.omfly-card-meta {
    font-size: 11.5px !important; color: var(--v2-text-m1) !important;
    margin-bottom: 8px !important;
}
.omfly-card-precio { font-size: 14px !important; font-weight: 700 !important; }
.omfly-card-precio strong {
    color: var(--v2-primary) !important;
    font-variant-numeric: tabular-nums;
}
.omfly-card-tipo {
    background: rgba(255,255,255,0.95) !important;
    color: var(--v2-primary-deep) !important;
    font-size: 10px !important; font-weight: 700 !important;
    letter-spacing: 0.06em !important;
    padding: 4px 10px !important; border-radius: var(--v2-r6) !important;
}
.omfly-card-actions {
    display: flex !important; gap: 6px !important;
    padding: 0 14px 14px !important; flex-wrap: wrap !important;
}
.omfly-card-placeholder {
    background: var(--v2-surf-hover) !important;
    color: var(--v2-text-muted) !important;
}

/* EDITOR FLYERS */
.omfly-editor {
    background: var(--v2-surf) !important;
    border: 1px solid var(--v2-border) !important;
    border-radius: var(--v2-r10) !important;
    padding: 0 !important; overflow: hidden;
}
.omfly-editor-head {
    padding: 18px 24px !important;
    border-bottom: 1px solid var(--v2-border-muted) !important;
    display: flex !important; justify-content: space-between !important;
    align-items: center !important;
}
.omfly-editor-grid {
    display: grid !important;
    grid-template-columns: 1fr 460px !important;
    gap: 0 !important;
}
@media (max-width: 1100px) {
    .omfly-editor-grid { grid-template-columns: 1fr !important; }
}
.omfly-form-col {
    padding: 22px 24px !important;
    border-right: 1px solid var(--v2-border-muted) !important;
}
.omfly-field { margin-bottom: 16px !important; }
.omfly-field-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
}
.omfly-field label { display: block !important; margin-bottom: 6px !important; }
.omfly-counter {
    font-size: 10.5px !important; color: var(--v2-text-muted) !important;
    font-weight: 600 !important; margin-top: 4px !important;
    font-variant-numeric: tabular-nums;
}
.omfly-counter.is-warn { color: var(--v2-warn) !important; }
.omfly-counter.is-err { color: var(--v2-err) !important; }
.omfly-helper {
    font-size: 11px !important; color: var(--v2-text-m1) !important;
    margin-top: 4px !important; line-height: 1.45 !important;
}
.omfly-img-row {
    display: flex !important; align-items: center !important; gap: 10px !important;
}
.omfly-img-preview {
    width: 60px !important; height: 60px !important;
    border-radius: var(--v2-r8) !important;
    border: 1px solid var(--v2-border) !important;
    background: var(--v2-surf-soft) !important;
    object-fit: cover !important;
}
.omfly-img-pick {
    padding: 8px 12px !important;
    background: var(--v2-surf-soft) !important;
    border: 1px solid var(--v2-border) !important;
    border-radius: var(--v2-r6) !important;
    font-size: 12px !important; font-weight: 600 !important;
    color: var(--v2-text-m2) !important; cursor: pointer !important;
}
.omfly-img-pick:hover {
    border-color: var(--v2-primary) !important;
    color: var(--v2-primary) !important;
    background: var(--v2-primary-soft) !important;
}
.omfly-editor-actions {
    display: flex !important; gap: 8px !important;
    justify-content: flex-end !important;
    padding: 16px 24px !important;
    background: var(--v2-surf-soft) !important;
    border-top: 1px solid var(--v2-border-muted) !important;
}
.omfly-back {
    font-size: 12px !important; color: var(--v2-text-m1) !important;
    font-weight: 500 !important;
}
.omfly-back:hover { color: var(--v2-primary) !important; }
.omfly-empty {
    text-align: center !important;
    padding: 60px 20px !important;
    color: var(--v2-text-m1) !important;
}
.omfly-empty-icon {
    width: 56px !important; height: 56px !important;
    margin: 0 auto 16px !important;
    background: var(--v2-primary-soft) !important;
    color: var(--v2-primary) !important;
    border-radius: 50% !important;
    display: grid !important; place-items: center !important;
}

/* EMPTY STATES */
.omc-empty-state { text-align: center !important; padding: 60px 20px !important; }
.omc-empty-state > * { color: var(--v2-text-m1) !important; }

/* USER CARD SIDEBAR */
.omp-sidebar-footer, .omp-user-card, .aside-user-card {
    margin-top: 24px !important; padding: 10px !important;
    background: var(--v2-surf-soft) !important;
    border: 1px solid var(--v2-border-muted) !important;
    border-radius: var(--v2-r8) !important;
}

a { transition: color 0.15s; }
button { transition: all 0.15s; }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
    background: var(--v2-border-strong);
    border-radius: 5px;
    border: 2px solid var(--v2-bg);
}
::-webkit-scrollbar-thumb:hover { background: var(--v2-text-muted); }

::selection {
    background: var(--v2-primary-soft);
    color: var(--v2-primary-deep);
}

.omc-fecha-editor {
    display: inline-flex !important; align-items: center !important; gap: 6px !important;
    padding: 6px 10px !important;
    background: var(--v2-surf-soft) !important;
    border: 1px solid var(--v2-border) !important;
    border-radius: var(--v2-r6) !important;
    font-size: 12px !important; font-weight: 500 !important;
    cursor: pointer !important;
}
.omc-fecha-editor:hover {
    border-color: var(--v2-primary) !important;
    color: var(--v2-primary) !important;
}

.omc-cotiz-container { padding: 0 !important; }
