.auth-card * {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  user-select: none;
}

.auth-card {
  background: linear-gradient(
    128deg,
    rgba(120, 120, 120, 0.1) 30%,
    rgba(120, 120, 120, 0.2) 100%
  );
  border-radius: 12px;
  border: 0;
  border-bottom: 1px solid #550;
  border-top: 1px solid #550;
  width: 100%;
  max-width: 520px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
  backdrop-filter: blur(4px);
  padding: 25px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  box-sizing: border-box;
  margin: 3vh auto;
  position: relative;
  z-index: 1;
  overflow: hidden;
  animation: fadeIn 0.5s ease-out, moveIn 1s ease-out;
}

.auth-card::before {
  content: '';
  position: absolute;
  border-radius: 50%;
  z-index: -1;
  background: rgba(255, 223, 56, 0.05);
  box-shadow: 0 0 42px rgba(255, 223, 86, 0.2);
  top: -30%;
  left: -30%;
  width: 60%;
  height: 60%;
  filter: blur(30px);
  animation: moveInBefore 1s ease-out forwards;
}

.auth-card::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  z-index: -1;
  background: rgba(255, 223, 86, 0.05);
  box-shadow: 0 0 10% rgba(255, 223, 86, 0.12);
  bottom: -45%;
  right: -45%;
  width: 90%;
  height: 90%;
  filter: blur(30px);
  animation: moveInAfter 1s ease-out forwards;
}

.auth-card.swmove::before {
  top: -30%;
  left: 70%;
  animation: moveInBeforeReverse 1s ease-out forwards;
}

.auth-card.swmove::after {
  bottom: -45%;
  left: -45%;
  animation: moveInAfterReverse 1s ease-out forwards;
}

@keyframes moveInBefore {
  from {transform: translate(130%, 0);}
  to   {transform: translate(0, 0);}}
@keyframes moveInAfter {
  from {transform: translate(-130%, 0);}
  to   {transform: translate(0, 0);}}
@keyframes moveInBeforeReverse {
  from {transform: translate(-130%, 0);}
  to   {transform: translate(0, 0);}}
@keyframes moveInAfterReverse {
  from {transform: translate(130%, 0);}
  to   {transform: translate(0, 0);}}
@keyframes fadeIn {
  from {opacity: 0;}
  to   {opacity: 1;}}
@keyframes fadeInLbl {
  from {opacity: .27;}
  to   {opacity: 1;}}
  
/* === separation box */  

.auth-card .sepbx {
 margin-bottom:7px;
}

.auth-card .sepbx p {
 margin-top: 8px;
}

/* === */

.auth-card__toggle {
  display: flex;
  justify-content: space-between;
  margin-bottom: 15px;
}

.auth-card__tab {
  background: none;
  border: none;
  font-size: 16px;
  padding: 12px 0;
  cursor: pointer;
  color: #ccc;
  flex: 1;
  text-align: center;
  transition: background-color 0.3s ease;
}

.auth-card__tab--active {
  color: #FFD700;
  border-bottom: 2px solid #FFD700;
}

.auth-card__forms {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 400px;
  gap: 15px;
  margin: 22px auto;
}

.auth-card__form {
  display: none;
}

.auth-card__form--2fa,
.auth-card__form--pwrsuccess,
.auth-card__form--restorepw,
.auth-card__form--rpwmsg,
.auth-card__form--forgotpw,
.auth-card__form--signup,
.auth-card__form--signin {
  display: flex;
  flex-direction: column;
}

.auth-card__form h3 {
  font-size: 22px;
  font-weight: 700;
  padding: 22px 7px 12px;
}

.auth-card__form--2fa div,
.auth-card__form--pwrsuccess div,
.auth-card__form--restorepw div,
.auth-card__form--rpwmsg div {
  font-size: 18px;
  line-height: 26px;
  padding: 7px;
}

.auth-card__form p {
  display: flex;
  flex-direction: column;
  position: relative;
}

.auth-card__form label {
  order: 10;
  font-size: 14px;
  letter-spacing:1px;
  color: #fff;
  transition: color 0.2s ease, opacity 0.3s ease;
  margin: 16px 0 9px 5px;
  opacity: 1;
  animation: fadeInLbl 1s ease-in forwards;
}

.auth-card__form input {
  order: 20;
  background: linear-gradient(145deg, rgba(51, 51, 51, 0.6), rgba(40, 40, 40, 0.5)); 
  border: 1px solid #555;
  border-radius: 5px;
  padding: 12px;
  width: 100%;
  color: #fff;
  font-size: 16px;
  transition: border-color 0.3s ease, background 0.3s ease;
  padding-right: 40px;
  position: relative;
}

.auth-card__form--2fa #otpfld:not(:placeholder-shown) {
  text-align:center; 
  font-size: 1.3em;
  font-weight: bold;
  letter-spacing: 3px; /* Wichtig: Standard beibehalten */
  text-shadow: 
    1px 0 0 currentColor, /* Erster Buchstabe (unsichtbarer Abstand) */
    1px 0 0 currentColor;   /* Zweiter Buchstabe (optischer Abstand) */
  padding-right: 0.5em;     /* Platz für den "fake" Abstand */
}

.auth-card__form input:focus {
  border-color: #FFD700;
  outline: none;
  background: linear-gradient(145deg, rgba(51, 51, 51, 0.8), rgba(30, 30, 30, 0.7)); 
}

.auth-card__form .dropdown_compl + label,
.auth-card__form input:focus + label,
.auth-card__form input:not(:placeholder-shown) + label {
  color: #FFD700;
  opacity: 1;
}

.auth-card__forgotpw {  
  margin: 22px 0 0;
  padding: 14px;
  font-size: 16px;
  color: #bbb;
  text-align: center;
  background: rgba(255,255,255,0.03);
  border: 0;
  border-radius: 5px;
  transition: transform 0.3s ease, background-color 0.3s ease;
}

.auth-card__forgotpw:hover {
  color: #fff;
  cursor: pointer;
  background: rgba(255,255,255,0.1);
  transform: scale(1.05);
}

.auth-card__submit {
  background: linear-gradient(145deg, #FFD700, #e6b800); 
  border: none;
  border-radius: 5px;
  color: #121212;
  font-size: 16px;
  padding: 14px;
  cursor: pointer;
  transition: transform 0.3s ease, background-color 0.3s ease;
  margin-top: 35px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
  text-align:center;
}

.auth-card__submit:hover {
  transform: scale(1.05);
  background: linear-gradient(145deg, #FFD700, #ffcc00);
  color: #222222;
  text-decoration: none;
}

.auth-card__submit:active {
  background: linear-gradient(145deg, #cc9900, #ffcc00);
}

.auth-card__submit.loading {
 position: relative;
 color: transparent;
 pointer-events: none;
}

.auth-card__submit.loading::after {
 content: "";
 position: absolute;
 top: 50%;
 left: 50%;
 width: 26px;
 height: 26px;
 margin: -16px 0 0 -13px;
 border: 3px solid rgba(255, 215, 0, 0.4);
 border-top: 3px solid #333;
 border-radius: 50%;
 animation: spin 1s linear infinite;
 box-shadow: 0 0 8px rgba(255, 215, 0, 0.3);
}

.password-toggle {
  border: none;
  color: #999;
  font-size: 24px;
  cursor: pointer;
  padding: 0;
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(9px);
  opacity: .2;
  z-index: 500;  
  display: block;
  width: 24px;
  height: 24px;
  background: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" fill="%23FFFFFF" viewBox="0 0 24 24" stroke="currentColor" class="password-toggle"%3E%3Cpath stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 4C6 4 2 7 2 12s4 8 10 8 10-3 10-8-4-8-10-8zM12 15c-1.66 0-3-1.34-3-3s1.34-3 3-3 3 1.34 3 3-1.34 3-3 3z"%3E%3C/path%3E%3C/svg%3E') no-repeat center;
  background-size: contain;
}

.password-toggle:hover {
  color: #FFD700;
  opacity: .3;
}

.field-error {
  border-color: #ff4d4d;
  background: linear-gradient(145deg, rgba(255, 255, 30, 0.3), rgba(0, 0, 0, 0))!important;
  border: 1px solid #aaa!important;
}

.field-error::placeholder {
 color:#fff;
}

.select-wrapper select.field-error {
  border-color: #ff4d4d;
  background: linear-gradient(145deg, rgba(120, 20, 20, 0.5), rgba(80, 0, 0, 0.5));
}


.terms-optin-wrapper u b.field-error {
  border-color: #ff4d4d;
  border: 2px solid #ff5!important;
}

@keyframes shake {
  0%   { transform: translateX(0); }
  20%  { transform: translateX(-5px); }
  40%  { transform: translateX(5px); }
  60%  { transform: translateX(-5px); }
  80%  { transform: translateX(5px); }
  100% { transform: translateX(0); }
}

.shake {
  animation: shake 0.3s;
}

.field-error-msg {
 color: #ff5;
 font-size: 14px;
 line-height: 24px;
 margin: 32px 0 -12px!important;
 padding-left: 5px;
 border-radius:8px;
 text-align:left;
}

.form-global-error {
  color: #fe5;
  text-align: center;
  padding: 8px 12px;
  background: rgba(255,255,255,0.05);
  border-radius: 5px;
  letter-spacing: 1px;
  line-height: 1.5em;
}

/* === Custom Select Dropdown === */

.select-wrapper {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  z-index: 10;
}

.select-wrapper label {
  font-size: 14px;
  color: #fff;
  margin-bottom: 8px;
}

.select-wrapper select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 100%;
  padding: 12px;
  font-size: 16px;
  color: #fff;
  background: linear-gradient(145deg, rgba(51, 51, 51, 0.6), rgba(40, 40, 40, 0.5)); 
  border: 1px solid #555;
  border-radius: 5px;
  outline: none;
  transition: background 0.3s ease, border-color 0.3s ease;
  z-index: 2;
}

.select-wrapper select:focus {
  border-color: #FFD700;
  background: linear-gradient(145deg, rgba(51, 51, 51, 0.8), rgba(30, 30, 30, 0.7)); 
}

.select-wrapper select:hover {
  border-color: #FFD700;
}

.select-wrapper select:focus + label {
  color: #FFD700;
  opacity: 1;
}

.select-wrapper::after {
  content: '▼';
  position: absolute;
  right: 15px;
  top: 60%;
  font-size: 18px;
  color: #fff;
  pointer-events: none;
  z-index: 3;
}

.select-wrapper label {
  order: 1;
}

.select-wrapper select {
  order: 2;
}

.select-wrapper select option {
  color: black;
  background-color: #fff;
  padding: 8px;
}

.select-wrapper select {
  position: relative;
  z-index: 1;
}

.select-wrapper select option:hover {
  background-color: #FFD700;
  color: #121212;
}

select::-ms-expand {
  display: none;
}

select {
  position: relative;
  z-index: 2;
}

/* === custom toggle slider === */

.checkbox-row {
  margin: 16px 0 0 0;
}

.checkbox-wrapper {
  margin: 0;
  display: flex;
  align-items: center;
  flex-direction: row;
  width: 100%;
}

.checkbox-wrapper input[type="checkbox"] {
  display: none;
}

.checkbox-wrapper label {
  display: flex;
  align-items: center;
  cursor: pointer;
  position: relative;
  margin-left: 8px;
  order: 1;
}

.checkbox-wrapper label i {
  font-style: normal;
  color: #fff;
  letter-spacing: 1px;
}

.checkbox-wrapper .slider {
  width: 40px;
  height: 20px;
  background-color: #555;
  border-radius: 50px;
  transition: background-color 0.3s ease;
  position: relative;
  margin-right: 14px;
}

.checkbox-wrapper .slider::before {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 14px;
  height: 14px;
  background-color: #fff;
  border-radius: 50%;
  transition: transform 0.3s ease;
}

.checkbox-wrapper input[type="checkbox"]:checked + label i {
  color: #FFD700;
}

.checkbox-wrapper input[type="checkbox"]:checked + label .slider {
  background-color: #FFD700;
}

.checkbox-wrapper input[type="checkbox"]:checked + label .slider::before {
  transform: translateX(20px);
}

.checkbox-wrapper input[type="checkbox"]:hover + label .slider {
  opacity: 0.8;
}

.checkbox-wrapper input[type="checkbox"]:active + label .slider {
  opacity: 1;
}

.slider-label {
  font-size: 16px;
  color: #fff;
  user-select: none;
  cursor: default;
  line-height: 20px;
  letter-spacing: 0.3px;
  transition: color 0.3s ease;
  order: 2;
}

.checkbox-wrapper input[type="checkbox"]:checked + label + .slider-label {
  color: #FFD700;
}

.checkbox-wrapper label .slider.field-error {
  background-color: #ff4d4d;
}

.checkbox-wrapper .field-error + label .slider {
  background-color: #ff4d4d;
}

.checkbox-wrapper.cbcentered {
  justify-content: center;
  width: 100%;
  margin-left: -12px;
}

/* === terms custom checkbox === */

.terms-optin-wrapper {
  display: flex;
  align-items: center;
  margin: 38px 0 0;
  width: 100%;
}

.terms-optin-wrapper * {
 user-select: none;
}

.terms-optin-wrapper u {
  flex: 0 0 16%;
  width: 16%;
  min-width:42px;
  height: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.terms-optin-wrapper u b {
  position: relative;
  display: inline-block;
  width: 32px;
  height: 32px;
  border: 2px solid #fff;
  border-radius: 4px;
  background: transparent;
  cursor: pointer;
  transition: background-color 0.3s ease, border-color 0.3s ease;
}

.terms-optin-wrapper u b input[type="checkbox"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  z-index: 2;
}

.terms-optin-wrapper u b i {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 1;
}

.terms-optin-wrapper u b input[type="checkbox"]:checked + i {
  background-color: #FFD700;
  border-color: #FFD700;
}

.terms-optin-wrapper u b input[type="checkbox"]:checked + i::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 20px;
  height: 20px;
  background: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" fill="none" stroke="%23121212" stroke-width="4" viewBox="0 0 24 24"%3E%3Cpath stroke-linecap="round" stroke-linejoin="round" d="M5 13l4 4L19 7"/%3E%3C/svg%3E') no-repeat center center;
  background-size: contain;
}

.terms-optin-wrapper .terms_lbl {
  flex: 1;
  font-size: 16px;
  color: #FFD700;
  padding-left: 9px;
}

.terms-optin-wrapper .terms_lbl a {
  color: #FFD700;
  text-decoration: none;
  transition: color 0.3s ease;
}

.terms-optin-wrapper .terms_lbl a:hover {
  color: #ffcc00;
  text-decoration: underline;
}

/* === Captcha === */

.hide-captcha {
 display: none;
}

.captchabox {
 margin: 32px 0;
}

.captchabox:empty {
 display:none;
}

.captchaimg-box {
 display: block; 
 text-align: center;
}

.captchaimg-box img {
 width: 100%; 
 box-shadow: 0 0 5px #333;
 border: 0;
 border-radius:5px;
 filter: contrast(1.2);
 transition: all .5s ease;
}

.captcha-reload {
 display: inline-block;
 margin: 12px 0 0;
 color: #e6b800;
}

.captcha-reload:hover {
 color: #FFD700;
 cursor: pointer;
}

.captcha-reload:active {
 text-shadow: 0 0 3px #aa0;
}

.captcha-reload .reload-icon {
  background: url('/ext/assets/refresh.svg') center center no-repeat;
  background-size: contain;
  width: 22px;
  height: 22px;
  display: inline-block;
  margin: 3px 7px 3px 0;
  cursor: pointer;
  transition: transform 0.23s cubic-bezier(.7,.3,.3,1);
  vertical-align: middle;
}

.captcha-reload:hover .reload-icon {
  transform: rotate(-360deg) scale(1.08);
  filter: drop-shadow(0 0 4px #ffec80);
}

.captcha-reload:active .reload-icon {
 transform: rotate(60deg) scale(1.08);
}

@keyframes spin {
  0% { transform: rotate(0deg) }
  100% { transform: rotate(360deg) }
}

/* === Responsive === */

@media (max-width: 480px) {
  .auth-card {
    margin: auto;
    padding: 15px 26px;
    max-width: 100%;
    min-width:280px;
    border-radius: 0;
    border:0;
    box-shadow: none;
  }

  .auth-card__tab {
    font-size: 14px;
    padding: 10px 0;
  }

  .auth-card__submit {
    font-size: 14px;
    padding: 12px;
  }

  .auth-card__form p {
    gap: 5px;
  }

  .auth-card__form p label {
    gap: 5px;
    margin: 15px 0 1px 3px;
  }

  .auth-card__form select,
  .auth-card__form input {
    padding: 0 10px;
    font-size: 18px;
    height: 58px;
    line-height: 58px;
  }
  
  .password-toggle {
    right: 12px;
    top: 48%;
    transform: translateY(9px);
    opacity: .3;
  }
  
  .field-error-msg {
    margin: 22px 0 -8px!important;
    padding-left: 3px!important;
  }
  
  .form-global-error {
    font-size: 0.8em;
    letter-spacing: 1px;
  }
}

@media (min-width: 481px) and (max-width: 768px) {
  .auth-card {
    padding: 20px;
    max-width: 90%;
  }

  .auth-card__tab {
    font-size: 15px;
    padding: 11px 0;
  }

  .auth-card__submit {
    font-size: 15px;
    padding: 13px;
  }

  .auth-card__form p {
    gap: 5px;
  }

  .auth-card__form p label {
    gap: 5px;
    margin: 17px 0 1px 3px;
  }

  .auth-card__form select,
  .auth-card__form input {
    padding: 0 11px;
    font-size: 18px;
    height: 58px;
    line-height: 58px;
  }
  
  .password-toggle {    
    right: 12px;
    top: 48%;
    transform: translateY(9px);
    opacity: .3;
  }
}
