body{background:#f5f7fb}
.main-content{margin-left:300px}
.container-fluid{padding:25px}
.topbar{padding-left:25px}
.sidenav .active{background:rgba(255,255,255,.18)}
.card{border-radius:16px}
.btn,.btn-large,.btn-small{border-radius:10px;text-transform:none}
.kpi{padding:22px;border-radius:18px;background:white;margin-bottom:18px}
.kpi i{font-size:36px;color:#1a73e8}
.kpi h3{margin:10px 0 0;font-weight:800}
.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a73e8,#0b57d0)}
.login-card{width:420px;border-radius:22px;padding:35px;background:#fff}
.searchbar{padding:18px;border-radius:16px;background:white;margin-bottom:18px}
.permissions-grid{overflow:auto}
.permissions-grid table td,.permissions-grid table th{text-align:center}
.permissions-grid table td:first-child,.permissions-grid table th:first-child{text-align:left;min-width:210px}
.student-card{width:860px;max-width:100%;background:#fff;border-radius:8px;box-shadow:0 8px 22px rgba(0,0,0,.18);overflow:hidden;margin:0 auto 30px}
.id-front,.id-back{position:relative;min-height:330px;background:#fff;border-bottom:18px solid #ddd}
.id-green{position:absolute;background:#34a853}
.front-left{left:0;top:0;width:180px;height:220px}
.photo-box{position:absolute;left:55px;top:80px;width:185px;height:240px;border:2px solid #ccc;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden}
.photo-box img{width:100%;height:100%;object-fit:cover}
.institution{position:absolute;left:280px;top:28px;font-size:24px;font-weight:700;line-height:1.15}
.info-box{position:absolute;left:250px;right:20px;top:135px;background:#e9eaec;padding:25px 35px;min-height:210px}
.validity{position:absolute;right:0;bottom:40px;background:#d93025;color:#111;padding:30px 45px;text-align:center;font-size:26px;font-weight:700}
.id-title{position:absolute;left:60px;bottom:30px;font-size:30px;font-weight:800}
.back-green{right:0;top:0;width:170px;height:315px}
.back-info{position:absolute;left:30px;top:45px;right:200px;background:#e9eaec;padding:25px;min-height:265px}
.barcode{height:70px;background:repeating-linear-gradient(90deg,#000 0,#000 3px,#fff 3px,#fff 8px);margin-top:18px}
.qr{width:95px;height:95px;background:#fff;margin:25px auto 10px;display:flex;align-items:center;justify-content:center;font-size:11px;color:#000;text-align:center;padding:6px}
@media(max-width:992px){.main-content{margin-left:0}.sidenav.sidenav-fixed{transform:translateX(-105%)}}



/* Login moderno inspirado no layout enviado */
.modern-login-body{
    min-height:100vh;
    margin:0;
    overflow:hidden;
    background:#ffffff;
    font-family:'Roboto',Arial,sans-serif;
    position:relative;
}
.login-shape{
    position:absolute;
    background:#0b83ee;
    filter:drop-shadow(0 8px 14px rgba(0,80,180,.25));
    z-index:1;
}
.shape-one{
    width:390px;
    height:390px;
    border-radius:0 0 50% 0;
    left:-90px;
    top:-80px;
}
.shape-two{
    width:360px;
    height:290px;
    border-radius:70px;
    transform:rotate(-28deg);
    right:110px;
    top:210px;
}
.shape-three{
    width:280px;
    height:280px;
    border-radius:70px;
    transform:rotate(-28deg);
    left:150px;
    bottom:-110px;
}
.modern-login-wrapper{
    position:relative;
    z-index:2;
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:70px;
    padding:40px;
}
.login-card-modern{
    width:470px;
    min-height:540px;
    background:#fff;
    border-radius:10px;
    padding:54px 58px 45px;
    box-shadow:0 8px 24px rgba(0,0,0,.18);
}
.login-header{
    text-align:center;
    margin-bottom:52px;
}
.login-header h4{
    font-size:24px;
    font-weight:800;
    color:#444;
    margin:0 0 42px;
}
.login-header h4 span{
    color:#0b83ee;
}
.login-header p{
    color:#9a9a9a;
    font-size:14px;
    margin:0;
}
.login-input-group{
    margin-bottom:42px;
}
.login-input-group label{
    color:#595959;
    font-size:14px;
    display:block;
    margin-bottom:4px;
}
.login-input-line{
    display:flex;
    align-items:center;
    border-bottom:2px solid #cfcfcf;
}
.login-input-line input{
    border:none!important;
    box-shadow:none!important;
    margin:0!important;
    height:38px!important;
    color:#666;
    font-size:15px!important;
    flex:1;
}
.login-input-line i{
    color:#777;
    cursor:pointer;
    font-size:22px;
}
.login-btn-modern{
    width:100%;
    height:48px;
    border:none;
    border-radius:4px;
    background:#0b83ee;
    color:white;
    font-weight:800;
    letter-spacing:.4px;
    margin-top:18px;
    cursor:pointer;
    transition:.2s;
}
.login-btn-modern:hover{
    background:#056fd0;
    transform:translateY(-1px);
    box-shadow:0 8px 18px rgba(11,131,238,.28);
}
.login-callout{
    width:430px;
    min-height:260px;
    background:#0b83ee;
    color:white;
    border-radius:78px;
    transform:rotate(-28deg);
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    box-shadow:0 10px 18px rgba(0,80,180,.2);
}
.login-callout h3,
.login-callout p{
    transform:rotate(28deg);
    text-align:center;
}
.login-callout h3{
    font-size:26px;
    line-height:1.25;
    font-weight:900;
    margin:0;
}
.login-callout p{
    margin:20px 0 0;
    opacity:.92;
    font-size:15px;
}
@media(max-width:980px){
    .modern-login-wrapper{
        gap:25px;
        padding:25px;
    }
    .login-callout{
        display:none;
    }
    .shape-two{
        right:-180px;
    }
}
@media(max-width:560px){
    .modern-login-body{
        overflow:auto;
    }
    .modern-login-wrapper{
        min-height:100vh;
        padding:22px;
    }
    .login-card-modern{
        width:100%;
        min-height:auto;
        padding:38px 28px 34px;
    }
    .login-header{
        margin-bottom:35px;
    }
    .login-header h4{
        margin-bottom:28px;
    }
    .shape-one{
        width:280px;
        height:280px;
    }
    .shape-three{
        left:40px;
    }
}

/* PATCH_JURIDICO_VISUAL */
.lgpd-box{
    background:#eef6ff;
    border:1px solid #cfe5ff;
    color:#1b4d89;
    border-radius:12px;
    padding:12px 14px;
    display:flex;
    gap:10px;
    font-size:12px;
    line-height:1.45;
    margin:-25px 0 28px;
}
.lgpd-box i{color:#0b83ee}
.lgpd-box span{font-weight:700}
.crm-timeline{border-left:4px solid #1a73e8;margin-left:14px;padding-left:18px}
.crm-event{background:#fff;border:1px solid #e3e9f5;border-radius:14px;padding:14px;margin:0 0 14px;box-shadow:0 4px 12px rgba(0,0,0,.04)}
.crm-event small{color:#6b7280}
.modern-id-card{
    width:920px;max-width:100%;margin:25px auto;background:#fff;border-radius:28px;overflow:hidden;
    box-shadow:0 25px 60px rgba(10,35,80,.18);font-family:Arial,sans-serif;border:1px solid #e6eef8;
}
.modern-id-top{height:115px;background:linear-gradient(135deg,#0b83ee,#0047b3);color:#fff;padding:26px 34px;display:flex;justify-content:space-between;align-items:center}
.modern-id-brand strong{font-size:28px;display:block;letter-spacing:.5px}.modern-id-brand span{opacity:.9}
.modern-id-badge{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.35);padding:10px 16px;border-radius:999px;font-weight:700}
.modern-id-body{display:grid;grid-template-columns:220px 1fr 190px;gap:24px;padding:30px 34px;align-items:center}
.modern-photo{width:190px;height:230px;border-radius:24px;background:#f0f5ff;border:6px solid #fff;box-shadow:0 8px 20px rgba(0,0,0,.12);display:flex;align-items:center;justify-content:center;overflow:hidden}
.modern-photo img{width:100%;height:100%;object-fit:cover}.modern-photo i{font-size:90px;color:#9ab9e8}
.modern-info h2{font-size:30px;margin:0 0 10px;color:#17233f}.modern-info .course{font-size:22px;color:#0b57d0;font-weight:800;margin-bottom:22px}
.modern-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modern-info-grid div{background:#f7faff;border:1px solid #e1ecfb;border-radius:14px;padding:12px}
.modern-info-grid small{display:block;color:#667085;font-size:12px}.modern-info-grid b{font-size:16px;color:#17233f}
.modern-qr{background:#f7faff;border-radius:20px;padding:18px;text-align:center}.modern-qr .fakeqr{width:130px;height:130px;margin:auto;background:repeating-linear-gradient(45deg,#111 0,#111 4px,#fff 4px,#fff 8px);border:12px solid #fff;box-shadow:0 0 0 1px #d8e3f3}.modern-qr b{display:block;margin-top:14px;color:#0b57d0}
.modern-id-footer{display:flex;justify-content:space-between;align-items:center;background:#f3f7fc;padding:18px 34px;color:#4b5563}.modern-valid{background:#d93025;color:#fff;border-radius:16px;padding:12px 22px;text-align:center;font-weight:800}
@media(max-width:850px){.modern-id-body{grid-template-columns:1fr;text-align:center}.modern-photo{margin:auto}.modern-info-grid{grid-template-columns:1fr}.modern-id-top,.modern-id-footer{display:block;text-align:center}.modern-id-badge{display:inline-block;margin-top:12px}}

/* PATCH_MONITORAMENTO_VISUAL */
.monitor-card{border-radius:20px}
.monitor-list{display:flex;flex-direction:column;gap:14px}
.monitor-item{display:flex;gap:16px;background:#f8fbff;border:1px solid #e3edf9;border-radius:18px;padding:16px;box-shadow:0 3px 10px rgba(20,60,100,.04)}
.monitor-icon{width:44px;height:44px;border-radius:14px;background:#e8f1ff;color:#0b83ee;display:flex;align-items:center;justify-content:center;flex:none}
.monitor-body{flex:1;min-width:0}
.monitor-head{display:flex;justify-content:space-between;gap:10px;align-items:center}
.monitor-head strong{font-size:16px;color:#17233f}
.monitor-head span{font-size:13px;color:#64748b}
.monitor-body p{margin:8px 0;color:#334155}
.monitor-meta{display:flex;gap:18px;flex-wrap:wrap;color:#475569;font-size:13px}
.monitor-item details{margin-top:8px;color:#64748b}
.copy-link-wrap{display:flex;gap:8px;align-items:center}
.copy-link-wrap input{min-width:320px}
.student-course-card{border-radius:18px;border:1px solid #e3edf9;background:#fff;margin-bottom:16px}
.progress-shell{height:12px;background:#e5edf8;border-radius:999px;overflow:hidden}
.progress-bar-custom{height:12px;background:#0b83ee;border-radius:999px}
.course-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.lesson-card{border:1px solid #e3edf9;border-radius:14px;padding:14px;margin:10px 0;background:#f8fbff}
@media(max-width:700px){.monitor-head,.monitor-meta{display:block}.copy-link-wrap{display:block}.copy-link-wrap input{min-width:100%;width:100%}}

/* PATCH_LOGIN_COMPACTO_MENU_ALUNO */
.login-card-modern{
    min-height:auto!important;
    padding:34px 46px 32px!important;
}
.login-header{
    margin-bottom:24px!important;
}
.login-header h4{
    margin-bottom:18px!important;
}
.lgpd-box{
    margin:0 0 18px!important;
    padding:10px 12px!important;
    font-size:12px!important;
}
.login-input-group{
    margin-bottom:24px!important;
}
.login-btn-modern{
    margin-top:8px!important;
}
.modern-login-wrapper{
    align-items:center!important;
}
@media(max-height:760px){
    .modern-login-wrapper{padding:18px!important}
    .login-card-modern{padding:26px 38px 24px!important}
    .login-header h4{font-size:22px!important}
    .login-input-group{margin-bottom:18px!important}
    .lgpd-box{font-size:11px!important}
}
