// shared styles used // on both the login and // create account modals .login-modal, .create-account { #login-buttons:not(.hidden) { display: flex; flex: 0 1 auto; flex-direction: column; align-items: stretch; min-height: 75px; padding: s(0 6); order: 2; button { display: flex; text-align: left; margin: 0.35em; white-space: nowrap; align-items: center; &:lang(zh_CN) { min-width: 200px; } &:first-of-type:last-of-type { &.oauth2_basic { // Handles a strange fringe case where OAuth2 and account approval are enabled margin-left: auto; margin-right: auto; justify-content: center; } } } } form { min-width: 300px; max-width: 100%; } #modal-alert { max-width: 100%; padding: s(2 4); } .login-modal { #login-buttons:not(.hidden) { button { &:first-of-type { margin-top: 2.8em; } &:last-of-type { margin-bottom: 3em; } } } } .create-account { #login-buttons:not(.hidden) { justify-content: flex-start; padding-top: 2.7em; + .login-form { border-right: 1px solid $primary-low; // Only show border when login-form is present } } } #login-form { box-sizing: border-box; flex: 1 0 auto; padding: s(0 6); + #login-buttons { border-left: 1px solid $primary-low; // Only show border when login-form is present } } tr:not(.instructions) { td { display: flex; padding: 5px 0 0 0; } } .tip, td label { display: block; overflow: hidden; word-wrap: break-word; margin-bottom: 0; max-width: 280px; @media screen and (min-width: 500px) { max-width: 400px; } } } .has-alt-auth { .tip, td label { max-width: 250px; } } // styles used on // login modal only .d-modal.login-modal { .modal-body, #credentials { display: flex; align-items: center; padding: 15px 0; tr { display: flex; flex-direction: column; } &.hidden { display: none; } } } // styles used on the // create account // modal only .d-modal.create-account { .modal-body { display: flex; padding: 15px 0; } .create-account-form tr { display: flex; flex-direction: column; } .login-form { position: relative; display: flex; overflow: hidden; flex: 1 1 auto; &:after, &:before { content: ""; display: block; position: absolute; width: 100%; pointer-events: none; } &:after { bottom: 0; height: 35px; @media screen and (max-height: 650px) { height: 45px; } background-image: linear-gradient( to bottom, rgba($secondary, 0) 0%, rgba($secondary, 0.9) 100% ); } &:before { top: 0; height: 25px; background-image: linear-gradient( to top, rgba($secondary, 0) 0%, rgba($secondary, 1) 100% ); } form { box-sizing: border-box; padding: s(4 6); margin-bottom: 0; max-height: 475px; @media screen and (max-height: 650px) { max-height: calc(65vh - 100px); > *:last-child { margin-bottom: 40px; } } overflow-x: hidden; overflow-y: auto; } form, table { width: 100%; } tr { display: flex; flex-direction: column; margin-top: 0.15em; &.password-confirmation { display: none; } } } tr.input { input, label { margin-bottom: 0; width: 100%; } .tip { max-width: 340px; } } .user-fields { margin-bottom: 20px; } .user-field { display: flex; flex-direction: column; &.confirm { margin-top: 5px; } > label { width: auto; } .controls { margin-left: 0; } } .invites-show { padding-top: 20px; .two-col { margin-top: 30px; } .col-form { margin-left: 200px; .inline-invite-img { display: none; } } form { .controls, .input { margin-left: 20px; } input, label { margin-bottom: 0; } .user-field .control-label:not(.checkbox-label) { margin-left: 20px; } } } .tos-agree { margin-bottom: 12px; } } .login-form { .tip { &:not(:empty) + td { display: none; } &:not(:empty), &:empty + td { min-height: 1.75em; &.bad .svg-icon { vertical-align: middle; } } } } .password-reset, .email-login, .invites-show { .col-form { padding-left: 20px; } .col-image { width: 175px; img { width: 100%; } } h2 { margin-bottom: 12px; } } .password-reset, .email-login { .col-form { padding-top: 40px; } }