/* ═══ MI NEGOCIO v3 — Design System Compliant ═══ */
/* Uses: .cs cards, var(--glass/glass2/sh/r2/brd2), backdrop-filter */

/* Kill old tab system from docs_oficiales chain */
.neg-tabs{display:none!important}
.neg-tab-content{display:block!important}

/* ── Page container ── */
.mn{max-width:840px;margin:0 auto;display:flex;flex-direction:column;gap:16px;padding-bottom:48px}

/* ══════════════════════════════════════
   1. BUSINESS IDENTITY STRIP
   ══════════════════════════════════════ */
.mn-id{
    display:flex;align-items:center;gap:16px;flex-wrap:wrap;
    background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid var(--brd2);border-radius:var(--r2);
    padding:16px 20px;box-shadow:var(--sh);
    transition:transform .2s,box-shadow .2s
}
.mn-id:hover{transform:translateY(-1px);box-shadow:var(--sh2)}
.mn-id-left{flex:1;min-width:200px}
.mn-id-name{font-size:16px;font-weight:700;letter-spacing:-.02em;color:var(--t1)}
.mn-id-meta{font-size:11px;color:var(--t3);margin-top:1px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.mn-id-chips{display:flex;gap:5px;flex-wrap:wrap;margin-top:6px}
.mn-chip{
    display:inline-flex;align-items:center;gap:3px;
    padding:3px 8px;background:var(--glass2);
    border:1px solid var(--brd);border-radius:8px;
    font-size:10px;color:var(--t2);font-weight:500;
    transition:all .15s
}
.mn-chip:hover{border-color:var(--brd2);color:var(--t1)}
.mn-tipo{
    padding:3px 10px;border-radius:8px;
    font-size:10px;font-weight:700;letter-spacing:.03em;text-transform:uppercase
}
.mn-tipo-auto{background:var(--success-subtle);color:var(--grn);border:1px solid var(--success-border)}
.mn-tipo-sl{background:var(--primary-a12);color:var(--acc2);border:1px solid var(--primary-a18)}

.mn-id-right{display:flex;flex-direction:column;gap:6px;align-items:flex-end}
.mn-gest{
    display:flex;align-items:center;gap:8px;
    padding:8px 12px;background:var(--glass2);
    border:1px solid var(--brd);border-radius:12px;
    transition:all .15s;cursor:default
}
.mn-gest:hover{border-color:var(--primary-a25);background:var(--primary-a6)}
.mn-gest-av{
    width:30px;height:30px;border-radius:8px;
    background:linear-gradient(135deg,var(--acc),var(--primary-active));
    color:var(--text-on-primary);display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:12px;flex-shrink:0
}
.mn-gest-name{font-size:11px;font-weight:600;color:var(--t1)}
.mn-gest-sub{font-size:10px;color:var(--t3)}
.mn-iban{font-size:10px;color:var(--t3);font-family:'SF Mono',Consolas,monospace;letter-spacing:.02em}

/* ══════════════════════════════════════
   2. ALERT BANNER
   ══════════════════════════════════════ */
.mn-alert{
    display:flex;align-items:center;gap:12px;
    padding:12px 16px;border-radius:14px;
    backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
    font-size:12px;line-height:1.4;
    animation:mn-slideIn .3s ease-out
}
@keyframes mn-slideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.mn-alert-warn{background:var(--warning-subtle);border:1px solid var(--warning-border);color:var(--ylw)}
.mn-alert-info{background:var(--primary-a8);border:1px solid var(--primary-a15);color:var(--acc2)}
.mn-alert b{display:block;margin-bottom:1px}
.mn-alert-icon{font-size:20px;flex-shrink:0}

/* ══════════════════════════════════════
   3. QUARTER HERO — Primary focus
   ══════════════════════════════════════ */
.mn-hero{
    background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border:1px solid var(--brd2);border-radius:var(--r2);
    box-shadow:var(--sh);overflow:hidden;
    transition:box-shadow .2s
}
.mn-hero:hover{box-shadow:var(--sh2)}
.mn-hero-head{
    display:flex;align-items:center;justify-content:space-between;
    padding:16px 20px 0
}
.mn-hero-head h3{
    font-size:13px;font-weight:700;color:var(--t1);
    letter-spacing:-.01em;display:flex;align-items:center;gap:6px
}
.mn-hero-head h3 span{font-size:15px}

/* Quarter pills */
.mn-qpills{display:flex;gap:4px}
.mn-qpill{
    padding:5px 12px;border-radius:8px;border:none;
    font-size:11px;font-weight:600;
    background:var(--glass2);color:var(--t3);
    cursor:pointer;transition:all .15s;letter-spacing:.02em
}
.mn-qpill:hover{color:var(--t1);background:var(--bg3)}
.mn-qpill.act{
    background:linear-gradient(135deg,var(--acc),var(--primary-active));
    color:var(--text-on-primary);box-shadow:0 2px 8px var(--primary-a30)
}

/* Hero stats row */
.mn-hero-stats{
    display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
    margin:16px 20px 0;border-radius:14px;overflow:hidden;
    background:var(--brd)
}
.mn-hero-stat{
    background:var(--glass2);padding:20px 16px;text-align:center;
    transition:background .15s
}
.mn-hero-stat:hover{background:var(--bg3)}
.mn-hero-stat-val{font-size:24px;font-weight:800;letter-spacing:-.03em;line-height:1}
.mn-hero-stat-lbl{
    font-size:9px;font-weight:600;color:var(--t3);
    text-transform:uppercase;letter-spacing:.08em;margin-top:4px
}

/* Model results row */
.mn-models{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:16px 20px 0}
.mn-mod{
    padding:14px 16px;border-radius:14px;
    background:var(--glass2);border:1px solid var(--brd);
    transition:all .15s;position:relative;overflow:hidden
}
.mn-mod:hover{border-color:var(--brd2);transform:translateY(-1px)}
.mn-mod::before{
    content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px
}
.mn-mod-303::before{background:var(--grn)}
.mn-mod-130::before{background:var(--ylw)}
.mn-mod-title{font-size:10px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.06em}
.mn-mod-val{font-size:22px;font-weight:800;letter-spacing:-.03em;margin-top:2px}
.mn-mod-note{font-size:10px;color:var(--t3);margin-top:1px}

/* Total bar */
.mn-total{
    margin:16px 20px 20px;padding:16px 20px;
    border-radius:14px;
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    transition:all .2s
}
.mn-total-debt{
    background:var(--danger-subtle);border:1px solid var(--danger-border)
}
.mn-total-ok{
    background:var(--success-subtle);border:1px solid var(--success-border)
}
.mn-total-left{flex:1}
.mn-total-lbl{font-size:12px;font-weight:600;color:var(--t2)}
.mn-total-sub{font-size:10px;color:var(--t3);margin-top:1px}
.mn-total-val{font-size:28px;font-weight:800;letter-spacing:-.03em}
.mn-total-cta{flex-shrink:0}

/* ══════════════════════════════════════
   4. TRANSITION METER
   ══════════════════════════════════════ */
.mn-trans{
    background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
    border:1px solid var(--brd2);border-radius:var(--r2);
    padding:16px 20px;box-shadow:var(--sh);
    transition:transform .2s,box-shadow .2s
}
.mn-trans:hover{transform:translateY(-1px);box-shadow:var(--sh2)}
.mn-trans-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.mn-trans-icon{font-size:20px}
.mn-trans-info{flex:1}
.mn-trans-title{font-size:13px;font-weight:700;color:var(--t1);letter-spacing:-.01em}
.mn-trans-sub{font-size:11px;color:var(--t2)}
.mn-trans-bar{height:6px;border-radius:3px;background:var(--glass2);overflow:hidden}
.mn-trans-fill{height:100%;border-radius:3px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.mn-trans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
.mn-trans-s{
    text-align:center;padding:10px 8px;border-radius:10px;
    background:var(--glass2);border:1px solid var(--brd);
    transition:all .15s
}
.mn-trans-s:hover{border-color:var(--brd2)}
.mn-trans-sv{font-size:15px;font-weight:800;letter-spacing:-.02em}
.mn-trans-sl{font-size:9px;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;margin-top:1px}

/* ══════════════════════════════════════
   5. COLLAPSIBLE SECTIONS
   ══════════════════════════════════════ */
.mn-sec{
    background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid var(--brd2);border-radius:var(--r2);
    box-shadow:var(--sh);overflow:hidden;
    transition:transform .2s,box-shadow .2s
}
.mn-sec:hover{transform:translateY(-1px);box-shadow:var(--sh2)}
.mn-sec-h{
    display:flex;align-items:center;justify-content:space-between;
    padding:14px 20px;cursor:pointer;user-select:none;transition:background .12s
}
.mn-sec-h:hover{background:var(--glass2)}
.mn-sec-h h3{
    margin:0;font-size:12px;font-weight:600;color:var(--t3);
    text-transform:uppercase;letter-spacing:.06em;
    display:flex;align-items:center;gap:6px
}
.mn-sec-h h3 span{font-size:14px}
.mn-sec-arrow{
    font-size:10px;color:var(--t3);
    transition:transform .25s cubic-bezier(.4,0,.2,1);
    display:inline-flex;align-items:center;justify-content:center;
    width:24px;height:24px;border-radius:6px;
    background:var(--glass2)
}
.mn-sec-arrow.open{transform:rotate(180deg)}
.mn-sec-b{padding:0 20px 20px;display:none}
.mn-sec-b.open{display:block;animation:mn-fadeIn .2s ease-out}
@keyframes mn-fadeIn{from{opacity:0}to{opacity:1}}

/* ── Annual summary stats ── */
.mn-yr-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.mn-yr-s{
    text-align:center;padding:12px 8px;border-radius:12px;
    background:var(--glass2);border:1px solid var(--brd);
    transition:all .15s
}
.mn-yr-s:hover{border-color:var(--brd2)}
.mn-yr-sv{font-size:16px;font-weight:800;letter-spacing:-.02em}
.mn-yr-sl{font-size:9px;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}

/* ── Table ── */
.mn-tbl{width:100%;border-collapse:collapse;font-size:11px}
.mn-tbl th{
    text-align:left;padding:8px 10px;
    background:var(--glass2);color:var(--t3);
    font-weight:600;font-size:9px;text-transform:uppercase;letter-spacing:.06em;
    border-bottom:1px solid var(--brd2)
}
.mn-tbl td{padding:8px 10px;border-bottom:1px solid var(--brd);color:var(--t1)}
.mn-tbl tr:last-child td{border-bottom:none}
.mn-tbl tbody tr{transition:background .1s}
.mn-tbl tbody tr:hover{background:var(--glass2)}
.mn-tbl tfoot td{font-weight:700;background:var(--glass2);border-top:2px solid var(--brd2)}
.mn-r{text-align:right}
.mn-pos{color:var(--grn);font-weight:700}
.mn-neg{color:var(--red);font-weight:700}
.mn-zero{color:var(--t3)}

/* ── Calendar rows ── */
.mn-cal{
    display:flex;align-items:center;gap:12px;
    padding:10px 0;border-bottom:1px solid var(--brd)
}
.mn-cal:last-child{border-bottom:none}
.mn-cal-d{
    min-width:44px;text-align:center;padding:6px 4px;
    border-radius:8px;font-size:10px;font-weight:700;line-height:1.2
}
.mn-cal-past{background:var(--glass2);color:var(--t3)}
.mn-cal-soon{background:var(--warning-subtle);color:var(--ylw)}
.mn-cal-future{background:var(--primary-a8);color:var(--acc2)}
.mn-cal-info{flex:1;min-width:0}
.mn-cal-m{font-size:12px;font-weight:600;color:var(--t1)}
.mn-cal-desc{font-size:10px;color:var(--t3)}
.mn-cal-badge{
    font-size:10px;font-weight:600;padding:3px 10px;
    border-radius:6px;white-space:nowrap
}

/* ══════════════════════════════════════
   6. MODEL GENERATORS (inline)
   ══════════════════════════════════════ */
.mn-gen-btns{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}
.mn-gen-btn{
    padding:8px 16px;border-radius:10px;border:1px solid var(--brd2);
    font-size:12px;font-weight:600;
    background:var(--glass2);color:var(--t2);
    cursor:pointer;transition:all .15s
}
.mn-gen-btn:hover{border-color:var(--primary-a25);color:var(--acc2);background:var(--primary-a6)}
.mn-gen-btn.act{
    background:linear-gradient(135deg,var(--acc),var(--primary-active));
    color:var(--text-on-primary);border-color:transparent;
    box-shadow:0 2px 8px var(--primary-a30)
}

/* ══════════════════════════════════════
   7. GESTOR ACCESS
   ══════════════════════════════════════ */
.mn-gestor{
    background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid var(--primary-a15);border-radius:var(--r2);
    padding:16px 20px;box-shadow:var(--sh);
    transition:transform .2s,box-shadow .2s
}
.mn-gestor:hover{transform:translateY(-1px);box-shadow:var(--sh2)}
.mn-gestor h3{
    margin:0 0 8px;font-size:12px;font-weight:600;
    text-transform:uppercase;letter-spacing:.06em;
    color:var(--acc2);display:flex;align-items:center;gap:6px
}

/* ── Year selector ── */
.mn-yr-sel{
    display:inline-flex;align-items:center;gap:4px;
    background:var(--glass2);border:1px solid var(--brd);
    border-radius:10px;padding:4px
}
.mn-yr-sel button{
    border:none;background:none;cursor:pointer;
    font-size:12px;color:var(--t3);padding:4px 6px;
    border-radius:6px;transition:all .15s;
    display:flex;align-items:center;justify-content:center
}
.mn-yr-sel button:hover{color:var(--t1);background:var(--bg3)}
.mn-yr-sel span{
    font-size:13px;font-weight:700;color:var(--t1);
    min-width:36px;text-align:center;letter-spacing:-.01em
}

/* ── Form grid ── */
.mn-fg{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:600px){.mn-fg{grid-template-columns:1fr}}
.mn-fg .fg{margin-bottom:0}

/* ══════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════ */
@media(max-width:640px){
    .mn-hero-stats{grid-template-columns:1fr}
    .mn-hero-stat{padding:14px 16px}
    .mn-hero-stat-val{font-size:20px}
    .mn-models{grid-template-columns:1fr;gap:8px;padding:12px 16px 0}
    .mn-total{margin:12px 16px 16px;flex-direction:column;text-align:center;gap:10px}
    .mn-id{flex-direction:column;padding:14px 16px}
    .mn-id-right{align-items:stretch;width:100%}
    .mn-trans-grid{grid-template-columns:1fr}
    .mn-yr-stats{grid-template-columns:1fr 1fr}
    .mn-hero-head{padding:14px 16px 0;flex-direction:column;gap:8px;align-items:flex-start}
    .mn-sec-b{padding:0 16px 16px}
    .mn-sec-h{padding:14px 16px}
}
