.path-login.pagelayout-login {
    background: #f8f9fa;
    font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
}

.path-login.pagelayout-login #page-wrapper,
.path-login.pagelayout-login #page,
.path-login.pagelayout-login #region-main-box,
.path-login.pagelayout-login #region-main {
    background: #f8f9fa;
    border: 0;
    box-shadow: none;
}

.path-login.pagelayout-login #page-header,
.path-login.pagelayout-login #page-navbar,
.path-login.pagelayout-login .loginform .login-heading,
.path-login.pagelayout-login .signupform .login-heading {
    display: none;
}

/* Login index: compact form width (Moodle default) and hide extra actions. */
#page-login-index .login-container {
    margin: 0 auto 2rem !important;
    max-width: 500px !important;
    width: 500px !important;
}

#page-login-index .login-wrapper {
    margin: 0 auto !important;
    max-width: 500px !important;
    width: auto !important;
}

@media (max-width: 575.98px) {
    #page-login-index .login-container {
        max-width: 100% !important;
        width: 100% !important;
    }
}

#page-login-signup .registration-topbar,
#page-login-index .registration-topbar,
#page-login-index #page-footer,
#page-login-index .loginform .login-divider,
#page-login-index .login-instructions,
#page-login-index .login-signup,
#page-login-index .login-signup a,
#page-login-index .login-signup .btn,
#page-login-index .login-identityproviders,
#page-login-index #guestlogin,
#page-login-index #loginguestbtn,
#page-login-index .loginform > h2.login-heading,
#page-login-index .loginform > .d-flex,
#page-login-index .loginform > .d-flex button {
    display: none !important;
}

/* Signup page: keep wider layout. */
#page-login-signup .login-container {
    margin: 0 auto !important;
    max-width: 1200px !important;
    width: 100% !important;
}

#page-login-signup .login-wrapper {
    max-width: 100% !important;
    width: 100% !important;
}

.path-login.pagelayout-login .registration-container {
    margin: 0 auto 2rem;
    max-width: 960px;
    padding: 1rem 1rem 2rem;
}

.path-login.pagelayout-login .registration-intro {
    margin-bottom: 1.75rem;
}

.path-login.pagelayout-login .registration-title {
    font-size: 2.4rem;
    font-weight: 700;
    margin: 0 0 0.3rem;
}

.path-login.pagelayout-login .registration-subtitle {
    color: #6c757d;
    font-size: 1rem;
    margin: 0;
}

.path-login.pagelayout-login .signupform {
    margin: 0 auto;
    max-width: 100%;
}

/* Signup: no collapsible section toggles (shortforms disabled in PHP; belt-and-braces). */
body#page-login-signup .mform .collapsible-actions,
body#page-login-signup .mform .fheader .icons-collapse-expand,
body#page-login-signup .mform .fheader a[data-bs-toggle="collapse"] {
    display: none !important;
}

body#page-login-signup .mform .fcontainer.collapse {
    display: block !important;
    height: auto !important;
    visibility: visible !important;
}

body#page-login-signup .mform .fheader .ftoggler {
    margin-right: 0 !important;
}

.path-login.pagelayout-login .mform fieldset {
    background: #fff;
    border: 0;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    margin: 0 0 1.6rem;
    padding: 1.75rem;
}

.path-login.pagelayout-login .mform fieldset .fitem {
    margin: 0 0 0.85rem;
}

.path-login.pagelayout-login #id_personaldetailscontainer,
.path-login.pagelayout-login #id_educationalbackgroundcontainer {
    display: grid;
    gap: 0.9rem 1.25rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.path-login.pagelayout-login #id_personaldetailscontainer > .fitem,
.path-login.pagelayout-login #id_educationalbackgroundcontainer > .fitem {
    margin-bottom: 0;
}

.path-login.pagelayout-login #fitem_id_passwordpolicyinfo,
.path-login.pagelayout-login #fitem_id_country,
.path-login.pagelayout-login #fitem_id_highesteducation {
    grid-column: 1 / -1;
}

.path-login.pagelayout-login .mform .fitem .col-form-label {
    color: #495057;
    font-size: 1.04rem;
    font-weight: 600;
}

.path-login.pagelayout-login .mform input[type="text"],
.path-login.pagelayout-login .mform input[type="password"],
.path-login.pagelayout-login .mform input[type="email"],
.path-login.pagelayout-login .mform input[type="number"],
.path-login.pagelayout-login .mform textarea {
    border: 1px solid #ced4da;
    border-radius: 0.45rem;
    font-size: 1.05rem;
    min-height: 3rem;
    padding: 0.55rem 0.8rem;
}

.path-login.pagelayout-login .mform select,
.path-login.pagelayout-login .mform select.form-control,
.path-login.pagelayout-login .mform select.custom-select,
.path-login.pagelayout-login .mform select.form-select {
    border: 1px solid #ced4da;
    border-radius: 0.45rem;
    font-size: 1.05rem;
    min-height: 3rem;
    padding: 0.55rem 2.75rem 0.55rem 0.8rem;
    background-position: right 0.85rem center;
    background-size: 1rem;
    max-width: 100%;
}

.path-login.pagelayout-login .mform .felement .form-control {
    width: 100%;
}

.path-login.pagelayout-login #id_personaldetailscontainer .felement,
.path-login.pagelayout-login #id_educationalbackgroundcontainer .felement {
    max-width: 100%;
    width: 100%;
}

.path-login.pagelayout-login #fitem_id_passwordpolicyinfo,
body.local-registrationlink-invite-signup #fitem_id_passwordpolicyinfo {
    display: none !important;
}

.path-login.pagelayout-login #fitem_id_passwordpolicyinfo .col-md-3 {
    display: none;
}

.path-login.pagelayout-login #fitem_id_passwordpolicyinfo .col-md-9 {
    flex: 0 0 100%;
    max-width: 100%;
    padding-left: 0;
}

.path-login.pagelayout-login #id_documentuploadssectioncontainer > .fcontainer {
    display: block;
}

.path-login.pagelayout-login .upload-grid {
    display: grid;
    gap: 0.75rem 1.5rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: auto auto;
}

.path-login.pagelayout-login .upload-grid > .upload-item:nth-child(1) {
    grid-column: 1;
    grid-row: 1;
}

.path-login.pagelayout-login .upload-grid > .upload-item:nth-child(3) {
    grid-column: 2;
    grid-row: 1;
}

.path-login.pagelayout-login .upload-grid > .fitem.row {
    display: block;
    margin-bottom: 0;
}

.path-login.pagelayout-login .upload-grid > #fitem_id_iddocumentupload_error {
    grid-column: 1;
    grid-row: 2;
    margin-top: 0;
}

.path-login.pagelayout-login .upload-grid > #fitem_id_certificatesupload_error {
    grid-column: 2;
    grid-row: 2;
    margin-top: 0;
}

.path-login.pagelayout-login #fitem_id_iddocumentupload_error .col-md-3,
.path-login.pagelayout-login #fitem_id_certificatesupload_error .col-md-3 {
    display: none;
}

.path-login.pagelayout-login #fitem_id_iddocumentupload_error .col-md-9,
.path-login.pagelayout-login #fitem_id_certificatesupload_error .col-md-9 {
    flex: 0 0 100%;
    max-width: 100%;
    padding-left: 0;
    width: 100%;
}

.path-login.pagelayout-login .upload-item-label {
    color: #495057;
    display: block;
    font-weight: 600;
    margin-bottom: 0.45rem;
}

.path-login.pagelayout-login .upload-item-label .req {
    color: #dc3545;
}

.path-login.pagelayout-login .file-upload-area {
    background: #f8f9fa;
    border: 2px dashed #dee2e6;
    border-radius: 8px;
    cursor: pointer;
    display: block;
    margin-bottom: 0;
    min-height: 150px;
    padding: 2rem 1.25rem;
    text-align: center;
    transition: all 0.3s ease;
}

.path-login.pagelayout-login .file-upload-area:hover,
.path-login.pagelayout-login .file-upload-area:focus-within {
    background: #e8f5ee;
    border-color: #086e37;
}

.path-login.pagelayout-login .file-upload-icon {
    display: block;
    line-height: 1;
    margin-bottom: 0.5rem;
}

.path-login.pagelayout-login .file-upload-icon .icon {
    color: #6c757d !important;
}

.path-login.pagelayout-login .file-upload-title {
    color: #374151;
    display: block;
    font-weight: 600;
    margin-top: 0.3rem;
}

.path-login.pagelayout-login .file-upload-subtitle {
    color: #6c757d;
    display: block;
    font-size: 0.85rem;
    margin-top: 0.25rem;
}

.path-login.pagelayout-login .signup-file-input {
    height: 0;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    width: 0;
}

.path-login.pagelayout-login .upload-status-badge {
    align-items: center;
    background: #198754;
    border-radius: 999px;
    color: #fff;
    display: none;
    font-size: 0.8rem;
    font-weight: 600;
    gap: 0.25rem;
    margin-top: 0.5rem;
    padding: 0.25rem 0.65rem;
}

.path-login.pagelayout-login .upload-status-badge.is-visible {
    display: inline-block;
}

.path-login.pagelayout-login .upload-file-preview {
    margin-top: 0.5rem;
}

.path-login.pagelayout-login .upload-file-preview-cards {
    display: grid;
    gap: 0.4rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.path-login.pagelayout-login .upload-preview-card {
    align-items: center;
    background: #fff;
    border: 1px solid #dee2e6;
    border-radius: 0.5rem;
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    min-height: 58px;
    padding: 0.25rem;
    position: relative;
}

.path-login.pagelayout-login .upload-preview-thumb,
.path-login.pagelayout-login .upload-preview-icon {
    border-radius: 0.35rem;
    height: 50px;
    object-fit: cover;
    width: 100%;
}

.path-login.pagelayout-login .upload-preview-icon {
    align-items: center;
    background: #f1f3f5;
    color: #495057;
    display: flex;
    font-size: 0.6rem;
    font-weight: 700;
    justify-content: center;
}

.path-login.pagelayout-login .upload-preview-remove {
    align-items: center;
    background: rgba(33, 37, 41, 0.85);
    border: 0;
    border-radius: 999px;
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    font-size: 0.85rem;
    font-weight: 700;
    height: 18px;
    justify-content: center;
    line-height: 1;
    padding: 0;
    position: absolute;
    right: 4px;
    top: 4px;
    width: 18px;
    z-index: 2;
}

.path-login.pagelayout-login .upload-preview-remove:hover {
    background: #dc3545;
}

.path-login.pagelayout-login .upload-file-preview-list {
    color: #495057;
    font-size: 0.85rem;
    margin: 0;
    padding-left: 1rem;
    text-align: left;
}

.path-login.pagelayout-login .upload-file-preview-list li {
    margin-bottom: 0.2rem;
    word-break: break-word;
}

.path-login.pagelayout-login .upload-file-preview-cards:empty {
    display: none;
}

.path-login.pagelayout-login .mform .fdescription.required {
    color: #dc3545;
}

/* Ensure Moodle validation messages are always visible in this custom layout. */
.path-login.pagelayout-login .mform .form-control-feedback.invalid-feedback {
    display: block;
}

.path-login.pagelayout-login .mform .error {
    color: #dc3545;
    display: block;
    font-size: 0.875rem;
    margin-top: 0.25rem;
}

.path-login.pagelayout-login .mform .btn.btn-primary {
    font-size: 1.08rem;
    padding: 0.72rem 2.9rem;
}

.path-login.pagelayout-login .mform .btn.btn-secondary {
    padding: 0.72rem 1.4rem;
}

/* Invite signup: stack labels above inputs like candidate-register.html */
body.local-registrationlink-invite-signup #id_personaldetailscontainer > .fitem.row,
body.local-registrationlink-invite-signup #id_educationalbackgroundcontainer > .fitem.row,
body.local-registrationlink-invite-signup #id_gdprconsentsectioncontainer > .fitem.row {
    display: block;
    margin-bottom: 0;
}

body.local-registrationlink-invite-signup #id_personaldetailscontainer > .fitem > .col-md-3,
body.local-registrationlink-invite-signup #id_personaldetailscontainer > .fitem > .col-md-9,
body.local-registrationlink-invite-signup #id_educationalbackgroundcontainer > .fitem > .col-md-3,
body.local-registrationlink-invite-signup #id_educationalbackgroundcontainer > .fitem > .col-md-9,
body.local-registrationlink-invite-signup #id_gdprconsentsectioncontainer > .fitem > .col-md-3,
body.local-registrationlink-invite-signup #id_gdprconsentsectioncontainer > .fitem > .col-md-9 {
    flex: 0 0 100%;
    max-width: 100%;
    padding-left: 0;
    padding-right: 0;
    width: 100%;
}

body.local-registrationlink-invite-signup #id_personaldetailscontainer .col-form-label,
body.local-registrationlink-invite-signup #id_educationalbackgroundcontainer .col-form-label {
    margin-bottom: 0.35rem;
    padding-bottom: 0;
}

body.local-registrationlink-invite-signup #id_personaldetailscontainer .felement,
body.local-registrationlink-invite-signup #id_educationalbackgroundcontainer .felement {
    width: 100%;
}

body.local-registrationlink-invite-signup #id_personaldetailscontainer .felement .form-control,
body.local-registrationlink-invite-signup #id_personaldetailscontainer .felement .form-select,
body.local-registrationlink-invite-signup #id_educationalbackgroundcontainer .felement .form-control,
body.local-registrationlink-invite-signup #id_educationalbackgroundcontainer .felement .form-select,
body.local-registrationlink-invite-signup #fitem_id_gender.form-select,
body.local-registrationlink-invite-signup #fitem_id_gender.fitem.form-select {
    background: transparent;
    border: 0;
    box-shadow: none;
    padding: 0;
}

body.local-registrationlink-invite-signup #fitem_id_gender .form-select,
body.local-registrationlink-invite-signup #fitem_id_country .form-select,
body.local-registrationlink-invite-signup #fitem_id_highesteducation .form-select {
    display: block;
    max-width: 100%;
    width: 100%;
}

body.local-registrationlink-invite-signup #fitem_id_gender .felement,
body.local-registrationlink-invite-signup #fitem_id_country .felement,
body.local-registrationlink-invite-signup #fitem_id_highesteducation .felement {
    display: block !important;
    flex: 0 0 100%;
    max-width: 100%;
    width: 100%;
}

@media (max-width: 767px) {
    .path-login.pagelayout-login #id_personaldetailscontainer,
    .path-login.pagelayout-login #id_educationalbackgroundcontainer,
    .path-login.pagelayout-login .upload-grid {
        grid-template-columns: 1fr;
    }

    .path-login.pagelayout-login .upload-grid > .upload-item:nth-child(1),
    .path-login.pagelayout-login .upload-grid > .upload-item:nth-child(3),
    .path-login.pagelayout-login .upload-grid > #fitem_id_iddocumentupload_error,
    .path-login.pagelayout-login .upload-grid > #fitem_id_certificatesupload_error {
        grid-column: 1 / -1;
        grid-row: auto;
    }

    .path-login.pagelayout-login .registration-title {
        font-size: 2rem;
    }

    .path-login.pagelayout-login .upload-file-preview-cards {
        grid-template-columns: 1fr;
    }
}
