
main {
  min-height: calc( 100dvh - 160px );
}
.mb20 {
  margin-bottom: 20px;
}
#form-forget{
  .forget-links{
    text-align: center;
  }
}
.form-login{
  width: 600px;
  max-width: 95vw;
  display: block;
  margin: 20px auto 40px;
  border-radius: 10px;
  box-shadow: 1px 1px 5px rgba(0,0,0,0.2);
  padding: 15px;
  min-height:  200px;
  
  
  
  
  
  
  h1 {
    font-size: 14px;
    text-align: center;
    margin-bottom: 20px;
  }
  label:has(input[name="agree"]) {
    display: flex;
    align-items: center;
    a { margin: 0px; color: #0000ff; }
    input {
      display: inline-block;
      margin-right: 5px;
    }
    margin-bottom: 10px;
  }
  .inp-field {
    border: 1px solid #999999;
    border-radius: 4px;
    position: relative;
    margin-bottom: 20px;
    label {
      position: absolute;
      font-size: 14px;
      color: #666666;
      transition: 0.5s;
      background: #ffffff;
      padding: 0px 5px;
      font-size: 12px;
      top: -9px;
      left: 5px;
      
    }
    button.inp-clear {
      position: absolute;
      top: 12px;
      right: 10px;
      border: 0px;
      font-size: 12px;
      background: #aaaaaa;
      color: #ffffff;
      display: block;
      width: 20px;
      height: 20px;
      border-radius: 100px;
    }
    p.note {
      background: #ffeecc;
      border-radius: 0px 0px 4px 4px;
      font-size: 10px;
      padding: 3px 10px;
    }
    input{
      border: 0px;
      border-radius: 4px;
      outline: none;
      font-size: 16px;
      padding: 10px;
      padding-top: 15px;
      width: 100%;
    }
  }
  p.pending {
    background: #dddddd;
    border-left: #999999 3px solid;
    padding: 5px 10px;
    border-radius: 4px;
    margin-bottom: 20px;    
  }
  .notice.success,
  p.complete {
    background: #dcf5cb;
    border-left: #61d12b 3px solid;
    padding: 5px 10px;
    border-radius: 4px;
    margin-bottom: 20px;
  }
  p.error{
    background: #ffcccc;
    border-left: #ff6666 3px solid;
    padding: 5px 10px;
    border-radius: 4px;
    margin-bottom: 20px;
  }
  
  .btn_primary {
    display: block;
    width: 100%;
    margin-bottom: 20px;
  }
  a{
    display: block;
    color: #000000;
    margin-bottom: 10px;
  }
}

.btn_primary{
  background: var(--col-main);
  border: 0px;
  color: #000000;
  padding: 10px 30px;
  border-radius: 4px;
}
.btn_secondary {
  border: 2px solid #cccccc;
  border-radius: 4px;
  padding: 10px;
}

#regist-comp {
  p.comp {
    margin-bottom: 5px;
  }
  .inp-field {
    margin-bottom: 5px;
  }
  pre {
    margin-bottom: 30px;
  }
  #sms_resend{
    margin-bottom: 30px;
    font-size: 12px;
    padding: 2px 10px;
    border: 1px solid var(--col-main);
    border-radius: 4px;
    background: #ffffff;
    color: #000000;
    
  }
  #sms_resend[disabled]{
    border: 1px solid #999999;
    background: #eeeeee;
    color: #999999;
    
  }
  #phone{
    font-family: monospace;
    letter-spacing: 5px;
  }
  #sms_code {
    font-family: monospace;
    text-align: center;
    letter-spacing: 5px;
  }
  #btn_sms{
    margin-bottom: 5px;
  }
  #btn_sms[disabled] {
    background: #cccccc;
  }
}
