:root{
    --bg:#061816;
    --bg-2:#081c2c;
    --bg-3:#10254a;
    --panel:rgba(10, 27, 36, .82);
    --panel-strong:#0d2230;
    --panel-soft:rgba(255,255,255,.05);
    --card:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
    --line:rgba(255,255,255,.1);
    --line-strong:rgba(255,255,255,.18);
    --text:#eef7f2;
    --text-soft:#bfd1cb;
    --text-muted:#94aaa5;
    --green:#75c800;
    --green-2:#5fac00;
    --blue:#0e1f9a;
    --blue-2:#1934c2;
    --gold:#f0d427;
    --success:#30d07a;
    --warning:#ffb84f;
    --danger:#ff6d74;
    --shadow:0 24px 65px rgba(0,0,0,.28);
    --shadow-soft:0 10px 30px rgba(0,0,0,.18);
    --radius-xl:32px;
    --radius-lg:24px;
    --radius:18px;
    --radius-sm:14px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
    min-height:100vh;
    font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;
    color:var(--text);
    background:
        radial-gradient(circle at 10% 10%, rgba(117,200,0,.18), transparent 22%),
        radial-gradient(circle at 88% 12%, rgba(14,31,154,.22), transparent 24%),
        radial-gradient(circle at 50% 100%, rgba(240,212,39,.08), transparent 20%),
        linear-gradient(145deg, #041311 0%, #071a18 28%, #0b1b31 64%, #08172c 100%);
}
body::before{
    content:"";
    position:fixed;
    inset:0;
    pointer-events:none;
    background-image:linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
    background-size:24px 24px;
    mask-image:radial-gradient(circle at center, black 20%, transparent 85%);
    opacity:.35;
}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
img{max-width:100%;display:block}
strong{font-weight:700}
.strong{font-weight:800;color:#f4fbf7}
.alert{padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.04)}

.login-body{display:grid;place-items:center;padding:30px;overflow-x:hidden}
.app-shell{display:grid;grid-template-columns:290px 1fr;min-height:100vh;position:relative;z-index:1}

.page-loader{
    position:fixed;
    inset:0;
    background:linear-gradient(145deg, rgba(2,10,15,.94), rgba(4,16,28,.88));
    display:grid;
    place-items:center;
    z-index:9999;
    opacity:1;
    visibility:visible;
    transition:opacity .45s ease, visibility .45s ease;
}
.page-loader.is-hidden{opacity:0;visibility:hidden}
.page-loader__panel{
    text-align:center;
    padding:34px 38px;
    border:1px solid var(--line);
    border-radius:28px;
    background:rgba(255,255,255,.04);
    box-shadow:var(--shadow);
    backdrop-filter:blur(18px);
}
.logo-loader{position:relative;width:144px;height:144px;margin:0 auto 18px;display:grid;place-items:center}
.logo-loader__ring{
    position:absolute;
    inset:0;
    border-radius:50%;
    border:2px solid rgba(255,255,255,.07);
    border-top-color:var(--green);
    border-right-color:var(--gold);
    border-bottom-color:var(--blue-2);
    animation:spin 1.35s linear infinite;
    box-shadow:0 0 36px rgba(117,200,0,.18);
}
.page-loader__title{font-size:1.15rem;font-weight:800;letter-spacing:.02em}
.page-loader__text{margin-top:8px;color:var(--text-soft)}

.brandmark{
    width:58px;height:58px;display:grid;place-items:center;overflow:hidden;
    border-radius:18px;
    background:linear-gradient(145deg, rgba(255,255,255,.14), rgba(255,255,255,.04));
    border:1px solid rgba(255,255,255,.16);
    box-shadow:var(--shadow-soft);
}
.brandmark img{width:100%;height:100%;object-fit:cover}
.brandmark--login{width:78px;height:78px;border-radius:24px}
.brandmark--loader{width:96px;height:96px;border-radius:28px;background:rgba(255,255,255,.08)}
.brandmark__fallback{font-size:1.2rem;font-weight:900;letter-spacing:.08em}

.sidebar{
    position:sticky;top:0;height:100vh;padding:22px 18px;
    background:linear-gradient(180deg, rgba(4,18,18,.92), rgba(7,20,35,.9));
    border-right:1px solid var(--line);
    backdrop-filter:blur(18px);
    display:flex;flex-direction:column;gap:18px;
    overflow:hidden;
    overscroll-behavior:contain;
}
.brand{display:flex;align-items:center;gap:14px}
.brand--sidebar{padding:8px 8px 12px}
.brand__title{font-weight:900;font-size:1.18rem;letter-spacing:.01em}
.brand__subtitle,.muted{color:var(--text-muted);font-size:.94rem;line-height:1.55}
.mini-kicker,.topbar__eyebrow{
    font-size:.74rem;
    text-transform:uppercase;
    letter-spacing:.14em;
    color:#b7c8c3;
}
.sidebar__panel,
.sidebar__footer,
.card,
.status-pill,
.login-card,
.login-panel,
.login-metric,
.login-feature,
.terminal-pill,
.switch,
.table-wrap,
.login-note{
    border:1px solid var(--line);
    background:var(--card);
    backdrop-filter:blur(16px);
    box-shadow:var(--shadow-soft);
}
.sidebar__panel{padding:16px;border-radius:24px}
.sidebar__panel--compact{background:linear-gradient(180deg, rgba(117,200,0,.12), rgba(255,255,255,.03))}
.sidebar__meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.sidebar__user-name{margin-top:6px;font-size:1.03rem;font-weight:800}
.sidebar__device{display:flex;gap:10px;align-items:center;margin-top:14px;color:var(--text-soft);font-size:.92rem}
.sidebar__stats{display:grid;grid-template-columns:1fr;gap:10px}
.sidebar__footer{margin-top:0;padding:16px;border-radius:24px;flex:0 0 auto}

.menu{display:flex;flex-direction:column;gap:8px;flex:1 1 auto;min-height:0;overflow-y:auto;padding-right:6px;scrollbar-width:thin;scrollbar-color:rgba(117,200,0,.45) rgba(255,255,255,.04)}
.menu::-webkit-scrollbar{width:8px}
.menu::-webkit-scrollbar-track{background:rgba(255,255,255,.04);border-radius:999px}
.menu::-webkit-scrollbar-thumb{background:linear-gradient(180deg, rgba(117,200,0,.72), rgba(14,31,154,.72));border-radius:999px}
.menu__item{
    display:flex;align-items:center;gap:12px;padding:14px 15px;border-radius:18px;
    color:#e7f4ee;position:relative;overflow:hidden;
    border:1px solid transparent;transition:transform .22s ease, border-color .22s ease, background .22s ease;
}
.menu__item::before{
    content:"";position:absolute;inset:0;background:linear-gradient(90deg, rgba(117,200,0,.14), rgba(14,31,154,.08));
    opacity:0;transition:opacity .22s ease;
}
.menu__item:hover,.menu__item.is-active{transform:translateX(4px);border-color:rgba(117,200,0,.24);background:rgba(255,255,255,.04)}
.menu__item:hover::before,.menu__item.is-active::before{opacity:1}
.menu__icon,.menu__item span{position:relative;z-index:1}
.menu__icon{
    width:36px;height:36px;border-radius:12px;display:grid;place-items:center;
    background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
}

.main{padding:26px 26px 34px;min-width:0}
.topbar{
    display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:20px;
}
.topbar__left,.topbar__right{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.page-title{margin:.18rem 0 0;font-size:clamp(1.6rem, 2vw, 2.2rem);font-weight:900}
.topbar__right{justify-content:flex-end}
.status-pill,.terminal-pill{
    display:inline-flex;gap:10px;align-items:center;padding:11px 14px;border-radius:999px;color:#ebf7f2;
}
.status-pill strong,.terminal-pill strong{font-weight:800}
.status-pill--accent{background:linear-gradient(90deg, rgba(14,31,154,.28), rgba(117,200,0,.18))}

.icon,.icon-btn svg{width:20px;height:20px;flex:0 0 auto}
.icon--sm{width:16px;height:16px}
.icon-btn,.btn{
    border:0;cursor:pointer;color:var(--text);transition:transform .18s ease, filter .18s ease, box-shadow .18s ease;
}
.icon-btn{
    width:48px;height:48px;border-radius:16px;display:grid;place-items:center;
    background:linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
    border:1px solid var(--line);
    box-shadow:var(--shadow-soft);
}
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:10px;
    padding:12px 18px;border-radius:16px;
    background:rgba(255,255,255,.06);border:1px solid transparent;
}
.btn:hover,.icon-btn:hover{transform:translateY(-1px);filter:brightness(1.06)}
.btn--primary{background:linear-gradient(135deg, var(--green-2), var(--green));color:#072010;box-shadow:0 12px 26px rgba(117,200,0,.28)}
.btn--success{background:linear-gradient(135deg, #19af60, #41db88);color:#062514}
.btn--danger{background:linear-gradient(135deg, #d64d65, #ff7a83);color:#fff}
.btn--warning{background:linear-gradient(135deg, #f0b117, #ffd166);color:#392700}
.btn--ghost{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1)}
.btn--sm{padding:10px 13px;border-radius:14px;font-size:.9rem}

.content{display:flex;flex-direction:column;gap:18px}
.grid{display:grid;gap:18px}
.grid--cards{grid-template-columns:repeat(4, minmax(0,1fr))}
.grid--2{grid-template-columns:repeat(2, minmax(0,1fr))}
.card{padding:20px;border-radius:26px;position:relative;overflow:hidden}
.card::after{
    content:"";position:absolute;inset:auto -30% -55% auto;width:180px;height:180px;border-radius:50%;
    background:radial-gradient(circle, rgba(117,200,0,.16), transparent 66%);pointer-events:none;
}
.card__title{margin:0 0 6px;font-size:1rem;color:#cbddd5;font-weight:700}
.card__metric{font-size:clamp(1.7rem, 2vw, 2.2rem);font-weight:900;line-height:1.1}
.card__footer{margin-top:10px;color:var(--text-muted);font-size:.92rem;line-height:1.55}
.toolbar{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center}
.section-title{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:0 0 14px;font-size:1.05rem;font-weight:800}

.form-grid{display:grid;grid-template-columns:repeat(12, minmax(0,1fr));gap:14px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:.94rem;color:#d7e7e0;font-weight:600}
.field input,.field select,.field textarea{
    width:100%;padding:14px 16px;border-radius:16px;border:1px solid rgba(255,255,255,.1);
    background:rgba(255,255,255,.06);color:var(--text);outline:none;transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.field textarea{min-height:110px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{
    border-color:rgba(117,200,0,.5);
    box-shadow:0 0 0 4px rgba(117,200,0,.12), 0 14px 28px rgba(0,0,0,.14);
    background:rgba(255,255,255,.08);
}
.password-field{position:relative}
.password-toggle{
    position:absolute;right:12px;top:50%;transform:translateY(-50%);width:42px;height:42px;
    border:0;border-radius:14px;background:rgba(255,255,255,.06);color:var(--text);cursor:pointer;display:grid;place-items:center;
}
.field-note{color:var(--text-muted);font-size:.86rem}
.span-12{grid-column:span 12}.span-8{grid-column:span 8}.span-6{grid-column:span 6}.span-4{grid-column:span 4}.span-3{grid-column:span 3}.span-2{grid-column:span 2}

.table-wrap{overflow:auto;border-radius:22px}
.table{width:100%;border-collapse:collapse;min-width:880px;background:rgba(255,255,255,.015)}
.table th,.table td{padding:14px 15px;border-bottom:1px solid rgba(255,255,255,.08);vertical-align:top}
.table th{position:sticky;top:0;background:rgba(7,18,28,.92);font-size:.92rem;text-align:left;color:#d7e7e0;backdrop-filter:blur(10px)}
.table tr:hover td{background:rgba(255,255,255,.03)}
.table .indent-1{padding-left:20px}.table .indent-2{padding-left:34px}.table .indent-3{padding-left:48px}.table .indent-4{padding-left:62px}.table .indent-5{padding-left:76px}
.text-right{text-align:right}.text-center{text-align:center}.code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:#d6ecff}
.empty{padding:34px;text-align:center;color:var(--text-muted)}
.actions{display:flex;flex-wrap:wrap;gap:8px}.totals{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}

.badge{
    display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;font-size:.82rem;font-weight:700;
    letter-spacing:.01em;border:1px solid transparent;
}
.badge--soft{background:rgba(14,31,154,.18);color:#d8e2ff;border-color:rgba(85,108,255,.18)}
.badge--success{background:rgba(48,208,122,.16);color:#d7ffe8;border-color:rgba(48,208,122,.18)}
.badge--warning{background:rgba(255,184,79,.16);color:#fff1d5;border-color:rgba(255,184,79,.2)}
.badge--danger{background:rgba(255,109,116,.16);color:#ffe0e2;border-color:rgba(255,109,116,.2)}

.kpi-bar{height:12px;border-radius:999px;overflow:hidden;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.06)}
.kpi-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg, var(--green), var(--blue-2), var(--gold));background-size:200% 100%;animation:gradientShift 4s linear infinite}

.switch{display:flex;gap:12px;align-items:flex-start;padding:15px 16px;border-radius:18px;color:#dceae3}
.switch input{margin-top:3px;transform:scale(1.1)}
small.muted{display:block;margin-top:6px}
.card code{display:inline-block;margin-top:8px;padding:10px 12px;border-radius:12px;background:rgba(255,255,255,.05);border:1px solid var(--line);color:#d0e6ff}

.toast-container{position:fixed;top:22px;right:24px;display:grid;gap:12px;z-index:7000;pointer-events:none}
.toast{
    display:flex;align-items:flex-start;gap:12px;max-width:min(420px, calc(100vw - 32px));
    padding:14px 16px;border-radius:20px;border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow);
    color:var(--text);backdrop-filter:blur(18px);pointer-events:auto;
    opacity:0;transform:translateY(-8px) scale(.98);transition:opacity .22s ease, transform .22s ease;
}
.toast.is-visible{opacity:1;transform:translateY(0) scale(1)}
.toast--success{background:linear-gradient(145deg, rgba(18,118,66,.92), rgba(14,59,43,.92))}
.toast--warning{background:linear-gradient(145deg, rgba(130,92,22,.92), rgba(72,52,17,.92))}
.toast--danger{background:linear-gradient(145deg, rgba(128,39,52,.94), rgba(78,18,31,.94))}
.toast__icon{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:rgba(255,255,255,.08)}
.toast__content strong{display:block;margin-bottom:2px}
.toast__close{margin-left:auto;background:transparent;border:0;color:inherit;font-size:1.4rem;line-height:1;cursor:pointer}

.confirm-backdrop{
    position:fixed;inset:0;background:rgba(1,8,13,.65);backdrop-filter:blur(6px);
    display:none;align-items:center;justify-content:center;padding:20px;z-index:8000;
}
.confirm-backdrop.is-open{display:flex}
.confirm-dialog{
    width:min(480px,100%);padding:24px;border-radius:28px;background:linear-gradient(180deg, rgba(14,31,30,.96), rgba(10,25,38,.96));
    border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow);
}
.confirm-dialog__title{display:flex;align-items:center;gap:12px;margin-bottom:10px;font-weight:900;font-size:1.15rem}
.confirm-dialog__message{color:var(--text-soft);line-height:1.65;margin-bottom:18px}
.confirm-dialog__actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}

.login-card{
    width:min(1240px,100%);display:grid;grid-template-columns:1.06fr .94fr;overflow:hidden;
    border-radius:34px;background:linear-gradient(145deg, rgba(5,20,18,.86), rgba(8,23,40,.8));
}
.login-hero{padding:42px 40px;background:
    radial-gradient(circle at 10% 10%, rgba(117,200,0,.18), transparent 24%),
    radial-gradient(circle at 85% 20%, rgba(14,31,154,.22), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
}
.login-hero__header{display:flex;align-items:center;gap:16px;margin-bottom:18px}
.login-kicker{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:#def0e4;font-size:.84rem;font-weight:700;letter-spacing:.02em}
.login-hero h1{font-size:clamp(2.1rem, 3vw, 3.35rem);line-height:1.06;margin:10px 0 16px;font-weight:900;max-width:680px}
.login-hero p{max-width:660px;font-size:1rem;line-height:1.72;color:var(--text-soft)}
.login-grid{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:14px;margin-top:26px}
.login-metric{padding:18px;border-radius:22px}
.login-metric__value{font-size:1.5rem;font-weight:900}
.login-metric__label{color:var(--text-muted);margin-top:6px}
.login-feature-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:26px}
.login-feature{padding:16px;border-radius:22px;display:flex;gap:12px;align-items:flex-start}
.login-feature__icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:rgba(255,255,255,.07);color:#e9f8ed;flex:0 0 auto}
.login-panel{padding:42px 38px;position:relative}
.login-panel::before{
    content:"";position:absolute;top:0;left:0;bottom:0;width:1px;background:linear-gradient(180deg, transparent, rgba(255,255,255,.15), transparent);
}
.login-panel__header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:18px}
.login-panel h2{margin:0;font-size:2rem;font-weight:900}
.login-note{padding:14px 16px;border-radius:20px;margin-bottom:18px;color:#deebff;background:linear-gradient(145deg, rgba(14,31,154,.22), rgba(117,200,0,.12))}
.login-note strong{display:block;margin-bottom:3px}
.login-terminal{display:flex;gap:10px;align-items:flex-start;padding:14px 16px;border-radius:20px;margin:18px 0;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:#d6e5df}
.login-terminal__token{display:block;margin-top:4px;color:var(--text-muted);font-size:.82rem;word-break:break-all}
.login-brand-inline{display:flex;gap:12px;align-items:center;margin-top:24px}

.page-enter{animation:fadeRise .44s ease}
.table-wrap,.card,.login-panel,.login-feature,.login-metric,.sidebar__panel,.sidebar__footer{animation:fadeRise .5s ease}

@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeRise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
@keyframes gradientShift{0%{background-position:0 50%}100%{background-position:200% 50%}}

@media (max-width:1200px){
    .grid--cards{grid-template-columns:repeat(2,minmax(0,1fr))}
    .login-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:980px){
    .app-shell{grid-template-columns:1fr}
    .sidebar{position:fixed;inset:0 auto 0 0;width:286px;transform:translateX(-105%);z-index:5000;transition:transform .24s ease}
    .sidebar.is-open{transform:translateX(0)}
    .main{padding:18px}
    .grid--2,.totals,.login-card{grid-template-columns:1fr}
    .login-card{overflow:visible}
    .login-panel::before{display:none}
    .login-feature-list{grid-template-columns:1fr}
}
@media (max-width:760px){
    .login-body{padding:16px}
    .topbar{flex-direction:column;align-items:flex-start}
    .topbar__right{justify-content:flex-start}
    .grid--cards,.login-grid,.totals{grid-template-columns:1fr}
    .form-grid{grid-template-columns:1fr}
    .span-12,.span-8,.span-6,.span-4,.span-3,.span-2{grid-column:span 1}
    .login-hero,.login-panel{padding:24px}
    .login-hero h1{font-size:2rem}
    .status-pill,.terminal-pill{width:100%}
}


.backup-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.timeline{display:flex;flex-direction:column;gap:14px}
.timeline__item{position:relative;padding-left:22px;color:var(--text-soft)}
.timeline__item::before{content:"";position:absolute;left:4px;top:7px;width:9px;height:9px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--blue-2));box-shadow:0 0 0 4px rgba(117,200,0,.12)}
.timeline__item::after{content:"";position:absolute;left:8px;top:20px;bottom:-12px;width:1px;background:linear-gradient(180deg, rgba(255,255,255,.16), transparent)}
.timeline__item:last-child::after{display:none}
.metric-inline{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.metric-inline strong{font-size:1.02rem}
.form-inline{display:inline}
.actions--wrap{display:flex;gap:10px;flex-wrap:wrap}
@media (max-width:1180px){.backup-grid{grid-template-columns:1fr}}


/* ===== FASE 4 UI ===== */
html,body{height:100%}
body{overflow-x:hidden}
.app-shell{align-items:start}
.sidebar{
    height:100dvh;
    max-height:100dvh;
}
.sidebar__footer{position:sticky;bottom:0;background:linear-gradient(180deg, rgba(7,20,35,.92), rgba(7,20,35,.98))}
.menu{
    padding-bottom:14px;
    overflow-y:auto;
    overflow-x:hidden;
}
.menu__item{min-height:58px}
.field select{
    appearance:none;
    -webkit-appearance:none;
    background-image:
        linear-gradient(45deg, transparent 50%, rgba(255,255,255,.75) 50%),
        linear-gradient(135deg, rgba(255,255,255,.75) 50%, transparent 50%),
        linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.06));
    background-position:
        calc(100% - 20px) calc(50% - 3px),
        calc(100% - 14px) calc(50% - 3px),
        0 0;
    background-size:6px 6px, 6px 6px, 100% 100%;
    background-repeat:no-repeat;
    padding-right:42px;
}
.field select option,
select option{
    background:#0d2230;
    color:#eef7f2;
}
select:focus option:checked{
    background:linear-gradient(135deg, rgba(117,200,0,.85), rgba(14,31,154,.75));
    color:#fff;
}
.module-header{
    display:flex;
    justify-content:space-between;
    gap:16px;
    align-items:flex-start;
    flex-wrap:wrap;
}
.module-header__note{
    max-width:520px;
    color:var(--text-soft);
    line-height:1.6;
}
.section-stack{display:flex;flex-direction:column;gap:18px}
.socio-summary{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:12px;
}
.info-chip{
    padding:14px 16px;
    border-radius:18px;
    border:1px solid var(--line);
    background:rgba(255,255,255,.04);
    min-height:88px;
}
.info-chip__label{
    color:var(--text-muted);
    font-size:.78rem;
    text-transform:uppercase;
    letter-spacing:.12em;
    margin-bottom:8px;
}
.info-chip__value{
    font-weight:800;
    color:var(--text);
    line-height:1.35;
    word-break:break-word;
}
.hero-inline{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    gap:14px;
    align-items:center;
}
.hero-inline__actions{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}
.card--fit{padding:18px 18px 16px}
.card--full{width:100%}
.asiento-layout--single{
    grid-template-columns:minmax(0,1fr);
}
.asiento-grid table input,
.asiento-grid table select{
    min-width:140px;
    padding:11px 12px;
    border-radius:12px;
    border:1px solid rgba(255,255,255,.1);
    background:rgba(255,255,255,.04);
    color:var(--text);
}
.table-compact th,.table-compact td{padding:11px 12px}
.metric-strip{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:14px;
}
.metric-mini{
    padding:14px 16px;
    border-radius:18px;
    border:1px solid var(--line);
    background:rgba(255,255,255,.04);
}
.metric-mini__label{
    color:var(--text-muted);
    font-size:.8rem;
    margin-bottom:8px;
}
.metric-mini__value{
    font-size:1.2rem;
    font-weight:900;
}
.filters-inline{
    display:grid;
    grid-template-columns:2fr 1.25fr 1fr 1fr auto;
    gap:12px;
    align-items:end;
}
.page-block{display:flex;flex-direction:column;gap:20px}
.helper-text{color:var(--text-muted);font-size:.92rem;line-height:1.6}
.module-table__saldo-positive{color:#d7ffe8}
.module-table__saldo-negative{color:#ffe0e2}
.table-wrap--thin{max-height:560px;overflow:auto}
.placeholder-panel{
    padding:16px;
    border-radius:20px;
    border:1px dashed rgba(255,255,255,.14);
    color:var(--text-soft);
    background:rgba(255,255,255,.025);
}
@media (max-width: 1300px){
    .socio-summary,.metric-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
    .filters-inline{grid-template-columns:1fr 1fr 1fr}
}
@media (max-width: 980px){
    .sidebar{
        position:fixed;
        left:0;
        top:0;
        bottom:0;
        z-index:5000;
        width:min(320px, 92vw);
        transform:translateX(-104%);
        transition:transform .25s ease;
    }
    .sidebar.is-open{transform:translateX(0)}
    .app-shell{grid-template-columns:1fr}
    .main{padding:18px}
}
@media (max-width: 760px){
    .socio-summary,.metric-strip,.filters-inline{
        grid-template-columns:1fr;
    }
    .topbar__right{width:100%;justify-content:flex-start}
}

.kpi-card .card__metric{font-size:clamp(2rem,2.6vw,2.7rem)}
.card--hero{min-height:100%}
.quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.quick-link{
    display:flex;flex-direction:column;gap:6px;padding:16px 18px;border-radius:18px;
    border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);
    transition:transform .18s ease,border-color .18s ease,background .18s ease;
}
.quick-link:hover{transform:translateY(-2px);border-color:rgba(117,200,0,.34);background:rgba(255,255,255,.07)}
.quick-link strong{font-size:1rem;color:#f2fbf6}
.quick-link span{color:var(--text-soft);font-size:.92rem;line-height:1.45}
.metric-strip--wide{grid-template-columns:repeat(3,minmax(0,1fr))}
.coverage-card{padding:16px 18px;border-radius:22px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04)}
.coverage-card__header{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:12px}
.progress{height:12px;background:rgba(255,255,255,.08);border-radius:999px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.progress span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--gold),var(--blue-2));box-shadow:0 0 24px rgba(117,200,0,.35)}
.filters-inline--dense{display:grid;grid-template-columns:2fr repeat(3,minmax(160px,1fr));gap:14px;align-items:end}
.field--grow{min-width:0}
.toolbar-actions-wrap{flex-wrap:wrap;justify-content:flex-end}
.detail-panel{padding:18px;border-radius:22px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.035)}
.detail-panel__title{font-size:1rem;font-weight:800;color:#f2fbf6;margin-bottom:14px}
.detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.detail-item{padding:14px 15px;border-radius:16px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08)}
.detail-item__label{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:6px}
.detail-item__value{font-weight:700;color:#eef8f3;line-height:1.45;word-break:break-word}
.placeholder-panel{padding:18px;border-radius:20px;border:1px dashed rgba(255,255,255,.16);background:rgba(255,255,255,.03);color:var(--text-soft)}
.module-header--stack-mobile{align-items:flex-start}
@media (max-width: 1180px){
    .grid--cards{grid-template-columns:repeat(2,minmax(0,1fr))}
    .metric-strip--wide{grid-template-columns:repeat(2,minmax(0,1fr))}
    .detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 980px){
    .quick-grid,.grid--2{grid-template-columns:1fr}
    .filters-inline--dense{grid-template-columns:1fr 1fr}
}
@media (max-width: 720px){
    .grid--cards,.metric-strip--wide,.detail-grid,.filters-inline--dense{grid-template-columns:1fr}
    .toolbar-actions-wrap{justify-content:stretch}
    .toolbar-actions-wrap .btn{width:100%}
}

.report-sheet{background:rgba(255,255,255,.02);border-radius:22px;padding:10px}
.report-sheet__top{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px;flex-wrap:wrap}
.report-sheet__company{font-size:1.25rem;font-weight:900;color:#f4fbf7}
.report-sheet__title{font-size:1.7rem;font-weight:900;letter-spacing:.02em;margin-top:6px}
.report-sheet__meta{color:var(--text-soft);line-height:1.7}
.report-sheet__meta--right{text-align:right}
.report-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px}
.report-table{min-width:760px}
@media (max-width: 980px){.report-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.report-sheet__meta--right{text-align:left}}
@media (max-width: 640px){.report-summary-grid{grid-template-columns:1fr}}

.btn:disabled,
.btn.is-disabled{
    opacity:.56;
    pointer-events:none;
    cursor:not-allowed;
    box-shadow:none;
    filter:saturate(.55);
}

.toolbar--stack-mobile{
    align-items:flex-start;
}

.report-sheet--formal{
    background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
    padding:16px;
}

.report-table--financial td,
.report-table--financial th{
    vertical-align:top;
}

.report-section-row td{
    background:rgba(117,200,0,.12);
    color:#f7fff9;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.04em;
}

.report-total-row td{
    background:rgba(255,255,255,.05);
    font-weight:800;
}

.report-total-row--accent td{
    background:rgba(117,200,0,.16);
}

.report-summary-grid--3{
    grid-template-columns:repeat(3,minmax(0,1fr));
}

@media (max-width: 980px){
    .report-summary-grid--3{
        grid-template-columns:1fr;
    }
}

/* ===== PATCH UI PREMIUM LOGIN + SIDEBAR ===== */
.login-body--premium{
    min-height:100dvh;
    padding:24px;
    align-items:center;
}
.login-noise{
    position:fixed;
    inset:0;
    pointer-events:none;
    background:
        radial-gradient(circle at 14% 18%, rgba(117,200,0,.16), transparent 20%),
        radial-gradient(circle at 82% 12%, rgba(14,31,154,.18), transparent 24%),
        radial-gradient(circle at 65% 84%, rgba(240,212,39,.08), transparent 16%);
    filter:blur(12px);
    opacity:.9;
}
.login-stage{
    width:min(1320px, 100%);
    position:relative;
    z-index:1;
}
.login-card--premium{
    grid-template-columns:minmax(0, 1.08fr) minmax(420px, .92fr);
    min-height:min(880px, calc(100dvh - 48px));
    border-radius:36px;
    box-shadow:0 30px 80px rgba(0,0,0,.34);
}
.login-hero--premium,
.login-panel--premium{
    padding:clamp(28px, 3vw, 46px);
}
.login-hero--premium{
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    gap:24px;
}
.login-hero__headline{max-width:720px}
.login-hero--premium h1{
    font-size:clamp(2.35rem, 3vw, 4.05rem);
    line-height:1.02;
    letter-spacing:-.03em;
    margin:12px 0 18px;
}
.login-hero--premium p{
    font-size:1.02rem;
    line-height:1.82;
    max-width:660px;
}
.login-trust-strip{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top:2px;
}
.login-trust-strip span{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:10px 14px;
    border-radius:999px;
    background:rgba(255,255,255,.055);
    border:1px solid rgba(255,255,255,.09);
    color:#dbece3;
    font-size:.9rem;
}
.login-grid--premium{margin-top:6px}
.login-feature-list--premium{margin-top:6px}
.login-brand-inline--premium{
    margin-top:auto;
    padding-top:8px;
}
.login-panel--premium{
    display:flex;
    flex-direction:column;
    justify-content:center;
    gap:14px;
}
.login-form-card{
    padding:18px;
    border-radius:24px;
    background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
    border:1px solid rgba(255,255,255,.08);
}
.btn--block{width:100%}
.login-form-card__actions{margin-top:4px}
.login-footer-strip{
    display:flex;
    justify-content:space-between;
    gap:14px;
    flex-wrap:wrap;
    color:var(--text-soft);
    font-size:.95rem;
    padding-top:2px;
}
.login-terminal--premium{
    background:linear-gradient(145deg, rgba(255,255,255,.05), rgba(255,255,255,.025));
}

/* sidebar más visible */
.sidebar{
    padding:16px 14px;
    gap:14px;
}
.brand--sidebar{padding:4px 6px 8px}
.brandmark{width:52px;height:52px;border-radius:16px}
.brand__title{font-size:1.08rem}
.brand__subtitle,.muted{font-size:.92rem}
.sidebar__panel,
.sidebar__footer{
    padding:14px;
    border-radius:22px;
}
.sidebar__user-name{font-size:.98rem}
.sidebar__device{font-size:.88rem;margin-top:10px}
.menu{
    gap:6px;
    padding-right:4px;
}
.menu__item{
    min-height:50px;
    padding:11px 12px;
    border-radius:16px;
}
.menu__icon{
    width:34px;
    height:34px;
    border-radius:11px;
}
.sidebar__footer{
    padding-top:13px;
    padding-bottom:13px;
}

/* paneles informativos opcionales ocupan menos */
.module-note,
.card--note,
.panel-note,
.section-note,
.help-panel{
    min-height:auto;
}

@media (max-width: 1360px){
    .login-card--premium{grid-template-columns:minmax(0,1fr) minmax(400px,.92fr)}
    .login-hero--premium h1{font-size:clamp(2.1rem, 2.7vw, 3.45rem)}
}
@media (max-width: 1180px){
    .login-body--premium{padding:18px}
    .login-card--premium{min-height:auto}
}
@media (max-width: 980px){
    .login-card--premium{grid-template-columns:1fr;min-height:auto}
    .login-panel--premium{border-top:1px solid rgba(255,255,255,.08)}
    .login-grid--premium{grid-template-columns:repeat(2, minmax(0,1fr))}
}
@media (max-width: 720px){
    .login-body--premium{padding:14px}
    .login-grid--premium,
    .login-feature-list--premium{grid-template-columns:1fr}
    .login-hero--premium,
    .login-panel--premium{padding:22px}
    .login-hero--premium h1{font-size:2rem}
    .login-footer-strip{flex-direction:column;gap:8px}
}
