/* ==========================================================================
   FILENAME: login.css
   DESCRIPTION: Login page styles extracted from login_base.html inline CSS.
   Colors converted to design-system tokens for light/dark mode support.
   ========================================================================== */

/* ==========================================================================
   A. PAGE LAYOUT
   ========================================================================== */

html,
body {
  height: 100%;
}

@media (max-width: 767px) {
  html,
  body {
    padding: 0 4px;
  }
}

body,
div,
p,
a,
label {
  font-size: 14px;
  font-weight: 400;
  color: var(--sys-on-background);
  margin: auto;
}

a {
  color: var(--sys-secondary);
}

p {
  line-height: 21px;
}

.container {
  max-width: 620px;
}

.login, .register { display: table; }
.va-wrapper { display: table-cell; width: 100%; vertical-align: middle; }
.custom-container { display: table-row; height: 100%; }

/* ==========================================================================
   B. LOGO
   ========================================================================== */

.logo {
  margin: 34px auto 25px auto;
  display: block;
}

/* ==========================================================================
   C. BOX (CARD CONTAINER)
   ========================================================================== */

.box {
  box-shadow: 0 0px 3px 1px var(--sys-scrim);
  border: 1px solid var(--sys-outline-variant);
  border-radius: 3px;
  padding: 0 30px;
  background-color: var(--sys-surface);
}

/* ==========================================================================
   D. BUTTONS
   ========================================================================== */

.btn-sp-green {
  height: 45px;
  line-height: 22.5px;
  padding: 0 40px;
  color: var(--sys-on-secondary);
  font-size: 17px;
  background: var(--sys-secondary);
  border: none;
}

.btn-sp-green:hover,
.btn-sp-green:focus {
  color: var(--sys-on-secondary);
  background: var(--sys-secondary);
  opacity: 0.85;
}

.btn-social {
  height: 37px;
  line-height: 18.5px;
  color: #fff;
  font-size: 16px;
  border-radius: 3px;
}

.btn-social:hover,
.btn-social:focus {
  color: #fff;
}

.btn-facebook {
  background: #3d63c0;
}

.btn-facebook:hover,
.btn-facebook:focus {
  color: #fff;
  background: #3767db;
}

.btn-google {
  background: #dd4b39;
}

.btn-google:hover,
.btn-google:focus {
  color: #fff;
  background: #e8503c;
}

.btn-register {
  font-size: 16px;
}

/* ==========================================================================
   E. FORM CONTROLS (LOGIN-SPECIFIC)
   ========================================================================== */

.form-control {
  font-size: 15px;
  box-shadow: none;
}

.form-control::placeholder {
  color: var(--sys-on-surface-variant);
}

.form-control:focus {
  border-color: var(--sys-secondary);
  box-shadow: 0 0 0 2px rgba(255, 85, 0, 0.2);
}

/* Override Chrome autofill background */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--sys-on-surface);
  -webkit-box-shadow: 0 0 0px 1000px var(--sys-surface-container-low) inset;
  transition: background-color 5000s ease-in-out 0s;
}

/* ==========================================================================
   F. VIEW LAYOUT
   ========================================================================== */

.view .header {
  padding: 34px 0;
}

.view .header,
.view .header a {
  font-weight: 300;
  font-size: 21px;
}

.view input[type="text"],
.view input[type="password"] {
  background-color: var(--sys-surface-container-low);
  height: 45px;
}

.view a.forgot,
.view a.to-login {
  float: right;
  padding: 17px 0;
  font-size: 13px;
}

.view form button {
  display: block;
  float: right;
  margin-bottom: 25px;
}

.view form label {
  height: 45px;
  line-height: 45px;
}

.view .box .header p {
  margin-top: 20px;
}

/* ==========================================================================
   G. SP-FORM (VALIDATION STYLES)
   ========================================================================== */

.sp-form .has-error,
.sp-form .has-error .help-block {
  color: var(--sys-error);
  font-weight: 600;
}

.sp-form .has-error input[type="text"],
.sp-form .has-error input[type="password"] {
  border-color: var(--sys-error);
}

.sp-form .form-group {
  margin-bottom: 21px;
}

.sp-form input[type="text"],
.sp-form input[type="password"] {
  position: relative;
}

.sp-form .help-block {
  font-size: 12px;
  position: absolute;
  top: 43px;
}

/* ==========================================================================
   H. VERIFY & UNVERIFIED VIEWS
   ========================================================================== */

.verify-view .box {
  padding-bottom: 30px;
}

.verify-view .box .header {
  padding-bottom: 20px;
}

.unverified-view .box {
  padding-bottom: 30px;
}

.unverified-view .box .header {
  padding-bottom: 25px;
}

/* ==========================================================================
   I. LOGIN VIEW — EMAIL/PASSWORD AREA
   ========================================================================== */

.login-view .box {
  background-color: var(--sys-surface-container-low);
  padding: 0;
}

.login-view label {
  margin-bottom: 7px;
}

.login-view .email-password-area {
  background-color: var(--sys-surface);
  border-top-left-radius: 3px;
  border-bottom-left-radius: 3px;
}

@media (min-width: 767px) {
  .login-view .email-password-area {
    padding: 0 30px;
  }
}

.login-view .email-password-area label {
  height: 14px;
  line-height: 14px;
}

.login-view .email-password-area input[type='checkbox'] {
  visibility: hidden;
}

.login-view .email-password-area input[type='checkbox'] + label {
  position: relative;
  padding-left: 8px;
  line-height: 16px;
  font-size: 13px;
}

.login-view .email-password-area input[type='checkbox'] + label:after {
  position: absolute;
  left: -16px;
  width: 16px;
  height: 16px;
  border: 1px solid var(--sys-outline-variant);
  background-color: var(--sys-surface-container-low);
  content: "";
}

.login-view .email-password-area input[type='checkbox']:checked + label:after {
  background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA2ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDowRTVBQUVGMzJEODBFMjExODQ2N0NBMjk4MjdCNDBCNyIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDo0RTY4NUM4NURGNEYxMUUyQUE5QkExOTlGODU3RkFEOCIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDo0RTY4NUM4NERGNEYxMUUyQUE5QkExOTlGODU3RkFEOCIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgQ1M2IChXaW5kb3dzKSI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOjQxNDQ4M0NEM0JERkUyMTE4MEYwQjNBRjIwMUNENzQxIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOkZDMEMxNjY2OUVCMUUyMTFBRjVDQkQ0QjE5MTNERDU2Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+3YY4qgAAALlJREFUeNpi/P//PwMlgImBQjDwBrCgCwQHB+NUfObMGT9mZuboe/fuheM0ABu4fv060/fv32cBNTNycHBE4nUBNs0/f/7cAWSeMzQ0rCA5DICaNwKj+qGRkVEFUYF47ty5GWfPns2EsjsYGRlFgM5OJzoQ//37t5eLi2sRMMDec3Jypn79+lVXX1//H9HRaGJisvr379/nuLm5lwKdP9vMzOwZyekAaEA3EF8G4hZCYcQ4mhcYAAIMAJGST/dDIpNQAAAAAElFTkSuQmCC);
  background-position: -1px -1px;
}

@media (min-width: 767px) {
  .login-view .email-password-area.small {
    border-right: 1px solid var(--sys-outline-variant);
  }

  .login-view .email-password-area.small .group-email {
    margin-bottom: 21px;
  }
}

@media (max-width: 767px) {
  .login-view .email-password-area.small {
    border-bottom: 1px solid var(--sys-outline-variant);
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
  }
}

.login-view .email-password-area.large {
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
}

@media (min-width: 767px) {
  .login-view .email-password-area.large {
    padding: 0 50px;
  }

  .login-view .email-password-area.large .group-email label,
  .login-view .email-password-area.large .group-password label {
    height: 45px;
    line-height: 45px;
  }
}

/* ==========================================================================
   J. LOGIN VIEW — SOCIAL AREA
   ========================================================================== */

.login-view .social-area {
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
  padding: 0 20px;
  position: relative;
  padding-bottom: 20px;
  background-color: var(--sys-surface-container-low);
}

.login-view .social-area .header {
  margin-bottom: -6px;
}

@media (max-width: 767px) {
  .login-view .social-area .header {
    padding: 0px;
  }
}

.login-view .social-area button {
  display: block;
  width: 100%;
  margin-bottom: 15px;
}

/* ==========================================================================
   K. HEADER LOGO
   ========================================================================== */

.header-logo {
  float: right;
  position: relative;
}

[data-theme="dark"] .header-logo {
  filter: invert(1);
}

/* ==========================================================================
   L. PAGE FOOTER
   ========================================================================== */

.login-footer {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 0;
  opacity: 0.45;
}

.login-footer .footer-logo {
  display: block;
}

.login-footer .footer-logo-dark {
  display: none;
}

[data-theme="dark"] .login-footer .footer-logo-light {
  display: none;
}

[data-theme="dark"] .login-footer .footer-logo-dark {
  display: block;
}

[data-theme="dark"] .login-footer .footer-logo[alt="Catapult"] {
  filter: invert(1);
}

.login-footer .footer-divider {
  width: 1px;
  height: 16px;
  background-color: var(--sys-on-background);
}

/* ==========================================================================
   M. THEME TOGGLE BUTTON
   ========================================================================== */

.theme-toggle {
  position: fixed;
  bottom: 12px;
  right: 16px;
  width: 32px;
  height: 32px;
  border: 1px solid var(--sys-outline-variant);
  border-radius: 50%;
  background-color: var(--sys-surface);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.6;
  transition: opacity 0.15s;
  padding: 0;
}

.theme-toggle:hover {
  opacity: 1;
}

.theme-toggle .glyphicon {
  font-size: 14px;
  color: var(--sys-on-surface);
}
