*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#f5f7fb;color:#06142d;font-size:14px}.clearfix:after{content:"";display:block;clear:both}a{color:#006bcf}.login-page,.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f7fb;padding:18px}.login-box,.login-card{width:490px;max-width:100%;background:#fff;border-radius:18px;padding:34px;box-shadow:0 14px 45px rgba(18,38,63,.12)}.logo-text,.login-logo{font-size:36px;line-height:40px;font-weight:800;color:#0b2d6b;letter-spacing:2px;text-align:center;margin-bottom:22px}.tabs,.login-subtitle{font-size:17px;margin-bottom:18px;color:#06142d}.input-box{margin-bottom:16px}.input-box input,.login-box input[type=text],.login-box input[type=password],.login-card input[type=text],.login-card input[type=password]{width:100%;height:44px;border:1px solid #bac7d8;border-radius:7px;padding:0 13px;font-size:14px;background:#fff}.login-btn{background:#0b63b6;color:#fff!important;border:none;border-radius:8px;padding:12px 30px;min-width:150px;font-size:15px;font-weight:700;line-height:20px;text-align:center;text-decoration:none!important;cursor:pointer;display:inline-block;transition:.2s}.login-btn:hover{background:#084f91}.small-note{font-size:12px;color:#60708a;margin-top:10px}.login-footer{text-align:center;color:#60708a;margin-top:28px}.login-footer-logo{font-weight:800;color:#0b2d6b;font-size:22px;margin-bottom:6px}.main-body{min-height:100vh}.page-wappere,.page-wrapper{display:flex;min-height:100vh}.left-side{width:240px;background:#eef1f6;position:fixed;left:0;top:0;bottom:0;border-right:1px solid #dde3ee;z-index:1000}.left-side-box{position:relative;min-height:100%;padding-bottom:85px}.slidebar-logo,.brand{padding:28px 24px;font-size:24px;font-weight:800;color:#102b63;letter-spacing:.5px}.left-menu,.menu{padding:10px 0;margin:0;list-style:none}.left-menu li{list-style:none;margin:0}.left-menu a,.menu a{display:flex;align-items:center;gap:12px;padding:15px 24px;color:#06142d;text-decoration:none;font-size:15px;line-height:20px}.left-menu a:hover,.left-menu a.active,.menu a:hover,.menu a.active{background:#fff;color:#0066b3;border-left:4px solid #2aa8f2;padding-left:20px}.menu-icon{display:inline-flex;width:20px;height:20px;min-width:20px;align-items:center;justify-content:center}.menu-icon svg,.left-menu svg,.menu svg{width:20px!important;height:20px!important;fill:#2aa8f2!important;display:block}.left-logout,.logout-link{position:absolute;bottom:18px;left:0;right:0}.right-side{margin-left:240px;width:calc(100% - 240px);min-height:100vh}.header-area{height:78px;background:#fff;border-bottom:1px solid #dde3ee;display:flex;align-items:center;justify-content:space-between;padding:0 28px}.header-logo{font-size:24px;font-weight:800;color:#102b63}.hamburger{display:none;background:none;border:none;font-size:26px;line-height:26px;color:#102b63;cursor:pointer;margin-right:12px}.welcome{font-size:14px;text-align:right;line-height:22px;color:#06142d}.main-area{padding:32px}.page-title h2{margin:0 0 8px 0;font-size:26px;color:#06142d}.page-title p{margin:0 0 24px 0;color:#60708a}.card-box,.report-card{background:#fff;border-radius:16px;padding:26px;box-shadow:0 10px 30px rgba(18,38,63,.08);margin-bottom:24px}.tile-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px}.tile-card,.dashboard-tile{background:#fff;border-radius:16px;padding:24px;border-left:5px solid #2aa8f2;box-shadow:0 10px 30px rgba(18,38,63,.08)}.tile-card p,.tile-label{margin:0 0 12px;color:#60708a}.tile-card h3,.tile-number{margin:0;font-size:32px;color:#003b84;font-weight:800}.form-row{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:22px;align-items:end;margin-bottom:20px}.form-row-3{grid-template-columns:repeat(3,minmax(200px,1fr))}.form-row-2{grid-template-columns:repeat(2,minmax(220px,1fr))}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:700;font-size:13px;margin-bottom:8px}.form-control{height:44px;border:1px solid #bcc7d8;border-radius:7px;padding:0 12px;width:100%;font-size:14px;background:#fff}.text-control,.modal-textarea,textarea.form-control{height:auto;min-height:110px;border:1px solid #bcc7d8;border-radius:7px;padding:12px;width:100%;font-size:14px;background:#fff;resize:vertical}.help-text{font-size:12px;color:#60708a;margin-top:6px}.btn-roche,input[type=submit].btn-roche,button.btn-roche,a.btn-roche{background:#0b63b6;color:#fff!important;border:none;border-radius:8px;padding:12px 30px;min-width:150px;font-size:15px;font-weight:700;line-height:20px;text-align:center;text-decoration:none!important;cursor:pointer;display:inline-block;transition:.2s}.btn-roche:hover,input[type=submit].btn-roche:hover,button.btn-roche:hover,a.btn-roche:hover{background:#084f91;color:#fff!important}.btn-roche-secondary{background:#fff;color:#0b63b6!important;border:1px solid #0b63b6;border-radius:8px;padding:12px 30px;min-width:150px;font-size:15px;font-weight:700;text-align:center;text-decoration:none!important;cursor:pointer;display:inline-block}.btn-roche-danger,.btn-danger-roche{background:#c82333;color:#fff!important;border:none;border-radius:8px;padding:12px 30px;min-width:120px;font-size:15px;font-weight:700;text-align:center;text-decoration:none!important;cursor:pointer;display:inline-block}.btn-roche-danger:hover,.btn-danger-roche:hover{background:#a71d2a}.btn-small,.btn-grid-action{padding:8px 14px!important;min-width:86px!important;font-size:13px!important;border-radius:7px!important}.button-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.report-actions{margin-bottom:18px}.table-wrap,.report-table-wrap{width:100%;overflow-x:auto}.report-table{width:100%;border-collapse:collapse;min-width:1250px}.report-table th{background:#0b3378;color:#fff;padding:12px 10px;text-align:left;font-size:13px;white-space:nowrap}.report-table td{padding:11px 10px;border:1px solid #dde3ee;font-size:13px;vertical-align:top;background:#fff}.report-table tr:nth-child(even) td{background:#f7f9fc}.file-link{color:#0b63b6;font-weight:700;text-decoration:none}.no-data{background:#fff;border:1px solid #dce4ef;color:#60708a;border-radius:8px;padding:16px;margin-top:10px}.action-col,.action-cell{min-width:150px;width:150px;text-align:center;vertical-align:middle!important}.action-buttons{display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;padding:4px 0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.45);z-index:99999;display:flex;align-items:center;justify-content:center;padding:15px}.modal-box{background:#fff;width:100%;max-width:560px;border-radius:14px;box-shadow:0 18px 45px rgba(0,0,0,.18);overflow:hidden}.modal-header{padding:18px 24px;border-bottom:1px solid #e8edf5}.modal-header h3{margin:0;color:#071333;font-size:22px;font-weight:700}.modal-body{padding:22px 24px}.modal-body label{display:block;font-weight:700;margin-bottom:8px;color:#071333}.modal-footer{padding:18px 24px;border-top:1px solid #e8edf5;display:flex;gap:12px;justify-content:flex-end}.footer-area{text-align:center;color:#60708a;padding:20px}.sidebar-backdrop{display:none}.roche-cal-overlay{position:absolute;background:#fff;border:1px solid #cbd6e5;border-radius:10px;box-shadow:0 12px 35px rgba(18,38,63,.18);z-index:999999;padding:12px;width:292px}.roche-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.roche-cal-head button{border:none;background:#0b63b6;color:#fff;border-radius:6px;padding:5px 9px;cursor:pointer}.roche-cal-title{font-weight:700;color:#06142d}.roche-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.roche-cal-day,.roche-cal-cell{text-align:center;padding:7px 0;border-radius:6px;font-size:12px}.roche-cal-day{font-weight:700;color:#60708a}.roche-cal-cell{cursor:pointer;background:#f5f7fb}.roche-cal-cell:hover{background:#0b63b6;color:#fff}.roche-month-box{width:300px}.roche-month-select{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.searchable-wrap{position:relative}.searchable-input{width:100%;height:38px;border:1px solid #bcc7d8;border-radius:7px;padding:0 10px;margin-bottom:6px}.searchable-select{width:100%}.date-note{font-size:12px;color:#60708a;margin-top:4px}.clear{clear:both}
@media(max-width:1199px){.form-row{grid-template-columns:repeat(2,minmax(220px,1fr))}.tile-row{grid-template-columns:repeat(2,1fr)}}
@media(max-width:991px){.left-side{transform:translateX(-100%);transition:.2s}.main-body.sidebar-open .left-side{transform:translateX(0)}.right-side{margin-left:0;width:100%}.hamburger{display:inline-block}.header-area{padding:0 16px}.main-area{padding:22px 16px}.sidebar-backdrop{display:none}.main-body.sidebar-open .sidebar-backdrop{display:block;position:fixed;left:0;right:0;top:0;bottom:0;background:rgba(0,0,0,.35);z-index:999}.tile-row{grid-template-columns:1fr}.form-row,.form-row-2,.form-row-3{grid-template-columns:1fr;gap:10px}.btn-roche,input[type=submit].btn-roche,button.btn-roche,a.btn-roche,.btn-roche-secondary,.btn-roche-danger,.btn-danger-roche{width:100%;min-width:100%;box-sizing:border-box}.modal-footer{flex-direction:column}.brand,.slidebar-logo{font-size:22px}.welcome{font-size:12px}.login-box,.login-card{padding:28px 20px}.logo-text,.login-logo{font-size:34px}.report-table{min-width:1100px}}

/* =========================================================
   Roche Final Sidebar Scroll Fix
   Full menu scroll + Logout separate bottom area
   Added to keep existing working Roche design intact.
   ========================================================= */

.left-side {
    height: 100vh !important;
    max-height: 100vh !important;
    overflow: hidden !important;
}

.left-side-box {
    height: 100vh !important;
    min-height: 0 !important;
    max-height: 100vh !important;
    padding-bottom: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
}

.slidebar-logo,
.brand {
    flex: 0 0 auto !important;
}

.menu-scroll-area {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-bottom: 10px !important;
}

.menu-scroll-area .left-menu {
    margin: 0 !important;
    padding: 10px 0 !important;
}

.logout-area {
    flex: 0 0 auto !important;
    border-top: 1px solid #dfe5ee !important;
    background: #eef1f6 !important;
    z-index: 2 !important;
}

.logout-area .left-menu {
    margin: 0 !important;
    padding: 8px 0 !important;
}

.logout-area .left-menu li,
.logout-area .left-menu a {
    margin: 0 !important;
}

/* Override old absolute logout CSS */
.left-logout,
.logout-link,
.logout-area,
.logout-area .left-logout,
.logout-area .left-logout li,
.logout-area .left-logout a {
    position: static !important;
    bottom: auto !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
}

/* Keep menu text/icon stable */
.menu-scroll-area .left-menu a,
.logout-area .left-menu a {
    min-height: 50px;
}

/* Sidebar scrollbar */
.menu-scroll-area::-webkit-scrollbar {
    width: 5px;
}

.menu-scroll-area::-webkit-scrollbar-track {
    background: transparent;
}

.menu-scroll-area::-webkit-scrollbar-thumb {
    background: #b8c2d1;
    border-radius: 10px;
}

/* Firefox scrollbar */
.menu-scroll-area {
    scrollbar-width: thin;
    scrollbar-color: #b8c2d1 transparent;
}

/* Mobile responsive sidebar fix */
@media only screen and (max-width: 991px) {
    .left-side {
        height: 100vh !important;
        max-height: 100vh !important;
        overflow: hidden !important;
    }

    .left-side-box {
        height: 100vh !important;
        max-height: 100vh !important;
        padding-bottom: 0 !important;
        display: flex !important;
        flex-direction: column !important;
    }

    .menu-scroll-area {
        flex: 1 1 auto !important;
        min-height: 0 !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        padding-bottom: 12px !important;
    }

    .logout-area {
        flex: 0 0 auto !important;
        background: #eef1f6 !important;
        border-top: 1px solid #dfe5ee !important;
    }

    body.sidebar-open .sidebar-backdrop {
        display: block;
        position: fixed;
        left: 0;
        right: 0;
        top: 0;
        bottom: 0;
        background: rgba(0,0,0,.35);
        z-index: 999;
    }

    body.sidebar-open .left-side {
        transform: translateX(0);
    }
}
