:root{
    color-scheme:light;
    --primary:#e11d48;
    --primary-dark:#be123c;
    --primary-soft:#fff1f2;
    --accent:#fb7185;
    --ink:#101828;
    --muted:#667085;
    --bg:#f6f8fc;
    --card:#ffffff;
    --border:#e6eaf2;
    --success:#059669;
    --warning:#d97706;
    --danger:#dc2626;
    --info:#0284c7;
    --shadow:0 18px 50px rgba(16,24,40,.08);
    --soft-shadow:0 8px 24px rgba(16,24,40,.06);
}
*{box-sizing:border-box}
html,body{min-height:100%}
body{
    margin:0;
    font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    color:var(--ink);
    background:
        radial-gradient(circle at 15% 0%, rgba(225,29,72,.09), transparent 28%),
        radial-gradient(circle at 85% 15%, rgba(251,113,133,.12), transparent 24%),
        var(--bg);
}
a{text-decoration:none}
.app{min-height:100vh;display:flex}
.sidebar{
    width:290px;
    position:fixed;
    inset:0 auto 0 0;
    background:rgba(255,255,255,.94);
    backdrop-filter:blur(16px);
    border-right:1px solid rgba(230,234,242,.9);
    padding:24px 18px;
    display:flex;
    flex-direction:column;
    z-index:1040;
    box-shadow:10px 0 30px rgba(16,24,40,.04);
}
.brand{display:flex;gap:13px;align-items:center;padding:4px 8px 24px;border-bottom:1px solid var(--border)}
.brand-logo{
    width:52px;height:52px;border-radius:18px;
    display:grid;place-items:center;
    color:#fff;font-size:25px;
    background:linear-gradient(135deg,var(--primary),var(--accent));
    box-shadow:0 14px 24px rgba(225,29,72,.25);
}
.brand strong{display:block;font-size:20px;font-weight:900;letter-spacing:-.4px}
.brand span{display:block;color:var(--muted);font-size:13px;margin-top:2px}
.menu{display:flex;flex-direction:column;gap:8px;margin-top:22px}
.menu a{
    display:flex;align-items:center;gap:12px;
    padding:12px 14px;border-radius:16px;
    color:#344054;font-weight:750;
    transition:.18s ease;
}
.menu a i{color:var(--primary);font-size:18px}
.menu a:hover{background:var(--primary-soft);color:var(--primary-dark);transform:translateX(2px)}
.menu a.active{
    color:#fff;
    background:linear-gradient(135deg,var(--primary),var(--primary-dark));
    box-shadow:0 12px 22px rgba(225,29,72,.18);
}
.menu a.active i{color:#fff}
.sidebar-user{
    margin-top:auto;
    display:flex;gap:11px;align-items:center;
    background:#f8fafc;border:1px solid var(--border);
    border-radius:18px;padding:12px;
}
.avatar{
    width:42px;height:42px;border-radius:14px;
    display:grid;place-items:center;
    background:var(--primary-soft);color:var(--primary);font-size:22px;
}
.sidebar-user strong{display:block;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user span{display:block;font-size:12px;color:var(--muted)}
.logout{
    margin-top:10px;
    border:1px solid var(--border);
    color:#475467;
    padding:10px 12px;
    border-radius:14px;
    text-align:center;
    font-weight:800;
    background:#fff;
}
.logout:hover{color:var(--primary);border-color:#fecdd3;background:#fff7f8}
.main{
    width:100%;
    min-width:0;
    margin-left:290px;
    padding:28px;
}
.topbar{
    background:rgba(255,255,255,.82);
    backdrop-filter:blur(14px);
    border:1px solid rgba(255,255,255,.9);
    box-shadow:var(--soft-shadow);
    border-radius:28px;
    padding:20px;
    display:flex;gap:16px;align-items:center;justify-content:space-between;
    margin-bottom:24px;
}
.eyebrow{text-transform:uppercase;letter-spacing:.1em;color:var(--primary);font-weight:900;font-size:12px;margin:0 0 5px}
.topbar h1{font-size:28px;letter-spacing:-.7px;margin:0;font-weight:950}
.topbar-actions{display:flex;gap:10px;align-items:center}
.btn-menu{
    display:none;
    border:1px solid var(--border);
    background:#fff;
    width:44px;height:44px;border-radius:14px;
    font-size:22px;color:var(--ink);
}
.btn{border-radius:14px;font-weight:800}
.btn-primary{
    --bs-btn-bg:var(--primary);
    --bs-btn-border-color:var(--primary);
    --bs-btn-hover-bg:var(--primary-dark);
    --bs-btn-hover-border-color:var(--primary-dark);
    --bs-btn-active-bg:var(--primary-dark);
    --bs-btn-active-border-color:var(--primary-dark);
}
.btn-outline-primary{
    --bs-btn-color:var(--primary);
    --bs-btn-border-color:var(--primary);
    --bs-btn-hover-bg:var(--primary);
    --bs-btn-hover-border-color:var(--primary);
}
.cardx{
    background:var(--card);
    border:1px solid var(--border);
    border-radius:26px;
    padding:22px;
    box-shadow:var(--shadow);
}
.stat{
    position:relative;
    overflow:hidden;
    min-height:170px;
}
.stat::after{
    content:"";
    position:absolute;right:-42px;top:-42px;
    width:136px;height:136px;border-radius:50%;
    background:var(--primary-soft);
}
.stat .icon{
    width:50px;height:50px;border-radius:17px;
    display:grid;place-items:center;
    background:var(--primary-soft);color:var(--primary);font-size:23px;
    position:relative;z-index:1;
}
.stat .label{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.06em;font-weight:900;margin:16px 0 6px;position:relative;z-index:1}
.stat .value{font-size:30px;font-weight:950;letter-spacing:-.6px;margin:0;position:relative;z-index:1}
.stat small{color:var(--muted);position:relative;z-index:1}
.section-title{font-weight:950;font-size:20px;letter-spacing:-.4px;margin:0}
.subtle{color:var(--muted)}
.filters{
    background:#fff;border:1px solid var(--border);
    border-radius:24px;padding:16px;box-shadow:var(--soft-shadow);
}
.form-label{font-weight:800;color:#344054;font-size:13px}
.form-control,.form-select{
    border-radius:14px;border-color:#d9e1ec;
    padding:.75rem .9rem;background:#fff;color:var(--ink);
}
.form-control:focus,.form-select:focus{
    border-color:var(--primary);
    box-shadow:0 0 0 .22rem rgba(225,29,72,.12);
}
.table{vertical-align:middle;margin:0;--bs-table-bg:transparent}
.table>:not(caption)>*>*{background:transparent!important;color:var(--ink)}
.table thead th{
    color:#667085!important;font-size:12px;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);white-space:nowrap;
}
.table tbody td{border-color:#edf2f7}
.table-responsive{border-radius:18px}
.badge{border-radius:999px;padding:.48rem .72rem;font-weight:850}
.mini{font-size:12px;color:var(--muted)}
.item-row{
    border:1px solid var(--border);
    background:#f8fafc;
    border-radius:20px;
    padding:14px;
    margin-bottom:12px;
}
.total-box{
    background:linear-gradient(135deg,#fff1f2,#fff);
    border:1px solid #ffe4e6;
    border-radius:22px;
    padding:16px;
}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
.calendar-head{
    text-align:center;font-size:12px;text-transform:uppercase;letter-spacing:.06em;
    color:#667085;font-weight:950;
}
.calendar-day{
    min-height:130px;background:#fff;border:1px solid var(--border);
    border-radius:20px;padding:10px;box-shadow:var(--soft-shadow);
}
.calendar-day.empty{background:transparent;border:0;box-shadow:none}
.calendar-day.today{outline:3px solid rgba(225,29,72,.16)}
.day-num{font-weight:950}
.day-pill{
    display:block;
    margin-top:7px;
    padding:6px 8px;
    border-radius:12px;
    background:#fff1f2;
    color:#be123c;
    font-size:12px;
    font-weight:900;
}
.credit-card{border-left:6px solid var(--primary)}
.progress{height:10px;border-radius:99px;background:#f1f5f9}
.alert{border-radius:18px}
.login-page{
    min-height:100vh;display:grid;place-items:center;padding:24px;
    background:
        radial-gradient(circle at top left,rgba(225,29,72,.18),transparent 34%),
        linear-gradient(135deg,#fff,#f8fafc);
}
.login-card{
    width:min(460px,94vw);background:#fff;border:1px solid var(--border);
    border-radius:30px;padding:36px;box-shadow:0 28px 80px rgba(16,24,40,.14);
}
.login-logo{
    width:70px;height:70px;border-radius:24px;
    display:grid;place-items:center;font-size:34px;color:#fff;
    background:linear-gradient(135deg,var(--primary),var(--accent));
    box-shadow:0 16px 30px rgba(225,29,72,.24);
}
.overlay{display:none}
.min-w-0{min-width:0}

@media (max-width: 1050px){
    .sidebar{transform:translateX(-110%);transition:.24s ease}
    .sidebar.show{transform:translateX(0)}
    .main{margin-left:0;padding:16px}
    .btn-menu{display:grid;place-items:center}
    .topbar{border-radius:22px;align-items:flex-start;flex-wrap:wrap}
    .topbar-actions{width:100%;justify-content:flex-end}
    .overlay.show{display:block;position:fixed;inset:0;background:rgba(15,23,42,.35);z-index:1030}
}
@media (max-width: 600px){
    .topbar h1{font-size:22px}
    .topbar-actions{display:grid;grid-template-columns:1fr;gap:8px}
    .topbar-actions .btn{width:100%}
    .stat .value{font-size:26px}
    .calendar-grid{grid-template-columns:1fr}
    .calendar-head,.calendar-day.empty{display:none}
    .cardx{padding:17px;border-radius:22px}
    .login-card{padding:25px}
}


/* ===== Login profesional responsive + recordar sesión ===== */
.login-page-v2{
    min-height:100svh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:18px;
    overflow-x:hidden;
    background:
        radial-gradient(circle at 10% 8%, rgba(225,29,72,.24), transparent 30%),
        radial-gradient(circle at 92% 12%, rgba(251,113,133,.18), transparent 26%),
        linear-gradient(135deg,#fff7f8 0%,#f8fafc 42%,#eef2ff 100%);
}
.login-shell{
    width:min(1080px,100%);
    min-height:min(680px,calc(100svh - 36px));
    display:grid;
    grid-template-columns:1.05fr .95fr;
    background:rgba(255,255,255,.76);
    border:1px solid rgba(255,255,255,.85);
    border-radius:34px;
    box-shadow:0 30px 90px rgba(16,24,40,.16);
    overflow:hidden;
    backdrop-filter:blur(18px);
}
.login-hero{
    position:relative;
    align-items:flex-end;
    padding:42px;
    color:#fff;
    background:
        linear-gradient(145deg,rgba(225,29,72,.95),rgba(190,18,60,.96)),
        radial-gradient(circle at 20% 10%,rgba(255,255,255,.18),transparent 28%);
    overflow:hidden;
}
.login-hero::before{
    content:"";
    position:absolute;
    width:280px;
    height:280px;
    border-radius:50%;
    right:-80px;
    top:-80px;
    background:rgba(255,255,255,.14);
}
.login-hero::after{
    content:"";
    position:absolute;
    width:190px;
    height:190px;
    border-radius:50%;
    left:-70px;
    bottom:110px;
    background:rgba(255,255,255,.10);
}
.login-hero-inner{position:relative;z-index:1;max-width:460px}
.hero-badge{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:9px 13px;
    border-radius:999px;
    background:rgba(255,255,255,.16);
    border:1px solid rgba(255,255,255,.22);
    font-weight:900;
    font-size:13px;
    margin-bottom:20px;
}
.login-hero h1{font-size:48px;line-height:1;font-weight:950;letter-spacing:-1.3px;margin:0 0 15px}
.login-hero p{font-size:17px;line-height:1.6;color:rgba(255,255,255,.86);margin:0 0 30px}
.hero-points{display:grid;gap:12px}
.hero-points div{
    display:flex;
    align-items:center;
    gap:12px;
    padding:13px 14px;
    border-radius:18px;
    background:rgba(255,255,255,.13);
    border:1px solid rgba(255,255,255,.16);
    font-weight:850;
}
.hero-points i{font-size:20px}
.login-card-v2{
    width:100%;
    max-width:none;
    border:0;
    border-radius:0;
    box-shadow:none;
    padding:52px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    background:#fff;
}
.login-header{text-align:left;margin-bottom:26px}
.login-header .login-logo{margin-bottom:18px}
.login-header h2{font-weight:950;letter-spacing:-.7px;font-size:34px;margin:0 0 7px;color:var(--ink)}
.login-alert{border:0;border-radius:18px;padding:13px 14px;font-weight:750}
.login-form{display:grid;gap:16px}
.form-group-v2{display:grid;gap:7px}
.input-icon-wrap{
    position:relative;
    display:flex;
    align-items:center;
}
.input-icon-wrap>i{
    position:absolute;
    left:15px;
    color:#98a2b3;
    font-size:18px;
    z-index:2;
}
.input-icon-wrap .form-control{
    min-height:54px;
    border-radius:18px;
    padding-left:46px;
    padding-right:46px;
    font-size:16px;
    background:#f8fafc;
    border-color:#e4e7ec;
}
.input-icon-wrap .form-control:focus{
    background:#fff;
}
.toggle-password{
    position:absolute;
    right:8px;
    width:40px;
    height:40px;
    border:0;
    border-radius:13px;
    background:transparent;
    color:#667085;
    display:grid;
    place-items:center;
}
.toggle-password:hover{background:#f1f5f9;color:var(--primary)}
.login-options{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    margin:2px 0 4px;
}
.remember-check{
    display:flex;
    align-items:center;
    gap:9px;
    font-weight:850;
    color:#344054;
    cursor:pointer;
    user-select:none;
}
.remember-check input{
    width:18px;
    height:18px;
    accent-color:var(--primary);
}
.login-options small{color:var(--muted);font-weight:800}
.login-submit{
    min-height:56px;
    border-radius:18px;
    font-size:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    box-shadow:0 16px 28px rgba(225,29,72,.22);
}
.login-submit i{font-size:24px;line-height:1}
.login-note{
    margin:0;
    color:var(--muted);
    text-align:center;
    font-size:13px;
    line-height:1.4;
}
.mobile-brand{
    align-items:center;
    gap:12px;
    margin-bottom:28px;
    padding:13px;
    border-radius:22px;
    background:#fff1f2;
    border:1px solid #ffe4e6;
}
.mobile-brand .login-logo{width:54px;height:54px;border-radius:18px;font-size:26px;flex:0 0 auto}
.mobile-brand span{display:block;color:var(--primary);font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.09em}
.mobile-brand strong{display:block;font-size:18px;font-weight:950;letter-spacing:-.4px;color:var(--ink)}

@media (max-width:991.98px){
    .login-page-v2{
        align-items:stretch;
        padding:10px;
    }
    .login-shell{
        display:block;
        width:100%;
        min-height:calc(100svh - 20px);
        border-radius:28px;
    }
    .login-card-v2{
        min-height:calc(100svh - 20px);
        border-radius:28px;
        padding:26px 20px;
    }
    .login-header{margin-bottom:22px}
    .login-header h2{font-size:30px}
}
@media (max-width:480px){
    .login-page-v2{padding:0;background:#fff}
    .login-shell{
        min-height:100svh;
        border-radius:0;
        box-shadow:none;
        border:0;
    }
    .login-card-v2{
        min-height:100svh;
        border-radius:0;
        padding:18px 14px 22px;
    }
    .mobile-brand{margin-bottom:22px}
    .login-header h2{font-size:27px}
    .login-header .subtle{font-size:14px}
    .input-icon-wrap .form-control{min-height:52px;border-radius:16px}
    .login-submit{min-height:54px;border-radius:16px;width:100%}
    .login-options{align-items:flex-start;flex-direction:column;gap:4px}
}
