
/* ========================================= */
/* LOGIN PAGE ONLY                        */
/* ========================================= */

html,
body{
    margin:0;
    padding:0;

    width:100%;
    min-height:100vh;

    font-family:Arial, Helvetica, sans-serif;

    background:
        radial-gradient(circle at top left, rgba(255,193,7,.18), transparent 28%),
        #f4f6f9;
}

.tplogin-page-wrapper{

    width:100%;

    min-height:100vh;

    display:flex;

    align-items:center;

    justify-content:center;

    padding:32px 18px;
}

        .tplogin-card-container{
            width:100%;
            max-width:980px;
            min-height:560px;
            background:#ffffff;
            border-radius:28px;
            overflow:hidden;
            box-shadow:0 24px 70px rgba(15,23,42,.12);
            border:1px solid rgba(15,23,42,.06);
            display:grid;
            grid-template-columns:1.1fr .9fr;
        }

        .tplogin-brand-side{
            position:relative;
            padding:56px;
            display:flex;
            flex-direction:column;
            align-items:center;
            justify-content:center;
            background:
                radial-gradient(circle at top left, rgba(255,193,7,.22), transparent 34%),
                linear-gradient(135deg,#ffffff,#fffaf0);
        }

        .tplogin-brand-side::before{
            content:"";
            position:absolute;
            width:180px;
            height:180px;
            border-radius:50%;
            background:rgba(255,193,7,.18);
            top:-70px;
            left:-70px;
        }

        .tplogin-brand-side::after{
            content:"";
            position:absolute;
            width:140px;
            height:140px;
            border-radius:50%;
            background:rgba(17,24,39,.05);
            bottom:-55px;
            right:-45px;
        }

        .tplogin-brand-logo{
            width:330px;
            max-width:90%;
            object-fit:contain;
            position:relative;
            z-index:1;
        }

        .tplogin-brand-text{
            margin-top:24px;
            text-align:center;
            position:relative;
            z-index:1;
        }

        .tplogin-brand-text h3{
            font-size:26px;
            font-weight:900;
            margin:0 0 8px;
            color:#212529;
        }

        .tplogin-brand-text p{
            color:#6c757d;
            margin:0;
            font-size:15px;
            line-height:1.5;
        }

        .tplogin-form-side{
            padding:56px 52px;
            display:flex;
            align-items:center;
            justify-content:center;
        }

        .tplogin-form-inner{
            width:100%;
            max-width:360px;
        }

        .tplogin-heading{
            text-align:center;
            margin-bottom:28px;
        }

        .tplogin-heading h2{
            font-size:30px;
            font-weight:900;
            margin:0 0 8px;
            color:#212529;
        }

        .tplogin-heading p{
            color:#6c757d;
            margin:0;
        }

        .tplogin-alert-status{
            background:#e7f7ee;
            color:#15803d;
            border-radius:14px;
            padding:12px 14px;
            font-size:14px;
            font-weight:700;
            margin-bottom:18px;
        }

        .tplogin-form-group{
            margin-bottom:18px;
        }

        .tplogin-form-label{
            font-size:14px;
            font-weight:800;
            color:#343a40;
            margin-bottom:8px;
            display:block;
        }

        .tplogin-input-wrap{
            position:relative;
        }

        .tplogin-input-icon{
            position:absolute;
            left:18px;
            top:50%;
            transform:translateY(-50%);
            color:#6c757d;
            z-index:2;
        }

        .tplogin-input-field{
            width:100%;
            height:52px;
            border-radius:999px;
            border:1px solid #e5e7eb;
            background:#f8f9fa;
            padding:0 18px 0 48px;
            outline:none;
            font-size:15px;
            color:#212529;
            transition:all .2s ease;
        }

        .tplogin-input-field:focus{
            border-color:#ffc107;
            background:#ffffff;
            box-shadow:0 0 0 4px rgba(255,193,7,.16);
        }

        .tplogin-password-field{
            padding-right:54px;
        }

        .tplogin-password-toggle-btn{
            position:absolute;
            right:15px;
            top:50%;
            transform:translateY(-50%);
            border:0;
            background:transparent;
            color:#6c757d;
            cursor:pointer;
            padding:6px;
            z-index:3;
        }

        .tplogin-password-toggle-btn:hover{
            color:#ff9800;
        }

        .tplogin-remember-row{
            display:flex;
            align-items:center;
            justify-content:space-between;
            gap:12px;
            margin:12px 0 22px;
            flex-wrap:wrap;
        }

        .tplogin-remember-label{
            display:inline-flex;
            align-items:center;
            gap:8px;
            font-size:14px;
            color:#495057;
            margin:0;
        }

        .tplogin-remember-label input{
            width:16px;
            height:16px;
            accent-color:#ffc107;
        }

        .tplogin-submit-btn{
            width:100%;
            height:52px;
            border:0;
            border-radius:999px;
            background:linear-gradient(135deg,#ffc107,#ff9800);
            color:#212529;
            font-weight:900;
            letter-spacing:.3px;
            box-shadow:0 14px 28px rgba(255,193,7,.28);
            transition:all .2s ease;
            cursor:pointer;
        }

        .tplogin-submit-btn:hover{
            transform:translateY(-2px);
            box-shadow:0 18px 34px rgba(255,193,7,.36);
        }

        .tplogin-register-box{
            text-align:center;
            margin-top:24px;
        }

        .tplogin-register-box p{
            margin:0 0 10px;
            color:#6c757d;
            font-weight:700;
        }

        .tplogin-register-btn{
            width:100%;
            height:50px;
            border-radius:999px;
            border:1px solid #ffc107;
            background:#fff8e1;
            color:#212529;
            font-weight:900;
            display:inline-flex;
            align-items:center;
            justify-content:center;
            text-decoration:none;
            transition:all .2s ease;
        }

        .tplogin-register-btn:hover{
            background:#ffc107;
            color:#212529;
        }

        .tplogin-error-text{
            margin-top:8px;
            font-size:13px;
            color:#dc3545;
            font-weight:700;
        }

       /* NOTICE MODAL */

.tplogin-notice-overlay{
    position:fixed;
    inset:0;

    background:rgba(15,23,42,.72);

    backdrop-filter:blur(6px);

    z-index:99999;

    display:flex;
    align-items:center;
    justify-content:center;

    padding:20px;

    overflow-y:auto;

    animation:tploginNoticeFade .25s ease;
}

.tplogin-notice-modal{
    width:100%;
    max-width:560px;

    background:#ffffff;

    border-radius:28px;

    padding:34px 30px;

    box-shadow:0 30px 80px rgba(0,0,0,.25);

    position:relative;

    overflow-y:auto;

    max-height:95vh;
}

.tplogin-notice-modal::before{
    content:"";
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:6px;

    background:linear-gradient(135deg,#ffc107,#ff9800);
}

.tplogin-notice-header{
    text-align:center;
    margin-bottom:22px;
}

.tplogin-notice-icon{
    width:84px;
    height:84px;

    border-radius:24px;

    background:linear-gradient(135deg,#ffc107,#ff9800);

    display:flex;
    align-items:center;
    justify-content:center;

    margin:0 auto 18px;

    box-shadow:0 18px 36px rgba(255,193,7,.28);
}

.tplogin-notice-icon i{
    font-size:36px;
    color:#111827;
}

.tplogin-notice-header h2{
    margin:0;

    font-size:28px;
    font-weight:900;

    color:#111827;
}

.tplogin-notice-content{
    text-align:center;
}

.tplogin-notice-content p{
    margin:0 0 16px;

    line-height:1.8;

    color:#4b5563;

    font-size:15px;
}

.tplogin-notice-whatsapp{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;

    min-height:56px;

    padding:0 26px;

    border-radius:999px;

    background:#25d366;

    color:#ffffff;

    text-decoration:none;

    font-weight:900;
    font-size:17px;

    margin:10px 0 18px;

    box-shadow:0 16px 34px rgba(37,211,102,.26);

    transition:all .2s ease;
}

.tplogin-notice-whatsapp:hover{
    transform:translateY(-2px);
    color:#ffffff;
}

        .forgot-link {
            color: #6c757d;
            font-size: 14px;
            text-decoration: none;
            font-weight: 700;
        }

        .forgot-link:hover {
            color: #ff9800;
        }


.tplogin-notice-list{
    margin:0 0 18px;

    padding-left:20px;

    text-align:left;

    display:inline-block;
}

.tplogin-notice-list li{
    margin-bottom:8px;

    color:#374151;

    font-weight:700;
}

.tplogin-notice-apology{
    font-weight:800;
    color:#dc2626 !important;
}

.tplogin-notice-close-btn{
    width:100%;
    height:56px;

    border:0;

    border-radius:999px;

    background:linear-gradient(135deg,#ffc107,#ff9800);

    color:#111827;

    font-size:15px;
    font-weight:900;

    cursor:pointer;

    transition:all .2s ease;

    margin-top:8px;
}

.tplogin-notice-close-btn:hover{
    transform:translateY(-2px);
}

@keyframes tploginNoticeFade{

    from{
        opacity:0;
    }

    to{
        opacity:1;
    }
}
/* RESPONSIVE FIX */

@media (max-width:900px){

    .tplogin-card-container{
        grid-template-columns:1fr;
        max-width:520px;
        min-height:auto;
    }

    .tplogin-brand-side{
        padding:40px 28px 24px;
    }

    .tplogin-brand-logo{
        width:210px;
    }

    .tplogin-brand-text{
        display:none;
    }

    .tplogin-form-side{
        padding:34px 30px;
    }

}

/* MOBILE */

@media (max-width:480px){

    html,
    body{
        width:100%;
        min-height:100vh;
        overflow-x:hidden;}

     .tplogin-page-wrapper{

        width:100%;

        min-height:100vh;

        display:flex;

        align-items:center;

        justify-content:center;

        padding:16px 12px;
    }

    .tplogin-card-container{

        width:100%;

        max-width:390px;

        margin:0 auto;

        display:flex;

        flex-direction:column;

        justify-content:center;
    }

    .tplogin-brand-side{

        width:100%;

        min-height:200px;

        padding:28px 18px 20px;

        display:flex;

        align-items:center;

        justify-content:center;
    }

    .tplogin-brand-side::before{

        width:140px;
        height:140px;

        top:-55px;
        left:-55px;
    }

    .tplogin-brand-side::after{

        width:110px;
        height:110px;

        bottom:-45px;
        right:-45px;
    }

    .tplogin-brand-logo{

        width:135px;

        max-width:100%;
    }

    .tplogin-brand-text{
        display:none;
    }

    .tplogin-form-side{

        width:100%;

        padding:28px 20px 30px;
    }

    .tplogin-form-inner{

        width:100%;

        max-width:100%;
    }

    .tplogin-heading{

        margin-bottom:24px;
    }

    .tplogin-heading h2{

        font-size:28px;

        line-height:1.2;
    }

    .tplogin-heading p{

        font-size:15px;
    }

    .tplogin-form-group{

        margin-bottom:18px;
    }

    .tplogin-form-label{

        font-size:14px;
    }

    .tplogin-input-field{

        width:100%;

        height:52px;

        font-size:14px;

        padding-left:46px;
    }

    .tplogin-input-icon{

        left:16px;
    }

    .tplogin-password-toggle-btn{

        right:14px;
    }

    .tplogin-submit-btn,
    .tplogin-register-btn{

        width:100%;

        height:52px;

        font-size:15px;
    }

    .tplogin-register-box{

        margin-top:22px;
    }

    .tplogin-register-box p{

        font-size:14px;
    }

    .tplogin-remember-row{

        flex-direction:column;

        align-items:flex-start;

        gap:10px;

        margin:14px 0 22px;
    }

    /* NOTICE MODAL */

    .tplogin-notice-overlay{

        position:fixed;

        inset:0;

        display:flex;

        align-items:center;

        justify-content:center;

        padding:10px;

        overflow-y:auto;
    }

    .tplogin-notice-modal{

        width:100%;

        max-width:380px;

        max-height:90vh;

        overflow-y:auto;

        padding:24px 18px;

        border-radius:22px;
    }

    .tplogin-notice-icon{

        width:70px;

        height:70px;

        border-radius:20px;
    }

    .tplogin-notice-icon i{

        font-size:30px;
    }

    .tplogin-notice-header h2{

        font-size:24px;

        line-height:1.3;
    }

    .tplogin-notice-content p{

        font-size:14px;

        line-height:1.8;
    }

    .tplogin-notice-whatsapp{

        width:100%;

        justify-content:center;

        font-size:14px;

        padding:0 16px;
    }

    .tplogin-notice-close-btn{

        height:52px;

        font-size:14px;
    }

}

/* ========================================= */
/* REGISTER PAGE ONLY                        */
/* ========================================= */
        html,
        body{
            min-height:100%;
        }

        body.tpregister-page-body{
            background:
                radial-gradient(circle at top left, rgba(255,193,7,.22), transparent 28%),
                radial-gradient(circle at bottom right, rgba(255,152,0,.16), transparent 28%),
                #f4f6f9;
                        min-height:100vh;

    display:flex;
    align-items:center;
    justify-content:center;

    padding:40px 14px;
        }

        .tpregister-wrapper{
            width:100%;
            max-width:980px;
            margin:0 auto;
        }

        .tpregister-card{
            background:#ffffff;
            border:0;
            border-radius:28px;
            overflow:hidden;
            box-shadow:0 28px 70px rgba(15,23,42,.12);
        }

        .tpregister-layout{
            display:grid;
            grid-template-columns:0.9fr 1.1fr;
            min-height:650px;
        }

        .tpregister-brand-panel{
            background:
                radial-gradient(circle at top left, rgba(255,255,255,.38), transparent 30%),
                linear-gradient(135deg,#ffc107,#ff9800);
            padding:36px;
            color:#111827;
            position:relative;
            overflow:hidden;
        }

        .tpregister-brand-panel::after{
            content:"";
            position:absolute;
            width:220px;
            height:220px;
            border-radius:50%;
            background:rgba(255,255,255,.20);
            right:-90px;
            bottom:-80px;
        }

        .tpregister-logo-box{
            width:82px;
            height:82px;
            border-radius:26px;
            background:rgba(255,255,255,.42);
            display:flex;
            align-items:center;
            justify-content:center;
            margin-bottom:26px;
            box-shadow:0 18px 36px rgba(15,23,42,.12);
        }

        .tpregister-logo-box img{
            width:62px;
            height:62px;
            object-fit:contain;
        }

        .tpregister-brand-panel h1{
            font-size:34px;
            font-weight:900;
            line-height:1.1;
            margin-bottom:14px;
        }

        .tpregister-brand-panel p{
            font-size:15px;
            line-height:1.6;
            font-weight:700;
            opacity:.82;
            max-width:320px;
        }

        .tpregister-feature-list{
            margin-top:34px;
            position:relative;
            z-index:2;
        }

        .tpregister-feature-item{
            display:flex;
            align-items:center;
            gap:12px;
            background:rgba(255,255,255,.34);
            border-radius:18px;
            padding:13px 14px;
            margin-bottom:12px;
            font-weight:800;
            font-size:13px;
        }

        .tpregister-feature-item i{
            width:34px;
            height:34px;
            border-radius:12px;
            background:#111827;
            color:#ffffff;
            display:flex;
            align-items:center;
            justify-content:center;
        }

        .tpregister-form-panel{
            padding:36px;
        }

        .tpregister-small-title{
            color:#6b7280;
            font-weight:800;
            font-size:13px;
            margin-bottom:2px;
        }

        .tpregister-main-title{
            color:#111827;
            font-size:28px;
            font-weight:900;
            margin-bottom:6px;
        }

        .tpregister-subtitle{
            color:#6b7280;
            font-size:13px;
            font-weight:700;
            margin-bottom:24px;
        }

        .tpregister-alert-box{
            border:0;
            border-radius:16px;
            padding:14px 16px;
            font-size:13px;
            box-shadow:0 8px 20px rgba(15,23,42,.06);
        }

        .tpregister-section-label{
            display:flex;
            align-items:center;
            gap:10px;
            color:#111827;
            font-size:14px;
            font-weight:900;
            margin:22px 0 14px;
        }

        .tpregister-section-label span{
            width:34px;
            height:34px;
            border-radius:12px;
            background:#fff3cd;
            color:#ff9800;
            display:flex;
            align-items:center;
            justify-content:center;
        }

        .tpregister-input-group{
            margin-bottom:14px;
        }

        .tpregister-input{
            height:46px;
            border-radius:14px 0 0 14px !important;
            border:1px solid #d1d5db;
            font-size:14px;
        }

        .tpregister-select{
            height:46px;
            border-radius:14px !important;
            border:1px solid #d1d5db;
            font-size:14px;
        }

        .tpregister-input:focus,
        .tpregister-select:focus{
            border-color:#ffc107;
            box-shadow:0 0 0 .18rem rgba(255,193,7,.18);
        }

        .tpregister-input.is-valid{
            border-color:#16a34a !important;
        }

        .tpregister-input.is-invalid{
            border-color:#dc2626 !important;
        }

        .tpregister-input-icon-box{
            width:46px;
            justify-content:center;
            border-radius:0 14px 14px 0 !important;
            background:#f8f9fa;
            color:#6b7280;
            border:1px solid #d1d5db;
            border-left:0;
            display:flex;
            align-items:center;
        }

        .tpregister-password-btn{
            width:46px;
            height:46px;
            border-radius:0 14px 14px 0 !important;
            border:1px solid #d1d5db;
            border-left:0;
            background:#f8f9fa;
            color:#6b7280;
        }

        .tpregister-password-note{
            background:#fff8e1;
            border:1px solid rgba(255,193,7,.34);
            color:#7c5700;
            font-size:12px;
            font-weight:800;
            border-radius:14px;
            padding:12px 14px;
            margin-bottom:14px;
        }

        .tpregister-submit-btn{
            height:48px;
            border-radius:999px;
            border:0;
            background:linear-gradient(135deg,#ffc107,#ff9800);
            color:#111827;
            font-size:14px;
            font-weight:900;
            box-shadow:0 12px 26px rgba(255,193,7,.28);
            transition:all .2s ease;
        }

        .tpregister-submit-btn:hover{
            transform:translateY(-2px);
            color:#111827;
            box-shadow:0 16px 34px rgba(255,193,7,.34);
        }

        .tpregister-submit-btn:disabled{
            opacity:.55;
            cursor:not-allowed;
            transform:none;
        }

        .tpregister-login-link-box{
            margin-top:16px;
            text-align:center;
        }

        .tpregister-login-link-box p{
            color:#6b7280;
            font-size:13px;
            font-weight:800;
            margin-bottom:10px;
        }

        .tpregister-login-btn{
            height:44px;
            border-radius:999px;
            font-weight:900;
            color:#111827;
            background:#ffffff;
            border:1px solid #d1d5db;
        }

        .tpregister-login-btn:hover{
            background:#f8f9fa;
            color:#111827;
        }

        .tpregister-invalid-feedback{
            font-size:12px;
            font-weight:800;
            display:block;
        }

        .tpregister-duplicate-message{
            display:block;
            margin-top:-6px;
            margin-bottom:10px;
            font-size:12px;
            font-weight:800;
        }

        .tpregister-danger-text{
            color:#dc2626 !important;
        }

        .tpregister-success-text{
            color:#15803d !important;
        }

        @media (max-width:767.98px){

            body.tpregister-page-body{
                padding:14px;
                display:block !important;
            }

            .tpregister-layout{
                grid-template-columns:1fr;
            }

            .tpregister-brand-panel{
                padding:28px;
            }

            .tpregister-brand-panel h1{
                font-size:28px;
            }

            .tpregister-form-panel{
                padding:26px 20px;
            }

            .tpregister-main-title{
                font-size:24px;
            }

            .tpregister-feature-list{
                margin-top:22px;
            }
        }


        /* ========================================= */
/* FORGOT-PASSWORD PAGE ONLY                        */
/* ========================================= */

        *{
            box-sizing:border-box;
        }

        html,
        body{
            margin:0;
            padding:0;
            width:100%;
            min-height:100%;
            font-family:Arial, Helvetica, sans-serif;
            background:
                radial-gradient(circle at top left, rgba(255,193,7,.18), transparent 28%),
                #f4f6f9;
        }

        .tpforgot-wrapper{
            min-height:100vh;
            width:100%;
            display:flex;
            align-items:center;
            justify-content:center;
            padding:32px 18px;
        }

        .tpforgot-card{
            width:100%;
            max-width:920px;
            min-height:540px;
            background:#ffffff;
            border-radius:28px;
            overflow:hidden;
            box-shadow:0 24px 70px rgba(15,23,42,.12);
            border:1px solid rgba(15,23,42,.06);
            display:grid;
            grid-template-columns:1fr 1fr;
        }

        .tpforgot-left-panel{
            position:relative;
            padding:56px;
            display:flex;
            flex-direction:column;
            align-items:center;
            justify-content:center;
            background:
                radial-gradient(circle at top left, rgba(255,193,7,.22), transparent 34%),
                linear-gradient(135deg,#ffffff,#fffaf0);
        }

        .tpforgot-left-panel::before{
            content:"";
            position:absolute;
            width:180px;
            height:180px;
            border-radius:50%;
            background:rgba(255,193,7,.18);
            top:-70px;
            left:-70px;
        }

        .tpforgot-left-panel::after{
            content:"";
            position:absolute;
            width:140px;
            height:140px;
            border-radius:50%;
            background:rgba(17,24,39,.05);
            bottom:-55px;
            right:-45px;
        }

        .tpforgot-logo{
            width:300px;
            max-width:90%;
            object-fit:contain;
            position:relative;
            z-index:1;
        }

        .tpforgot-brand-text{
            margin-top:24px;
            text-align:center;
            position:relative;
            z-index:1;
        }

        .tpforgot-brand-text h3{
            font-size:26px;
            font-weight:900;
            margin:0 0 8px;
            color:#212529;
        }

        .tpforgot-brand-text p{
            color:#6c757d;
            margin:0;
            font-size:15px;
            line-height:1.5;
        }

        .tpforgot-right-panel{
            padding:56px 52px;
            display:flex;
            align-items:center;
            justify-content:center;
        }

        .tpforgot-inner{
            width:100%;
            max-width:360px;
        }

        .tpforgot-header{
            text-align:center;
            margin-bottom:28px;
        }

        .tpforgot-header h2{
            font-size:30px;
            font-weight:900;
            margin:0 0 8px;
            color:#212529;
        }

        .tpforgot-header p{
            color:#6c757d;
            margin:0;
        }

        .tpforgot-alert{
            background:#e7f7ee;
            color:#15803d;
            border-radius:14px;
            padding:12px 14px;
            font-size:14px;
            font-weight:700;
            margin-bottom:18px;
        }

        .tpforgot-group{
            margin-bottom:18px;
        }

        .tpforgot-label{
            font-size:14px;
            font-weight:800;
            color:#343a40;
            margin-bottom:8px;
            display:block;
        }

        .tpforgot-input-wrap{
            position:relative;
        }

        .tpforgot-input-icon{
            position:absolute;
            left:18px;
            top:50%;
            transform:translateY(-50%);
            color:#6c757d;
            z-index:2;
        }

        .tpforgot-input-field{
            width:100%;
            height:52px;
            border-radius:999px;
            border:1px solid #e5e7eb;
            background:#f8f9fa;
            padding:0 18px 0 48px;
            outline:none;
            font-size:15px;
            color:#212529;
            transition:all .2s ease;
        }

        .tpforgot-input-field:focus{
            border-color:#ffc107;
            background:#ffffff;
            box-shadow:0 0 0 4px rgba(255,193,7,.16);
        }

        .tpforgot-error{
            margin-top:8px;
            font-size:13px;
            color:#dc3545;
            font-weight:700;
        }

        .tpforgot-submit-btn{
            width:100%;
            height:52px;
            border:0;
            border-radius:999px;
            background:linear-gradient(135deg,#ffc107,#ff9800);
            color:#212529;
            font-weight:900;
            letter-spacing:.3px;
            box-shadow:0 14px 28px rgba(255,193,7,.28);
            transition:all .2s ease;
            cursor:pointer;
        }

        .tpforgot-submit-btn:hover{
            transform:translateY(-2px);
            box-shadow:0 18px 34px rgba(255,193,7,.36);
        }

        .tpforgot-back-btn{
            width:100%;
            height:50px;
            border-radius:999px;
            border:1px solid #ffc107;
            background:#fff8e1;
            color:#212529;
            font-weight:900;
            display:inline-flex;
            align-items:center;
            justify-content:center;
            text-decoration:none;
            transition:all .2s ease;
            margin-top:16px;
        }

        .tpforgot-back-btn:hover{
            background:#ffc107;
            color:#212529;
        }

        @media (max-width:900px){

            .tpforgot-card{
                grid-template-columns:1fr;
                max-width:520px;
            }

            .tpforgot-left-panel{
                padding:38px 32px 24px;
            }

            .tpforgot-logo{
                width:220px;
            }

            .tpforgot-brand-text{
                display:none;
            }

            .tpforgot-right-panel{
                padding:32px;
            }
        }

        @media (max-width:480px){

            .tpforgot-wrapper{
                padding:18px 14px;
                align-items:flex-start;
            }

            .tpforgot-card{
                border-radius:24px;
            }

            .tpforgot-left-panel{
                padding:30px 22px 16px;
            }

            .tpforgot-logo{
                width:180px;
            }

            .tpforgot-right-panel{
                padding:26px 22px 30px;
            }

            .tpforgot-header h2{
                font-size:26px;
            }
        }

           /* ========================================= */
/* RESET-PASSWORD PAGE ONLY                        */
/* ========================================= */
        *{
            box-sizing:border-box;
        }

        html,
        body{
            margin:0;
            padding:0;
            width:100%;
            min-height:100%;
            font-family:Arial, Helvetica, sans-serif;
            background:
                radial-gradient(circle at top left, rgba(255,193,7,.18), transparent 28%),
                #f4f6f9;
        }

        .tpreset-wrapper{
            min-height:100vh;
            width:100%;
            display:flex;
            align-items:center;
            justify-content:center;
            padding:32px 18px;
        }

        .tpreset-card{
            width:100%;
            max-width:980px;
            min-height:580px;
            background:#ffffff;
            border-radius:28px;
            overflow:hidden;
            box-shadow:0 24px 70px rgba(15,23,42,.12);
            border:1px solid rgba(15,23,42,.06);
            display:grid;
            grid-template-columns:1fr 1fr;
        }

        .tpreset-left-panel{
            position:relative;
            padding:56px;
            display:flex;
            flex-direction:column;
            align-items:center;
            justify-content:center;
            background:
                radial-gradient(circle at top left, rgba(255,193,7,.22), transparent 34%),
                linear-gradient(135deg,#ffffff,#fffaf0);
        }

        .tpreset-left-panel::before{
            content:"";
            position:absolute;
            width:180px;
            height:180px;
            border-radius:50%;
            background:rgba(255,193,7,.18);
            top:-70px;
            left:-70px;
        }

        .tpreset-left-panel::after{
            content:"";
            position:absolute;
            width:140px;
            height:140px;
            border-radius:50%;
            background:rgba(17,24,39,.05);
            bottom:-55px;
            right:-45px;
        }

        .tpreset-logo{
            width:300px;
            max-width:90%;
            object-fit:contain;
            position:relative;
            z-index:1;
        }

        .tpreset-brand-text{
            margin-top:24px;
            text-align:center;
            position:relative;
            z-index:1;
        }

        .tpreset-brand-text h3{
            font-size:26px;
            font-weight:900;
            margin:0 0 8px;
            color:#212529;
        }

        .tpreset-brand-text p{
            color:#6c757d;
            margin:0;
            font-size:15px;
            line-height:1.5;
        }

        .tpreset-right-panel{
            padding:56px 52px;
            display:flex;
            align-items:center;
            justify-content:center;
        }

        .tpreset-inner{
            width:100%;
            max-width:360px;
        }

        .tpreset-header{
            text-align:center;
            margin-bottom:28px;
        }

        .tpreset-header h2{
            font-size:30px;
            font-weight:900;
            margin:0 0 8px;
            color:#212529;
        }

        .tpreset-header p{
            color:#6c757d;
            margin:0;
        }

        .tpreset-group{
            margin-bottom:18px;
        }

        .tpreset-label{
            font-size:14px;
            font-weight:800;
            color:#343a40;
            margin-bottom:8px;
            display:block;
        }

        .tpreset-input-wrap{
            position:relative;
        }

        .tpreset-input-icon{
            position:absolute;
            left:18px;
            top:50%;
            transform:translateY(-50%);
            color:#6c757d;
            z-index:2;
        }

        .tpreset-input-field{
            width:100%;
            height:52px;
            border-radius:999px;
            border:1px solid #e5e7eb;
            background:#f8f9fa;
            padding:0 52px 0 48px;
            outline:none;
            font-size:15px;
            color:#212529;
            transition:all .2s ease;
        }

        .tpreset-input-field:focus{
            border-color:#ffc107;
            background:#ffffff;
            box-shadow:0 0 0 4px rgba(255,193,7,.16);
        }

        .tpreset-error{
            margin-top:8px;
            font-size:13px;
            color:#dc3545;
            font-weight:700;
        }

        .tpreset-password-note{
            background:#fff8e1;
            border:1px solid rgba(255,193,7,.34);
            color:#7c5700;
            font-size:12px;
            font-weight:800;
            border-radius:14px;
            padding:12px 14px;
            margin-bottom:18px;
            transition:all .2s ease;
        }

        .tpreset-password-toggle{
            position:absolute;
            right:15px;
            top:50%;
            transform:translateY(-50%);
            border:0;
            background:transparent;
            color:#6c757d;
            cursor:pointer;
            padding:6px;
            z-index:3;
        }

        .tpreset-password-toggle:hover{
            color:#ff9800;
        }

        .tpreset-submit-btn{
            width:100%;
            height:52px;
            border:0;
            border-radius:999px;
            background:linear-gradient(135deg,#ffc107,#ff9800);
            color:#212529;
            font-weight:900;
            letter-spacing:.3px;
            box-shadow:0 14px 28px rgba(255,193,7,.28);
            transition:all .2s ease;
            cursor:pointer;
        }

        .tpreset-submit-btn:hover{
            transform:translateY(-2px);
            box-shadow:0 18px 34px rgba(255,193,7,.36);
        }

        .tpreset-submit-btn:disabled{
            opacity:.55;
            cursor:not-allowed;
            transform:none;
        }

        .tpreset-back-btn{
            width:100%;
            height:50px;
            border-radius:999px;
            border:1px solid #ffc107;
            background:#fff8e1;
            color:#212529;
            font-weight:900;
            display:inline-flex;
            align-items:center;
            justify-content:center;
            text-decoration:none;
            transition:all .2s ease;
            margin-top:16px;
        }

        .tpreset-back-btn:hover{
            background:#ffc107;
            color:#212529;
        }

        @media (max-width:900px){

            .tpreset-card{
                grid-template-columns:1fr;
                max-width:520px;
            }

            .tpreset-left-panel{
                padding:38px 32px 24px;
            }

            .tpreset-logo{
                width:220px;
            }

            .tpreset-brand-text{
                display:none;
            }

            .tpreset-right-panel{
                padding:32px;
            }
        }

        @media (max-width:480px){

            .tpreset-wrapper{
                padding:18px 14px;
                align-items:flex-start;
            }

            .tpreset-card{
                border-radius:24px;
            }

            .tpreset-left-panel{
                padding:30px 22px 16px;
            }

            .tpreset-logo{
                width:180px;
            }

            .tpreset-right-panel{
                padding:26px 22px 30px;
            }

            .tpreset-header h2{
                font-size:26px;
            }
        }

                   /* ========================================= */
/* Verify-EMail PAGE ONLY                        */
/* ========================================= */
*{
            box-sizing:border-box;
        }

        html,
        body{
            margin:0;
            padding:0;
            width:100%;
            min-height:100%;
            font-family:Arial, Helvetica, sans-serif;
            background:
                radial-gradient(circle at top left, rgba(255,193,7,.18), transparent 28%),
                #f4f6f9;
        }

        .tpverify-wrapper{
            min-height:100vh;
            width:100%;
            display:flex;
            align-items:center;
            justify-content:center;
            padding:32px 18px;
        }

        .tpverify-card{
            width:100%;
            max-width:1050px;
            min-height:620px;
            background:#ffffff;
            border-radius:28px;
            overflow:hidden;
            box-shadow:0 24px 70px rgba(15,23,42,.12);
            border:1px solid rgba(15,23,42,.06);
            display:grid;
            grid-template-columns:1.1fr .9fr;
        }

        .tpverify-left-panel{
            position:relative;
            padding:56px;
            display:flex;
            flex-direction:column;
            align-items:center;
            justify-content:center;
            background:
                radial-gradient(circle at top left, rgba(255,193,7,.22), transparent 34%),
                linear-gradient(135deg,#ffffff,#fffaf0);
        }

        .tpverify-left-panel::before{
            content:"";
            position:absolute;
            width:180px;
            height:180px;
            border-radius:50%;
            background:rgba(255,193,7,.18);
            top:-70px;
            left:-70px;
        }

        .tpverify-left-panel::after{
            content:"";
            position:absolute;
            width:140px;
            height:140px;
            border-radius:50%;
            background:rgba(17,24,39,.05);
            bottom:-55px;
            right:-45px;
        }

        .tpverify-logo{
            width:330px;
            max-width:90%;
            object-fit:contain;
            position:relative;
            z-index:1;
        }

        .tpverify-brand{
            margin-top:24px;
            text-align:center;
            position:relative;
            z-index:1;
        }

        .tpverify-brand h3{
            margin:0 0 10px;
            font-size:28px;
            font-weight:900;
            color:#1f2937;
        }

        .tpverify-brand p{
            margin:0;
            color:#6b7280;
            line-height:1.6;
            font-size:15px;
        }

        .tpverify-right-panel{
            padding:56px 52px;
            display:flex;
            align-items:center;
            justify-content:center;
        }

        .tpverify-inner{
            width:100%;
            max-width:420px;
        }

        .tpverify-header{
            text-align:center;
            margin-bottom:28px;
        }

        .tpverify-icon-box{
            width:82px;
            height:82px;
            border-radius:24px;
            background:linear-gradient(135deg,#ffc107,#ff9800);
            margin:0 auto 20px;
            display:flex;
            align-items:center;
            justify-content:center;
            box-shadow:0 18px 36px rgba(255,193,7,.24);
        }

        .tpverify-icon-box i{
            font-size:34px;
            color:#111827;
        }

        .tpverify-header h2{
            margin:0 0 12px;
            font-size:32px;
            font-weight:900;
            color:#111827;
        }

        .tpverify-header p{
            margin:0;
            color:#6b7280;
            line-height:1.7;
            font-size:15px;
        }

        .tpverify-alert-success{
            background:#e7f7ee;
            border:1px solid rgba(21,128,61,.18);
            color:#15803d;
            border-radius:16px;
            padding:14px 16px;
            font-size:14px;
            font-weight:800;
            line-height:1.6;
            margin-bottom:20px;
        }

        .tpverify-submit-btn{
            width:100%;
            height:54px;
            border:0;
            border-radius:999px;
            background:linear-gradient(135deg,#ffc107,#ff9800);
            color:#1f2937;
            font-size:14px;
            font-weight:900;
            letter-spacing:.4px;
            cursor:pointer;
            transition:all .2s ease;
            box-shadow:0 14px 28px rgba(255,193,7,.28);
        }

        .tpverify-submit-btn:hover{
            transform:translateY(-2px);
        }

        .tpverify-divider{
            text-align:center;
            margin:20px 0;
            position:relative;
        }

        .tpverify-divider::before{
            content:'';
            position:absolute;
            top:50%;
            left:0;
            width:100%;
            height:1px;
            background:#e5e7eb;
        }

        .tpverify-divider span{
            position:relative;
            background:#fff;
            padding:0 14px;
            color:#9ca3af;
            font-size:12px;
            font-weight:700;
        }

        .tpverify-logout-btn{
            width:100%;
            height:52px;
            border-radius:999px;
            border:1px solid #d1d5db;
            background:#ffffff;
            color:#374151;
            font-size:14px;
            font-weight:800;
            cursor:pointer;
            transition:all .2s ease;
        }

        .tpverify-logout-btn:hover{
            background:#f9fafb;
        }

        @media (max-width:900px){

            .tpverify-card{
                grid-template-columns:1fr;
                max-width:520px;
            }

            .tpverify-left-panel{
                padding:36px 24px 20px;
            }

            .tpverify-logo{
                width:220px;
            }

            .tpverify-brand{
                display:none;
            }

            .tpverify-right-panel{
                padding:34px 24px;
            }
        }

        @media (max-width:480px){

            .tpverify-wrapper{
                padding:18px 14px;
                align-items:flex-start;
            }

            .tpverify-card{
                border-radius:24px;
            }

            .tpverify-left-panel{
                padding:30px 22px 16px;
            }

            .tpverify-logo{
                width:180px;
            }

            .tpverify-right-panel{
                padding:26px 22px 30px;
            }

            .tpverify-header h2{
                font-size:26px;
            }
        }
        
        /* ========================================= */
/* REGISTER PAGE ONLY                        */
/* ========================================= */
        
        
                html,
        body {
            min-height: 100%;
        }

        body.portal-admin-register-page-v1 {
            background:
                radial-gradient(circle at top left, rgba(255,193,7,.22), transparent 28%),
                radial-gradient(circle at bottom right, rgba(255,152,0,.16), transparent 28%),
                #f4f6f9;
            min-height:100vh;

    display:flex;
    align-items:center;
    justify-content:center;

    padding:40px 14px;
        }

        .portal-admin-register-wrapper-v1 {
            width: 100%;
            max-width: 980px;
            margin: 0 auto;
        }

        .portal-admin-register-card-v1 {
            background: #ffffff;
            border: 0;
            border-radius: 28px;
            overflow: hidden;
            box-shadow: 0 28px 70px rgba(15, 23, 42, .12);
        }

        .portal-admin-register-layout-v1 {
            display: grid;
            grid-template-columns: .95fr 1.05fr;
            min-height: 700px;
        }

        .portal-admin-register-brand-panel-v1 {
            background:
                radial-gradient(circle at top left, rgba(255,255,255,.38), transparent 30%),
                linear-gradient(135deg, #ffc107, #ff9800);
            padding: 36px;
            color: #111827;
            position: relative;
            overflow: hidden;
        }

        .portal-admin-register-brand-panel-v1::after {
            content: "";
            position: absolute;
            width: 220px;
            height: 220px;
            border-radius: 50%;
            background: rgba(255,255,255,.20);
            right: -90px;
            bottom: -80px;
        }

        .portal-admin-register-logo-box-v1 {
            width: 82px;
            height: 82px;
            border-radius: 26px;
            background: rgba(255,255,255,.42);
            display: flex;
            align-items: center;
            justify-content: center;
            margin-bottom: 26px;
            box-shadow: 0 18px 36px rgba(15,23,42,.12);
        }

        .portal-admin-register-logo-box-v1 img {
            width: 62px;
            height: 62px;
            object-fit: contain;
        }

        .portal-admin-register-brand-panel-v1 h1 {
            font-size: 34px;
            font-weight: 900;
            line-height: 1.1;
            margin-bottom: 14px;
        }

        .portal-admin-register-brand-panel-v1 p {
            font-size: 15px;
            line-height: 1.6;
            font-weight: 700;
            opacity: .82;
            max-width: 320px;
        }

        .portal-admin-register-feature-list-v1 {
            margin-top: 34px;
            position: relative;
            z-index: 2;
        }

        .portal-admin-register-feature-item-v1 {
            display: flex;
            align-items: center;
            gap: 12px;
            background: rgba(255,255,255,.34);
            border-radius: 18px;
            padding: 13px 14px;
            margin-bottom: 12px;
            font-weight: 800;
            font-size: 13px;
        }

        .portal-admin-register-feature-item-v1 i {
            width: 34px;
            height: 34px;
            border-radius: 12px;
            background: #111827;
            color: #ffffff;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .portal-admin-register-form-panel-v1 {
            padding: 36px;
        }

        .portal-admin-register-small-title-v1 {
            color: #6b7280;
            font-weight: 800;
            font-size: 13px;
            margin-bottom: 2px;
        }

        .portal-admin-register-title-v1 {
            color: #111827;
            font-size: 28px;
            font-weight: 900;
            margin-bottom: 6px;
        }

        .portal-admin-register-subtitle-v1 {
            color: #6b7280;
            font-size: 13px;
            font-weight: 700;
            margin-bottom: 24px;
        }

        .portal-admin-register-section-title-v1 {
            display: flex;
            align-items: center;
            gap: 10px;
            color: #111827;
            font-size: 14px;
            font-weight: 900;
            margin: 22px 0 14px;
        }

        .portal-admin-register-section-title-v1 span {
            width: 34px;
            height: 34px;
            border-radius: 12px;
            background: #fff3cd;
            color: #ff9800;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .portal-admin-register-input-group-v1 {
            margin-bottom: 14px;
        }

        .portal-admin-register-input-v1 {
            height: 46px;
            border-radius: 14px 0 0 14px !important;
            border: 1px solid #d1d5db;
            font-size: 14px;
            font-weight: 700;
        }

        .portal-admin-register-input-v1:focus {
            border-color: #ffc107;
            box-shadow: 0 0 0 .18rem rgba(255,193,7,.18);
        }

        .portal-admin-register-input-icon-v1 {
            width: 46px;
            justify-content: center;
            border-radius: 0 14px 14px 0 !important;
            background: #f8f9fa;
            color: #6b7280;
            border: 1px solid #d1d5db;
            border-left: 0;
        }

        .portal-admin-register-password-toggle-v1 {
            width: 46px;
            height: 46px;
            border-radius: 0 14px 14px 0 !important;
            border: 1px solid #d1d5db;
            border-left: 0;
            background: #f8f9fa;
            color: #6b7280;
        }

        .portal-admin-register-password-note-v1 {
            background: #fff8e1;
            border: 1px solid rgba(255,193,7,.34);
            color: #7c5700;
            font-size: 12px;
            font-weight: 800;
            border-radius: 14px;
            padding: 12px 14px;
            margin-bottom: 14px;
        }

        .portal-admin-register-submit-btn-v1 {
            height: 48px;
            border-radius: 999px;
            border: 0;
            background: linear-gradient(135deg, #ffc107, #ff9800);
            color: #111827;
            font-size: 14px;
            font-weight: 900;
            box-shadow: 0 12px 26px rgba(255,193,7,.28);
            transition: all .2s ease;
        }

        .portal-admin-register-submit-btn-v1:hover {
            transform: translateY(-2px);
            color: #111827;
        }

        .portal-admin-register-login-box-v1 {
            margin-top: 16px;
            text-align: center;
        }

        .portal-admin-register-login-btn-v1 {
            height: 44px;
            border-radius: 999px;
            font-weight: 900;
            color: #111827;
            background: #ffffff;
            border: 1px solid #d1d5db;
        }

        .portal-admin-register-login-btn-v1:hover {
            background: #f8f9fa;
            color: #111827;
        }

        @media (max-width: 767.98px) {

            body.portal-admin-register-page-v1 {
                padding: 14px;
            }

            .portal-admin-register-layout-v1 {
                grid-template-columns: 1fr;
            }

            .portal-admin-register-brand-panel-v1 {
                padding: 28px;
            }

            .portal-admin-register-form-panel-v1 {
                padding: 26px 20px;
            }
        }